LaravelTest
8782 строки · 229.8 Кб
1/*!
2* jQuery JavaScript Library v3.6.0 -ajax,-ajax/jsonp,-ajax/load,-ajax/script,-ajax/var/location,-ajax/var/nonce,-ajax/var/rquery,-ajax/xhr,-manipulation/_evalUrl,-deprecated/ajax-event-alias,-effects,-effects/Tween,-effects/animatedSelector
3* https://jquery.com/
4*
5* Includes Sizzle.js
6* https://sizzlejs.com/
7*
8* Copyright OpenJS Foundation and other contributors
9* Released under the MIT license
10* https://jquery.org/license
11*
12* Date: 2021-03-02T17:08Z
13*/
14( function( global, factory ) {15
16"use strict";17
18if ( typeof module === "object" && typeof module.exports === "object" ) {19
20// For CommonJS and CommonJS-like environments where a proper `window`21// is present, execute the factory and get jQuery.22// For environments that do not have a `window` with a `document`23// (such as Node.js), expose a factory as module.exports.24// This accentuates the need for the creation of a real `window`.25// e.g. var jQuery = require("jquery")(window);26// See ticket #14549 for more info.27module.exports = global.document ?28factory( global, true ) :29function( w ) {30if ( !w.document ) {31throw new Error( "jQuery requires a window with a document" );32}33return factory( w );34};35} else {36factory( global );37}38
39// Pass this if window is not defined yet
40} )( typeof window !== "undefined" ? window : this, function( window, noGlobal ) {41
42// Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1
43// throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode
44// arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common
45// enough that all such attempts are guarded in a try block.
46"use strict";47
48var arr = [];49
50var getProto = Object.getPrototypeOf;51
52var slice = arr.slice;53
54var flat = arr.flat ? function( array ) {55return arr.flat.call( array );56} : function( array ) {57return arr.concat.apply( [], array );58};59
60
61var push = arr.push;62
63var indexOf = arr.indexOf;64
65var class2type = {};66
67var toString = class2type.toString;68
69var hasOwn = class2type.hasOwnProperty;70
71var fnToString = hasOwn.toString;72
73var ObjectFunctionString = fnToString.call( Object );74
75var support = {};76
77var isFunction = function isFunction( obj ) {78
79// Support: Chrome <=57, Firefox <=5280// In some browsers, typeof returns "function" for HTML <object> elements81// (i.e., `typeof document.createElement( "object" ) === "function"`).82// We don't want to classify *any* DOM node as a function.83// Support: QtWeb <=3.8.5, WebKit <=534.34, wkhtmltopdf tool <=0.12.584// Plus for old WebKit, typeof returns "function" for HTML collections85// (e.g., `typeof document.getElementsByTagName("div") === "function"`). (gh-4756)86return typeof obj === "function" && typeof obj.nodeType !== "number" &&87typeof obj.item !== "function";88};89
90
91var isWindow = function isWindow( obj ) {92return obj != null && obj === obj.window;93};94
95
96var document = window.document;97
98
99
100var preservedScriptAttributes = {101type: true,102src: true,103nonce: true,104noModule: true105};106
107function DOMEval( code, node, doc ) {108doc = doc || document;109
110var i, val,111script = doc.createElement( "script" );112
113script.text = code;114if ( node ) {115for ( i in preservedScriptAttributes ) {116
117// Support: Firefox 64+, Edge 18+118// Some browsers don't support the "nonce" property on scripts.119// On the other hand, just using `getAttribute` is not enough as120// the `nonce` attribute is reset to an empty string whenever it121// becomes browsing-context connected.122// See https://github.com/whatwg/html/issues/2369123// See https://html.spec.whatwg.org/#nonce-attributes124// The `node.getAttribute` check was added for the sake of125// `jQuery.globalEval` so that it can fake a nonce-containing node126// via an object.127val = node[ i ] || node.getAttribute && node.getAttribute( i );128if ( val ) {129script.setAttribute( i, val );130}131}132}133doc.head.appendChild( script ).parentNode.removeChild( script );134}135
136
137function toType( obj ) {138if ( obj == null ) {139return obj + "";140}141
142// Support: Android <=2.3 only (functionish RegExp)143return typeof obj === "object" || typeof obj === "function" ?144class2type[ toString.call( obj ) ] || "object" :145typeof obj;146}
147/* global Symbol */
148// Defining this global in .eslintrc.json would create a danger of using the global
149// unguarded in another place, it seems safer to define global only for this module
150
151
152
153var
154version = "3.6.0 -ajax,-ajax/jsonp,-ajax/load,-ajax/script,-ajax/var/location,-ajax/var/nonce,-ajax/var/rquery,-ajax/xhr,-manipulation/_evalUrl,-deprecated/ajax-event-alias,-effects,-effects/Tween,-effects/animatedSelector",155
156// Define a local copy of jQuery157jQuery = function( selector, context ) {158
159// The jQuery object is actually just the init constructor 'enhanced'160// Need init if jQuery is called (just allow error to be thrown if not included)161return new jQuery.fn.init( selector, context );162};163
164jQuery.fn = jQuery.prototype = {165
166// The current version of jQuery being used167jquery: version,168
169constructor: jQuery,170
171// The default length of a jQuery object is 0172length: 0,173
174toArray: function() {175return slice.call( this );176},177
178// Get the Nth element in the matched element set OR179// Get the whole matched element set as a clean array180get: function( num ) {181
182// Return all the elements in a clean array183if ( num == null ) {184return slice.call( this );185}186
187// Return just the one element from the set188return num < 0 ? this[ num + this.length ] : this[ num ];189},190
191// Take an array of elements and push it onto the stack192// (returning the new matched element set)193pushStack: function( elems ) {194
195// Build a new jQuery matched element set196var ret = jQuery.merge( this.constructor(), elems );197
198// Add the old object onto the stack (as a reference)199ret.prevObject = this;200
201// Return the newly-formed element set202return ret;203},204
205// Execute a callback for every element in the matched set.206each: function( callback ) {207return jQuery.each( this, callback );208},209
210map: function( callback ) {211return this.pushStack( jQuery.map( this, function( elem, i ) {212return callback.call( elem, i, elem );213} ) );214},215
216slice: function() {217return this.pushStack( slice.apply( this, arguments ) );218},219
220first: function() {221return this.eq( 0 );222},223
224last: function() {225return this.eq( -1 );226},227
228even: function() {229return this.pushStack( jQuery.grep( this, function( _elem, i ) {230return ( i + 1 ) % 2;231} ) );232},233
234odd: function() {235return this.pushStack( jQuery.grep( this, function( _elem, i ) {236return i % 2;237} ) );238},239
240eq: function( i ) {241var len = this.length,242j = +i + ( i < 0 ? len : 0 );243return this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] );244},245
246end: function() {247return this.prevObject || this.constructor();248},249
250// For internal use only.251// Behaves like an Array's method, not like a jQuery method.252push: push,253sort: arr.sort,254splice: arr.splice255};256
257jQuery.extend = jQuery.fn.extend = function() {258var options, name, src, copy, copyIsArray, clone,259target = arguments[ 0 ] || {},260i = 1,261length = arguments.length,262deep = false;263
264// Handle a deep copy situation265if ( typeof target === "boolean" ) {266deep = target;267
268// Skip the boolean and the target269target = arguments[ i ] || {};270i++;271}272
273// Handle case when target is a string or something (possible in deep copy)274if ( typeof target !== "object" && !isFunction( target ) ) {275target = {};276}277
278// Extend jQuery itself if only one argument is passed279if ( i === length ) {280target = this;281i--;282}283
284for ( ; i < length; i++ ) {285
286// Only deal with non-null/undefined values287if ( ( options = arguments[ i ] ) != null ) {288
289// Extend the base object290for ( name in options ) {291copy = options[ name ];292
293// Prevent Object.prototype pollution294// Prevent never-ending loop295if ( name === "__proto__" || target === copy ) {296continue;297}298
299// Recurse if we're merging plain objects or arrays300if ( deep && copy && ( jQuery.isPlainObject( copy ) ||301( copyIsArray = Array.isArray( copy ) ) ) ) {302src = target[ name ];303
304// Ensure proper type for the source value305if ( copyIsArray && !Array.isArray( src ) ) {306clone = [];307} else if ( !copyIsArray && !jQuery.isPlainObject( src ) ) {308clone = {};309} else {310clone = src;311}312copyIsArray = false;313
314// Never move original objects, clone them315target[ name ] = jQuery.extend( deep, clone, copy );316
317// Don't bring in undefined values318} else if ( copy !== undefined ) {319target[ name ] = copy;320}321}322}323}324
325// Return the modified object326return target;327};328
329jQuery.extend( {330
331// Unique for each copy of jQuery on the page332expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ),333
334// Assume jQuery is ready without the ready module335isReady: true,336
337error: function( msg ) {338throw new Error( msg );339},340
341noop: function() {},342
343isPlainObject: function( obj ) {344var proto, Ctor;345
346// Detect obvious negatives347// Use toString instead of jQuery.type to catch host objects348if ( !obj || toString.call( obj ) !== "[object Object]" ) {349return false;350}351
352proto = getProto( obj );353
354// Objects with no prototype (e.g., `Object.create( null )`) are plain355if ( !proto ) {356return true;357}358
359// Objects with prototype are plain iff they were constructed by a global Object function360Ctor = hasOwn.call( proto, "constructor" ) && proto.constructor;361return typeof Ctor === "function" && fnToString.call( Ctor ) === ObjectFunctionString;362},363
364isEmptyObject: function( obj ) {365var name;366
367for ( name in obj ) {368return false;369}370return true;371},372
373// Evaluates a script in a provided context; falls back to the global one374// if not specified.375globalEval: function( code, options, doc ) {376DOMEval( code, { nonce: options && options.nonce }, doc );377},378
379each: function( obj, callback ) {380var length, i = 0;381
382if ( isArrayLike( obj ) ) {383length = obj.length;384for ( ; i < length; i++ ) {385if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {386break;387}388}389} else {390for ( i in obj ) {391if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {392break;393}394}395}396
397return obj;398},399
400// results is for internal usage only401makeArray: function( arr, results ) {402var ret = results || [];403
404if ( arr != null ) {405if ( isArrayLike( Object( arr ) ) ) {406jQuery.merge( ret,407typeof arr === "string" ?408[ arr ] : arr409);410} else {411push.call( ret, arr );412}413}414
415return ret;416},417
418inArray: function( elem, arr, i ) {419return arr == null ? -1 : indexOf.call( arr, elem, i );420},421
422// Support: Android <=4.0 only, PhantomJS 1 only423// push.apply(_, arraylike) throws on ancient WebKit424merge: function( first, second ) {425var len = +second.length,426j = 0,427i = first.length;428
429for ( ; j < len; j++ ) {430first[ i++ ] = second[ j ];431}432
433first.length = i;434
435return first;436},437
438grep: function( elems, callback, invert ) {439var callbackInverse,440matches = [],441i = 0,442length = elems.length,443callbackExpect = !invert;444
445// Go through the array, only saving the items446// that pass the validator function447for ( ; i < length; i++ ) {448callbackInverse = !callback( elems[ i ], i );449if ( callbackInverse !== callbackExpect ) {450matches.push( elems[ i ] );451}452}453
454return matches;455},456
457// arg is for internal usage only458map: function( elems, callback, arg ) {459var length, value,460i = 0,461ret = [];462
463// Go through the array, translating each of the items to their new values464if ( isArrayLike( elems ) ) {465length = elems.length;466for ( ; i < length; i++ ) {467value = callback( elems[ i ], i, arg );468
469if ( value != null ) {470ret.push( value );471}472}473
474// Go through every key on the object,475} else {476for ( i in elems ) {477value = callback( elems[ i ], i, arg );478
479if ( value != null ) {480ret.push( value );481}482}483}484
485// Flatten any nested arrays486return flat( ret );487},488
489// A global GUID counter for objects490guid: 1,491
492// jQuery.support is not used in Core but other projects attach their493// properties to it so it needs to exist.494support: support495} );496
497if ( typeof Symbol === "function" ) {498jQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ];499}
500
501// Populate the class2type map
502jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ),503function( _i, name ) {504class2type[ "[object " + name + "]" ] = name.toLowerCase();505} );506
507function isArrayLike( obj ) {508
509// Support: real iOS 8.2 only (not reproducible in simulator)510// `in` check used to prevent JIT error (gh-2145)511// hasOwn isn't used here due to false negatives512// regarding Nodelist length in IE513var length = !!obj && "length" in obj && obj.length,514type = toType( obj );515
516if ( isFunction( obj ) || isWindow( obj ) ) {517return false;518}519
520return type === "array" || length === 0 ||521typeof length === "number" && length > 0 && ( length - 1 ) in obj;522}
523var Sizzle =524/*!
525* Sizzle CSS Selector Engine v2.3.6
526* https://sizzlejs.com/
527*
528* Copyright JS Foundation and other contributors
529* Released under the MIT license
530* https://js.foundation/
531*
532* Date: 2021-02-16
533*/
534( function( window ) {535var i,536support,537Expr,538getText,539isXML,540tokenize,541compile,542select,543outermostContext,544sortInput,545hasDuplicate,546
547// Local document vars548setDocument,549document,550docElem,551documentIsHTML,552rbuggyQSA,553rbuggyMatches,554matches,555contains,556
557// Instance-specific data558expando = "sizzle" + 1 * new Date(),559preferredDoc = window.document,560dirruns = 0,561done = 0,562classCache = createCache(),563tokenCache = createCache(),564compilerCache = createCache(),565nonnativeSelectorCache = createCache(),566sortOrder = function( a, b ) {567if ( a === b ) {568hasDuplicate = true;569}570return 0;571},572
573// Instance methods574hasOwn = ( {} ).hasOwnProperty,575arr = [],576pop = arr.pop,577pushNative = arr.push,578push = arr.push,579slice = arr.slice,580
581// Use a stripped-down indexOf as it's faster than native582// https://jsperf.com/thor-indexof-vs-for/5583indexOf = function( list, elem ) {584var i = 0,585len = list.length;586for ( ; i < len; i++ ) {587if ( list[ i ] === elem ) {588return i;589}590}591return -1;592},593
594booleans = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|" +595"ismap|loop|multiple|open|readonly|required|scoped",596
597// Regular expressions598
599// http://www.w3.org/TR/css3-selectors/#whitespace600whitespace = "[\\x20\\t\\r\\n\\f]",601
602// https://www.w3.org/TR/css-syntax-3/#ident-token-diagram603identifier = "(?:\\\\[\\da-fA-F]{1,6}" + whitespace +604"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",605
606// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors607attributes = "\\[" + whitespace + "*(" + identifier + ")(?:" + whitespace +608
609// Operator (capture 2)610"*([*^$|!~]?=)" + whitespace +611
612// "Attribute values must be CSS identifiers [capture 5]613// or strings [capture 3 or capture 4]"614"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" +615whitespace + "*\\]",616
617pseudos = ":(" + identifier + ")(?:\\((" +618
619// To reduce the number of selectors needing tokenize in the preFilter, prefer arguments:620// 1. quoted (capture 3; capture 4 or capture 5)621"('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|" +622
623// 2. simple (capture 6)624"((?:\\\\.|[^\\\\()[\\]]|" + attributes + ")*)|" +625
626// 3. anything else (capture 2)627".*" +628")\\)|)",629
630// Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter631rwhitespace = new RegExp( whitespace + "+", "g" ),632rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" +633whitespace + "+$", "g" ),634
635rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ),636rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace +637"*" ),638rdescend = new RegExp( whitespace + "|>" ),639
640rpseudo = new RegExp( pseudos ),641ridentifier = new RegExp( "^" + identifier + "$" ),642
643matchExpr = {644"ID": new RegExp( "^#(" + identifier + ")" ),645"CLASS": new RegExp( "^\\.(" + identifier + ")" ),646"TAG": new RegExp( "^(" + identifier + "|[*])" ),647"ATTR": new RegExp( "^" + attributes ),648"PSEUDO": new RegExp( "^" + pseudos ),649"CHILD": new RegExp( "^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" +650whitespace + "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" +651whitespace + "*(\\d+)|))" + whitespace + "*\\)|)", "i" ),652"bool": new RegExp( "^(?:" + booleans + ")$", "i" ),653
654// For use in libraries implementing .is()655// We use this for POS matching in `select`656"needsContext": new RegExp( "^" + whitespace +657"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + whitespace +658"*((?:-\\d)?\\d*)" + whitespace + "*\\)|)(?=[^-]|$)", "i" )659},660
661rhtml = /HTML$/i,662rinputs = /^(?:input|select|textarea|button)$/i,663rheader = /^h\d$/i,664
665rnative = /^[^{]+\{\s*\[native \w/,666
667// Easily-parseable/retrievable ID or TAG or CLASS selectors668rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,669
670rsibling = /[+~]/,671
672// CSS escapes673// http://www.w3.org/TR/CSS21/syndata.html#escaped-characters674runescape = new RegExp( "\\\\[\\da-fA-F]{1,6}" + whitespace + "?|\\\\([^\\r\\n\\f])", "g" ),675funescape = function( escape, nonHex ) {676var high = "0x" + escape.slice( 1 ) - 0x10000;677
678return nonHex ?679
680// Strip the backslash prefix from a non-hex escape sequence681nonHex :682
683// Replace a hexadecimal escape sequence with the encoded Unicode code point684// Support: IE <=11+685// For values outside the Basic Multilingual Plane (BMP), manually construct a686// surrogate pair687high < 0 ?688String.fromCharCode( high + 0x10000 ) :689String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 );690},691
692// CSS string/identifier serialization693// https://drafts.csswg.org/cssom/#common-serializing-idioms694rcssescape = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,695fcssescape = function( ch, asCodePoint ) {696if ( asCodePoint ) {697
698// U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER699if ( ch === "\0" ) {700return "\uFFFD";701}702
703// Control characters and (dependent upon position) numbers get escaped as code points704return ch.slice( 0, -1 ) + "\\" +705ch.charCodeAt( ch.length - 1 ).toString( 16 ) + " ";706}707
708// Other potentially-special ASCII characters get backslash-escaped709return "\\" + ch;710},711
712// Used for iframes713// See setDocument()714// Removing the function wrapper causes a "Permission Denied"715// error in IE716unloadHandler = function() {717setDocument();718},719
720inDisabledFieldset = addCombinator(721function( elem ) {722return elem.disabled === true && elem.nodeName.toLowerCase() === "fieldset";723},724{ dir: "parentNode", next: "legend" }725);726
727// Optimize for push.apply( _, NodeList )
728try {729push.apply(730( arr = slice.call( preferredDoc.childNodes ) ),731preferredDoc.childNodes732);733
734// Support: Android<4.0735// Detect silently failing push.apply736// eslint-disable-next-line no-unused-expressions737arr[ preferredDoc.childNodes.length ].nodeType;738} catch ( e ) {739push = { apply: arr.length ?740
741// Leverage slice if possible742function( target, els ) {743pushNative.apply( target, slice.call( els ) );744} :745
746// Support: IE<9747// Otherwise append directly748function( target, els ) {749var j = target.length,750i = 0;751
752// Can't trust NodeList.length753while ( ( target[ j++ ] = els[ i++ ] ) ) {}754target.length = j - 1;755}756};757}
758
759function Sizzle( selector, context, results, seed ) {760var m, i, elem, nid, match, groups, newSelector,761newContext = context && context.ownerDocument,762
763// nodeType defaults to 9, since context defaults to document764nodeType = context ? context.nodeType : 9;765
766results = results || [];767
768// Return early from calls with invalid selector or context769if ( typeof selector !== "string" || !selector ||770nodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) {771
772return results;773}774
775// Try to shortcut find operations (as opposed to filters) in HTML documents776if ( !seed ) {777setDocument( context );778context = context || document;779
780if ( documentIsHTML ) {781
782// If the selector is sufficiently simple, try using a "get*By*" DOM method783// (excepting DocumentFragment context, where the methods don't exist)784if ( nodeType !== 11 && ( match = rquickExpr.exec( selector ) ) ) {785
786// ID selector787if ( ( m = match[ 1 ] ) ) {788
789// Document context790if ( nodeType === 9 ) {791if ( ( elem = context.getElementById( m ) ) ) {792
793// Support: IE, Opera, Webkit794// TODO: identify versions795// getElementById can match elements by name instead of ID796if ( elem.id === m ) {797results.push( elem );798return results;799}800} else {801return results;802}803
804// Element context805} else {806
807// Support: IE, Opera, Webkit808// TODO: identify versions809// getElementById can match elements by name instead of ID810if ( newContext && ( elem = newContext.getElementById( m ) ) &&811contains( context, elem ) &&812elem.id === m ) {813
814results.push( elem );815return results;816}817}818
819// Type selector820} else if ( match[ 2 ] ) {821push.apply( results, context.getElementsByTagName( selector ) );822return results;823
824// Class selector825} else if ( ( m = match[ 3 ] ) && support.getElementsByClassName &&826context.getElementsByClassName ) {827
828push.apply( results, context.getElementsByClassName( m ) );829return results;830}831}832
833// Take advantage of querySelectorAll834if ( support.qsa &&835!nonnativeSelectorCache[ selector + " " ] &&836( !rbuggyQSA || !rbuggyQSA.test( selector ) ) &&837
838// Support: IE 8 only839// Exclude object elements840( nodeType !== 1 || context.nodeName.toLowerCase() !== "object" ) ) {841
842newSelector = selector;843newContext = context;844
845// qSA considers elements outside a scoping root when evaluating child or846// descendant combinators, which is not what we want.847// In such cases, we work around the behavior by prefixing every selector in the848// list with an ID selector referencing the scope context.849// The technique has to be used as well when a leading combinator is used850// as such selectors are not recognized by querySelectorAll.851// Thanks to Andrew Dupont for this technique.852if ( nodeType === 1 &&853( rdescend.test( selector ) || rcombinators.test( selector ) ) ) {854
855// Expand context for sibling selectors856newContext = rsibling.test( selector ) && testContext( context.parentNode ) ||857context;858
859// We can use :scope instead of the ID hack if the browser860// supports it & if we're not changing the context.861if ( newContext !== context || !support.scope ) {862
863// Capture the context ID, setting it first if necessary864if ( ( nid = context.getAttribute( "id" ) ) ) {865nid = nid.replace( rcssescape, fcssescape );866} else {867context.setAttribute( "id", ( nid = expando ) );868}869}870
871// Prefix every selector in the list872groups = tokenize( selector );873i = groups.length;874while ( i-- ) {875groups[ i ] = ( nid ? "#" + nid : ":scope" ) + " " +876toSelector( groups[ i ] );877}878newSelector = groups.join( "," );879}880
881try {882push.apply( results,883newContext.querySelectorAll( newSelector )884);885return results;886} catch ( qsaError ) {887nonnativeSelectorCache( selector, true );888} finally {889if ( nid === expando ) {890context.removeAttribute( "id" );891}892}893}894}895}896
897// All others898return select( selector.replace( rtrim, "$1" ), context, results, seed );899}
900
901/**
902* Create key-value caches of limited size
903* @returns {function(string, object)} Returns the Object data after storing it on itself with
904* property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength)
905* deleting the oldest entry
906*/
907function createCache() {908var keys = [];909
910function cache( key, value ) {911
912// Use (key + " ") to avoid collision with native prototype properties (see Issue #157)913if ( keys.push( key + " " ) > Expr.cacheLength ) {914
915// Only keep the most recent entries916delete cache[ keys.shift() ];917}918return ( cache[ key + " " ] = value );919}920return cache;921}
922
923/**
924* Mark a function for special use by Sizzle
925* @param {Function} fn The function to mark
926*/
927function markFunction( fn ) {928fn[ expando ] = true;929return fn;930}
931
932/**
933* Support testing using an element
934* @param {Function} fn Passed the created element and returns a boolean result
935*/
936function assert( fn ) {937var el = document.createElement( "fieldset" );938
939try {940return !!fn( el );941} catch ( e ) {942return false;943} finally {944
945// Remove from its parent by default946if ( el.parentNode ) {947el.parentNode.removeChild( el );948}949
950// release memory in IE951el = null;952}953}
954
955/**
956* Adds the same handler for all of the specified attrs
957* @param {String} attrs Pipe-separated list of attributes
958* @param {Function} handler The method that will be applied
959*/
960function addHandle( attrs, handler ) {961var arr = attrs.split( "|" ),962i = arr.length;963
964while ( i-- ) {965Expr.attrHandle[ arr[ i ] ] = handler;966}967}
968
969/**
970* Checks document order of two siblings
971* @param {Element} a
972* @param {Element} b
973* @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b
974*/
975function siblingCheck( a, b ) {976var cur = b && a,977diff = cur && a.nodeType === 1 && b.nodeType === 1 &&978a.sourceIndex - b.sourceIndex;979
980// Use IE sourceIndex if available on both nodes981if ( diff ) {982return diff;983}984
985// Check if b follows a986if ( cur ) {987while ( ( cur = cur.nextSibling ) ) {988if ( cur === b ) {989return -1;990}991}992}993
994return a ? 1 : -1;995}
996
997/**
998* Returns a function to use in pseudos for input types
999* @param {String} type
1000*/
1001function createInputPseudo( type ) {1002return function( elem ) {1003var name = elem.nodeName.toLowerCase();1004return name === "input" && elem.type === type;1005};1006}
1007
1008/**
1009* Returns a function to use in pseudos for buttons
1010* @param {String} type
1011*/
1012function createButtonPseudo( type ) {1013return function( elem ) {1014var name = elem.nodeName.toLowerCase();1015return ( name === "input" || name === "button" ) && elem.type === type;1016};1017}
1018
1019/**
1020* Returns a function to use in pseudos for :enabled/:disabled
1021* @param {Boolean} disabled true for :disabled; false for :enabled
1022*/
1023function createDisabledPseudo( disabled ) {1024
1025// Known :disabled false positives: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable1026return function( elem ) {1027
1028// Only certain elements can match :enabled or :disabled1029// https://html.spec.whatwg.org/multipage/scripting.html#selector-enabled1030// https://html.spec.whatwg.org/multipage/scripting.html#selector-disabled1031if ( "form" in elem ) {1032
1033// Check for inherited disabledness on relevant non-disabled elements:1034// * listed form-associated elements in a disabled fieldset1035// https://html.spec.whatwg.org/multipage/forms.html#category-listed1036// https://html.spec.whatwg.org/multipage/forms.html#concept-fe-disabled1037// * option elements in a disabled optgroup1038// https://html.spec.whatwg.org/multipage/forms.html#concept-option-disabled1039// All such elements have a "form" property.1040if ( elem.parentNode && elem.disabled === false ) {1041
1042// Option elements defer to a parent optgroup if present1043if ( "label" in elem ) {1044if ( "label" in elem.parentNode ) {1045return elem.parentNode.disabled === disabled;1046} else {1047return elem.disabled === disabled;1048}1049}1050
1051// Support: IE 6 - 111052// Use the isDisabled shortcut property to check for disabled fieldset ancestors1053return elem.isDisabled === disabled ||1054
1055// Where there is no isDisabled, check manually1056/* jshint -W018 */1057elem.isDisabled !== !disabled &&1058inDisabledFieldset( elem ) === disabled;1059}1060
1061return elem.disabled === disabled;1062
1063// Try to winnow out elements that can't be disabled before trusting the disabled property.1064// Some victims get caught in our net (label, legend, menu, track), but it shouldn't1065// even exist on them, let alone have a boolean value.1066} else if ( "label" in elem ) {1067return elem.disabled === disabled;1068}1069
1070// Remaining elements are neither :enabled nor :disabled1071return false;1072};1073}
1074
1075/**
1076* Returns a function to use in pseudos for positionals
1077* @param {Function} fn
1078*/
1079function createPositionalPseudo( fn ) {1080return markFunction( function( argument ) {1081argument = +argument;1082return markFunction( function( seed, matches ) {1083var j,1084matchIndexes = fn( [], seed.length, argument ),1085i = matchIndexes.length;1086
1087// Match elements found at the specified indexes1088while ( i-- ) {1089if ( seed[ ( j = matchIndexes[ i ] ) ] ) {1090seed[ j ] = !( matches[ j ] = seed[ j ] );1091}1092}1093} );1094} );1095}
1096
1097/**
1098* Checks a node for validity as a Sizzle context
1099* @param {Element|Object=} context
1100* @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value
1101*/
1102function testContext( context ) {1103return context && typeof context.getElementsByTagName !== "undefined" && context;1104}
1105
1106// Expose support vars for convenience
1107support = Sizzle.support = {};1108
1109/**
1110* Detects XML nodes
1111* @param {Element|Object} elem An element or a document
1112* @returns {Boolean} True iff elem is a non-HTML XML node
1113*/
1114isXML = Sizzle.isXML = function( elem ) {1115var namespace = elem && elem.namespaceURI,1116docElem = elem && ( elem.ownerDocument || elem ).documentElement;1117
1118// Support: IE <=81119// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes1120// https://bugs.jquery.com/ticket/48331121return !rhtml.test( namespace || docElem && docElem.nodeName || "HTML" );1122};1123
1124/**
1125* Sets document-related variables once based on the current document
1126* @param {Element|Object} [doc] An element or document object to use to set the document
1127* @returns {Object} Returns the current document
1128*/
1129setDocument = Sizzle.setDocument = function( node ) {1130var hasCompare, subWindow,1131doc = node ? node.ownerDocument || node : preferredDoc;1132
1133// Return early if doc is invalid or already selected1134// Support: IE 11+, Edge 17 - 18+1135// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1136// two documents; shallow comparisons work.1137// eslint-disable-next-line eqeqeq1138if ( doc == document || doc.nodeType !== 9 || !doc.documentElement ) {1139return document;1140}1141
1142// Update global variables1143document = doc;1144docElem = document.documentElement;1145documentIsHTML = !isXML( document );1146
1147// Support: IE 9 - 11+, Edge 12 - 18+1148// Accessing iframe documents after unload throws "permission denied" errors (jQuery #13936)1149// Support: IE 11+, Edge 17 - 18+1150// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1151// two documents; shallow comparisons work.1152// eslint-disable-next-line eqeqeq1153if ( preferredDoc != document &&1154( subWindow = document.defaultView ) && subWindow.top !== subWindow ) {1155
1156// Support: IE 11, Edge1157if ( subWindow.addEventListener ) {1158subWindow.addEventListener( "unload", unloadHandler, false );1159
1160// Support: IE 9 - 10 only1161} else if ( subWindow.attachEvent ) {1162subWindow.attachEvent( "onunload", unloadHandler );1163}1164}1165
1166// Support: IE 8 - 11+, Edge 12 - 18+, Chrome <=16 - 25 only, Firefox <=3.6 - 31 only,1167// Safari 4 - 5 only, Opera <=11.6 - 12.x only1168// IE/Edge & older browsers don't support the :scope pseudo-class.1169// Support: Safari 6.0 only1170// Safari 6.0 supports :scope but it's an alias of :root there.1171support.scope = assert( function( el ) {1172docElem.appendChild( el ).appendChild( document.createElement( "div" ) );1173return typeof el.querySelectorAll !== "undefined" &&1174!el.querySelectorAll( ":scope fieldset div" ).length;1175} );1176
1177/* Attributes1178---------------------------------------------------------------------- */
1179
1180// Support: IE<81181// Verify that getAttribute really returns attributes and not properties1182// (excepting IE8 booleans)1183support.attributes = assert( function( el ) {1184el.className = "i";1185return !el.getAttribute( "className" );1186} );1187
1188/* getElement(s)By*1189---------------------------------------------------------------------- */
1190
1191// Check if getElementsByTagName("*") returns only elements1192support.getElementsByTagName = assert( function( el ) {1193el.appendChild( document.createComment( "" ) );1194return !el.getElementsByTagName( "*" ).length;1195} );1196
1197// Support: IE<91198support.getElementsByClassName = rnative.test( document.getElementsByClassName );1199
1200// Support: IE<101201// Check if getElementById returns elements by name1202// The broken getElementById methods don't pick up programmatically-set names,1203// so use a roundabout getElementsByName test1204support.getById = assert( function( el ) {1205docElem.appendChild( el ).id = expando;1206return !document.getElementsByName || !document.getElementsByName( expando ).length;1207} );1208
1209// ID filter and find1210if ( support.getById ) {1211Expr.filter[ "ID" ] = function( id ) {1212var attrId = id.replace( runescape, funescape );1213return function( elem ) {1214return elem.getAttribute( "id" ) === attrId;1215};1216};1217Expr.find[ "ID" ] = function( id, context ) {1218if ( typeof context.getElementById !== "undefined" && documentIsHTML ) {1219var elem = context.getElementById( id );1220return elem ? [ elem ] : [];1221}1222};1223} else {1224Expr.filter[ "ID" ] = function( id ) {1225var attrId = id.replace( runescape, funescape );1226return function( elem ) {1227var node = typeof elem.getAttributeNode !== "undefined" &&1228elem.getAttributeNode( "id" );1229return node && node.value === attrId;1230};1231};1232
1233// Support: IE 6 - 7 only1234// getElementById is not reliable as a find shortcut1235Expr.find[ "ID" ] = function( id, context ) {1236if ( typeof context.getElementById !== "undefined" && documentIsHTML ) {1237var node, i, elems,1238elem = context.getElementById( id );1239
1240if ( elem ) {1241
1242// Verify the id attribute1243node = elem.getAttributeNode( "id" );1244if ( node && node.value === id ) {1245return [ elem ];1246}1247
1248// Fall back on getElementsByName1249elems = context.getElementsByName( id );1250i = 0;1251while ( ( elem = elems[ i++ ] ) ) {1252node = elem.getAttributeNode( "id" );1253if ( node && node.value === id ) {1254return [ elem ];1255}1256}1257}1258
1259return [];1260}1261};1262}1263
1264// Tag1265Expr.find[ "TAG" ] = support.getElementsByTagName ?1266function( tag, context ) {1267if ( typeof context.getElementsByTagName !== "undefined" ) {1268return context.getElementsByTagName( tag );1269
1270// DocumentFragment nodes don't have gEBTN1271} else if ( support.qsa ) {1272return context.querySelectorAll( tag );1273}1274} :1275
1276function( tag, context ) {1277var elem,1278tmp = [],1279i = 0,1280
1281// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too1282results = context.getElementsByTagName( tag );1283
1284// Filter out possible comments1285if ( tag === "*" ) {1286while ( ( elem = results[ i++ ] ) ) {1287if ( elem.nodeType === 1 ) {1288tmp.push( elem );1289}1290}1291
1292return tmp;1293}1294return results;1295};1296
1297// Class1298Expr.find[ "CLASS" ] = support.getElementsByClassName && function( className, context ) {1299if ( typeof context.getElementsByClassName !== "undefined" && documentIsHTML ) {1300return context.getElementsByClassName( className );1301}1302};1303
1304/* QSA/matchesSelector1305---------------------------------------------------------------------- */
1306
1307// QSA and matchesSelector support1308
1309// matchesSelector(:active) reports false when true (IE9/Opera 11.5)1310rbuggyMatches = [];1311
1312// qSa(:focus) reports false when true (Chrome 21)1313// We allow this because of a bug in IE8/9 that throws an error1314// whenever `document.activeElement` is accessed on an iframe1315// So, we allow :focus to pass through QSA all the time to avoid the IE error1316// See https://bugs.jquery.com/ticket/133781317rbuggyQSA = [];1318
1319if ( ( support.qsa = rnative.test( document.querySelectorAll ) ) ) {1320
1321// Build QSA regex1322// Regex strategy adopted from Diego Perini1323assert( function( el ) {1324
1325var input;1326
1327// Select is set to empty string on purpose1328// This is to test IE's treatment of not explicitly1329// setting a boolean content attribute,1330// since its presence should be enough1331// https://bugs.jquery.com/ticket/123591332docElem.appendChild( el ).innerHTML = "<a id='" + expando + "'></a>" +1333"<select id='" + expando + "-\r\\' msallowcapture=''>" +1334"<option selected=''></option></select>";1335
1336// Support: IE8, Opera 11-12.161337// Nothing should be selected when empty strings follow ^= or $= or *=1338// The test attribute must be unknown in Opera but "safe" for WinRT1339// https://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section1340if ( el.querySelectorAll( "[msallowcapture^='']" ).length ) {1341rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:''|\"\")" );1342}1343
1344// Support: IE81345// Boolean attributes and "value" are not treated correctly1346if ( !el.querySelectorAll( "[selected]" ).length ) {1347rbuggyQSA.push( "\\[" + whitespace + "*(?:value|" + booleans + ")" );1348}1349
1350// Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+1351if ( !el.querySelectorAll( "[id~=" + expando + "-]" ).length ) {1352rbuggyQSA.push( "~=" );1353}1354
1355// Support: IE 11+, Edge 15 - 18+1356// IE 11/Edge don't find elements on a `[name='']` query in some cases.1357// Adding a temporary attribute to the document before the selection works1358// around the issue.1359// Interestingly, IE 10 & older don't seem to have the issue.1360input = document.createElement( "input" );1361input.setAttribute( "name", "" );1362el.appendChild( input );1363if ( !el.querySelectorAll( "[name='']" ).length ) {1364rbuggyQSA.push( "\\[" + whitespace + "*name" + whitespace + "*=" +1365whitespace + "*(?:''|\"\")" );1366}1367
1368// Webkit/Opera - :checked should return selected option elements1369// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked1370// IE8 throws error here and will not see later tests1371if ( !el.querySelectorAll( ":checked" ).length ) {1372rbuggyQSA.push( ":checked" );1373}1374
1375// Support: Safari 8+, iOS 8+1376// https://bugs.webkit.org/show_bug.cgi?id=1368511377// In-page `selector#id sibling-combinator selector` fails1378if ( !el.querySelectorAll( "a#" + expando + "+*" ).length ) {1379rbuggyQSA.push( ".#.+[+~]" );1380}1381
1382// Support: Firefox <=3.6 - 5 only1383// Old Firefox doesn't throw on a badly-escaped identifier.1384el.querySelectorAll( "\\\f" );1385rbuggyQSA.push( "[\\r\\n\\f]" );1386} );1387
1388assert( function( el ) {1389el.innerHTML = "<a href='' disabled='disabled'></a>" +1390"<select disabled='disabled'><option/></select>";1391
1392// Support: Windows 8 Native Apps1393// The type and name attributes are restricted during .innerHTML assignment1394var input = document.createElement( "input" );1395input.setAttribute( "type", "hidden" );1396el.appendChild( input ).setAttribute( "name", "D" );1397
1398// Support: IE81399// Enforce case-sensitivity of name attribute1400if ( el.querySelectorAll( "[name=d]" ).length ) {1401rbuggyQSA.push( "name" + whitespace + "*[*^$|!~]?=" );1402}1403
1404// FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled)1405// IE8 throws error here and will not see later tests1406if ( el.querySelectorAll( ":enabled" ).length !== 2 ) {1407rbuggyQSA.push( ":enabled", ":disabled" );1408}1409
1410// Support: IE9-11+1411// IE's :disabled selector does not pick up the children of disabled fieldsets1412docElem.appendChild( el ).disabled = true;1413if ( el.querySelectorAll( ":disabled" ).length !== 2 ) {1414rbuggyQSA.push( ":enabled", ":disabled" );1415}1416
1417// Support: Opera 10 - 11 only1418// Opera 10-11 does not throw on post-comma invalid pseudos1419el.querySelectorAll( "*,:x" );1420rbuggyQSA.push( ",.*:" );1421} );1422}1423
1424if ( ( support.matchesSelector = rnative.test( ( matches = docElem.matches ||1425docElem.webkitMatchesSelector ||1426docElem.mozMatchesSelector ||1427docElem.oMatchesSelector ||1428docElem.msMatchesSelector ) ) ) ) {1429
1430assert( function( el ) {1431
1432// Check to see if it's possible to do matchesSelector1433// on a disconnected node (IE 9)1434support.disconnectedMatch = matches.call( el, "*" );1435
1436// This should fail with an exception1437// Gecko does not error, returns false instead1438matches.call( el, "[s!='']:x" );1439rbuggyMatches.push( "!=", pseudos );1440} );1441}1442
1443rbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join( "|" ) );1444rbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join( "|" ) );1445
1446/* Contains1447---------------------------------------------------------------------- */
1448hasCompare = rnative.test( docElem.compareDocumentPosition );1449
1450// Element contains another1451// Purposefully self-exclusive1452// As in, an element does not contain itself1453contains = hasCompare || rnative.test( docElem.contains ) ?1454function( a, b ) {1455var adown = a.nodeType === 9 ? a.documentElement : a,1456bup = b && b.parentNode;1457return a === bup || !!( bup && bup.nodeType === 1 && (1458adown.contains ?1459adown.contains( bup ) :1460a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 161461) );1462} :1463function( a, b ) {1464if ( b ) {1465while ( ( b = b.parentNode ) ) {1466if ( b === a ) {1467return true;1468}1469}1470}1471return false;1472};1473
1474/* Sorting1475---------------------------------------------------------------------- */
1476
1477// Document order sorting1478sortOrder = hasCompare ?1479function( a, b ) {1480
1481// Flag for duplicate removal1482if ( a === b ) {1483hasDuplicate = true;1484return 0;1485}1486
1487// Sort on method existence if only one input has compareDocumentPosition1488var compare = !a.compareDocumentPosition - !b.compareDocumentPosition;1489if ( compare ) {1490return compare;1491}1492
1493// Calculate position if both inputs belong to the same document1494// Support: IE 11+, Edge 17 - 18+1495// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1496// two documents; shallow comparisons work.1497// eslint-disable-next-line eqeqeq1498compare = ( a.ownerDocument || a ) == ( b.ownerDocument || b ) ?1499a.compareDocumentPosition( b ) :1500
1501// Otherwise we know they are disconnected15021;1503
1504// Disconnected nodes1505if ( compare & 1 ||1506( !support.sortDetached && b.compareDocumentPosition( a ) === compare ) ) {1507
1508// Choose the first element that is related to our preferred document1509// Support: IE 11+, Edge 17 - 18+1510// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1511// two documents; shallow comparisons work.1512// eslint-disable-next-line eqeqeq1513if ( a == document || a.ownerDocument == preferredDoc &&1514contains( preferredDoc, a ) ) {1515return -1;1516}1517
1518// Support: IE 11+, Edge 17 - 18+1519// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1520// two documents; shallow comparisons work.1521// eslint-disable-next-line eqeqeq1522if ( b == document || b.ownerDocument == preferredDoc &&1523contains( preferredDoc, b ) ) {1524return 1;1525}1526
1527// Maintain original order1528return sortInput ?1529( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :15300;1531}1532
1533return compare & 4 ? -1 : 1;1534} :1535function( a, b ) {1536
1537// Exit early if the nodes are identical1538if ( a === b ) {1539hasDuplicate = true;1540return 0;1541}1542
1543var cur,1544i = 0,1545aup = a.parentNode,1546bup = b.parentNode,1547ap = [ a ],1548bp = [ b ];1549
1550// Parentless nodes are either documents or disconnected1551if ( !aup || !bup ) {1552
1553// Support: IE 11+, Edge 17 - 18+1554// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1555// two documents; shallow comparisons work.1556/* eslint-disable eqeqeq */1557return a == document ? -1 :1558b == document ? 1 :1559/* eslint-enable eqeqeq */1560aup ? -1 :1561bup ? 1 :1562sortInput ?1563( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :15640;1565
1566// If the nodes are siblings, we can do a quick check1567} else if ( aup === bup ) {1568return siblingCheck( a, b );1569}1570
1571// Otherwise we need full lists of their ancestors for comparison1572cur = a;1573while ( ( cur = cur.parentNode ) ) {1574ap.unshift( cur );1575}1576cur = b;1577while ( ( cur = cur.parentNode ) ) {1578bp.unshift( cur );1579}1580
1581// Walk down the tree looking for a discrepancy1582while ( ap[ i ] === bp[ i ] ) {1583i++;1584}1585
1586return i ?1587
1588// Do a sibling check if the nodes have a common ancestor1589siblingCheck( ap[ i ], bp[ i ] ) :1590
1591// Otherwise nodes in our document sort first1592// Support: IE 11+, Edge 17 - 18+1593// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1594// two documents; shallow comparisons work.1595/* eslint-disable eqeqeq */1596ap[ i ] == preferredDoc ? -1 :1597bp[ i ] == preferredDoc ? 1 :1598/* eslint-enable eqeqeq */15990;1600};1601
1602return document;1603};1604
1605Sizzle.matches = function( expr, elements ) {1606return Sizzle( expr, null, null, elements );1607};1608
1609Sizzle.matchesSelector = function( elem, expr ) {1610setDocument( elem );1611
1612if ( support.matchesSelector && documentIsHTML &&1613!nonnativeSelectorCache[ expr + " " ] &&1614( !rbuggyMatches || !rbuggyMatches.test( expr ) ) &&1615( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) {1616
1617try {1618var ret = matches.call( elem, expr );1619
1620// IE 9's matchesSelector returns false on disconnected nodes1621if ( ret || support.disconnectedMatch ||1622
1623// As well, disconnected nodes are said to be in a document1624// fragment in IE 91625elem.document && elem.document.nodeType !== 11 ) {1626return ret;1627}1628} catch ( e ) {1629nonnativeSelectorCache( expr, true );1630}1631}1632
1633return Sizzle( expr, document, null, [ elem ] ).length > 0;1634};1635
1636Sizzle.contains = function( context, elem ) {1637
1638// Set document vars if needed1639// Support: IE 11+, Edge 17 - 18+1640// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1641// two documents; shallow comparisons work.1642// eslint-disable-next-line eqeqeq1643if ( ( context.ownerDocument || context ) != document ) {1644setDocument( context );1645}1646return contains( context, elem );1647};1648
1649Sizzle.attr = function( elem, name ) {1650
1651// Set document vars if needed1652// Support: IE 11+, Edge 17 - 18+1653// IE/Edge sometimes throw a "Permission denied" error when strict-comparing1654// two documents; shallow comparisons work.1655// eslint-disable-next-line eqeqeq1656if ( ( elem.ownerDocument || elem ) != document ) {1657setDocument( elem );1658}1659
1660var fn = Expr.attrHandle[ name.toLowerCase() ],1661
1662// Don't get fooled by Object.prototype properties (jQuery #13807)1663val = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ?1664fn( elem, name, !documentIsHTML ) :1665undefined;1666
1667return val !== undefined ?1668val :1669support.attributes || !documentIsHTML ?1670elem.getAttribute( name ) :1671( val = elem.getAttributeNode( name ) ) && val.specified ?1672val.value :1673null;1674};1675
1676Sizzle.escape = function( sel ) {1677return ( sel + "" ).replace( rcssescape, fcssescape );1678};1679
1680Sizzle.error = function( msg ) {1681throw new Error( "Syntax error, unrecognized expression: " + msg );1682};1683
1684/**
1685* Document sorting and removing duplicates
1686* @param {ArrayLike} results
1687*/
1688Sizzle.uniqueSort = function( results ) {1689var elem,1690duplicates = [],1691j = 0,1692i = 0;1693
1694// Unless we *know* we can detect duplicates, assume their presence1695hasDuplicate = !support.detectDuplicates;1696sortInput = !support.sortStable && results.slice( 0 );1697results.sort( sortOrder );1698
1699if ( hasDuplicate ) {1700while ( ( elem = results[ i++ ] ) ) {1701if ( elem === results[ i ] ) {1702j = duplicates.push( i );1703}1704}1705while ( j-- ) {1706results.splice( duplicates[ j ], 1 );1707}1708}1709
1710// Clear input after sorting to release objects1711// See https://github.com/jquery/sizzle/pull/2251712sortInput = null;1713
1714return results;1715};1716
1717/**
1718* Utility function for retrieving the text value of an array of DOM nodes
1719* @param {Array|Element} elem
1720*/
1721getText = Sizzle.getText = function( elem ) {1722var node,1723ret = "",1724i = 0,1725nodeType = elem.nodeType;1726
1727if ( !nodeType ) {1728
1729// If no nodeType, this is expected to be an array1730while ( ( node = elem[ i++ ] ) ) {1731
1732// Do not traverse comment nodes1733ret += getText( node );1734}1735} else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) {1736
1737// Use textContent for elements1738// innerText usage removed for consistency of new lines (jQuery #11153)1739if ( typeof elem.textContent === "string" ) {1740return elem.textContent;1741} else {1742
1743// Traverse its children1744for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {1745ret += getText( elem );1746}1747}1748} else if ( nodeType === 3 || nodeType === 4 ) {1749return elem.nodeValue;1750}1751
1752// Do not include comment or processing instruction nodes1753
1754return ret;1755};1756
1757Expr = Sizzle.selectors = {1758
1759// Can be adjusted by the user1760cacheLength: 50,1761
1762createPseudo: markFunction,1763
1764match: matchExpr,1765
1766attrHandle: {},1767
1768find: {},1769
1770relative: {1771">": { dir: "parentNode", first: true },1772" ": { dir: "parentNode" },1773"+": { dir: "previousSibling", first: true },1774"~": { dir: "previousSibling" }1775},1776
1777preFilter: {1778"ATTR": function( match ) {1779match[ 1 ] = match[ 1 ].replace( runescape, funescape );1780
1781// Move the given value to match[3] whether quoted or unquoted1782match[ 3 ] = ( match[ 3 ] || match[ 4 ] ||1783match[ 5 ] || "" ).replace( runescape, funescape );1784
1785if ( match[ 2 ] === "~=" ) {1786match[ 3 ] = " " + match[ 3 ] + " ";1787}1788
1789return match.slice( 0, 4 );1790},1791
1792"CHILD": function( match ) {1793
1794/* matches from matchExpr["CHILD"]17951 type (only|nth|...)
17962 what (child|of-type)
17973 argument (even|odd|\d*|\d*n([+-]\d+)?|...)
17984 xn-component of xn+y argument ([+-]?\d*n|)
17995 sign of xn-component
18006 x of xn-component
18017 sign of y-component
18028 y of y-component
1803*/
1804match[ 1 ] = match[ 1 ].toLowerCase();1805
1806if ( match[ 1 ].slice( 0, 3 ) === "nth" ) {1807
1808// nth-* requires argument1809if ( !match[ 3 ] ) {1810Sizzle.error( match[ 0 ] );1811}1812
1813// numeric x and y parameters for Expr.filter.CHILD1814// remember that false/true cast respectively to 0/11815match[ 4 ] = +( match[ 4 ] ?1816match[ 5 ] + ( match[ 6 ] || 1 ) :18172 * ( match[ 3 ] === "even" || match[ 3 ] === "odd" ) );1818match[ 5 ] = +( ( match[ 7 ] + match[ 8 ] ) || match[ 3 ] === "odd" );1819
1820// other types prohibit arguments1821} else if ( match[ 3 ] ) {1822Sizzle.error( match[ 0 ] );1823}1824
1825return match;1826},1827
1828"PSEUDO": function( match ) {1829var excess,1830unquoted = !match[ 6 ] && match[ 2 ];1831
1832if ( matchExpr[ "CHILD" ].test( match[ 0 ] ) ) {1833return null;1834}1835
1836// Accept quoted arguments as-is1837if ( match[ 3 ] ) {1838match[ 2 ] = match[ 4 ] || match[ 5 ] || "";1839
1840// Strip excess characters from unquoted arguments1841} else if ( unquoted && rpseudo.test( unquoted ) &&1842
1843// Get excess from tokenize (recursively)1844( excess = tokenize( unquoted, true ) ) &&1845
1846// advance to the next closing parenthesis1847( excess = unquoted.indexOf( ")", unquoted.length - excess ) - unquoted.length ) ) {1848
1849// excess is a negative index1850match[ 0 ] = match[ 0 ].slice( 0, excess );1851match[ 2 ] = unquoted.slice( 0, excess );1852}1853
1854// Return only captures needed by the pseudo filter method (type and argument)1855return match.slice( 0, 3 );1856}1857},1858
1859filter: {1860
1861"TAG": function( nodeNameSelector ) {1862var nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase();1863return nodeNameSelector === "*" ?1864function() {1865return true;1866} :1867function( elem ) {1868return elem.nodeName && elem.nodeName.toLowerCase() === nodeName;1869};1870},1871
1872"CLASS": function( className ) {1873var pattern = classCache[ className + " " ];1874
1875return pattern ||1876( pattern = new RegExp( "(^|" + whitespace +1877")" + className + "(" + whitespace + "|$)" ) ) && classCache(1878className, function( elem ) {1879return pattern.test(1880typeof elem.className === "string" && elem.className ||1881typeof elem.getAttribute !== "undefined" &&1882elem.getAttribute( "class" ) ||1883""1884);1885} );1886},1887
1888"ATTR": function( name, operator, check ) {1889return function( elem ) {1890var result = Sizzle.attr( elem, name );1891
1892if ( result == null ) {1893return operator === "!=";1894}1895if ( !operator ) {1896return true;1897}1898
1899result += "";1900
1901/* eslint-disable max-len */1902
1903return operator === "=" ? result === check :1904operator === "!=" ? result !== check :1905operator === "^=" ? check && result.indexOf( check ) === 0 :1906operator === "*=" ? check && result.indexOf( check ) > -1 :1907operator === "$=" ? check && result.slice( -check.length ) === check :1908operator === "~=" ? ( " " + result.replace( rwhitespace, " " ) + " " ).indexOf( check ) > -1 :1909operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" :1910false;1911/* eslint-enable max-len */1912
1913};1914},1915
1916"CHILD": function( type, what, _argument, first, last ) {1917var simple = type.slice( 0, 3 ) !== "nth",1918forward = type.slice( -4 ) !== "last",1919ofType = what === "of-type";1920
1921return first === 1 && last === 0 ?1922
1923// Shortcut for :nth-*(n)1924function( elem ) {1925return !!elem.parentNode;1926} :1927
1928function( elem, _context, xml ) {1929var cache, uniqueCache, outerCache, node, nodeIndex, start,1930dir = simple !== forward ? "nextSibling" : "previousSibling",1931parent = elem.parentNode,1932name = ofType && elem.nodeName.toLowerCase(),1933useCache = !xml && !ofType,1934diff = false;1935
1936if ( parent ) {1937
1938// :(first|last|only)-(child|of-type)1939if ( simple ) {1940while ( dir ) {1941node = elem;1942while ( ( node = node[ dir ] ) ) {1943if ( ofType ?1944node.nodeName.toLowerCase() === name :1945node.nodeType === 1 ) {1946
1947return false;1948}1949}1950
1951// Reverse direction for :only-* (if we haven't yet done so)1952start = dir = type === "only" && !start && "nextSibling";1953}1954return true;1955}1956
1957start = [ forward ? parent.firstChild : parent.lastChild ];1958
1959// non-xml :nth-child(...) stores cache data on `parent`1960if ( forward && useCache ) {1961
1962// Seek `elem` from a previously-cached index1963
1964// ...in a gzip-friendly way1965node = parent;1966outerCache = node[ expando ] || ( node[ expando ] = {} );1967
1968// Support: IE <9 only1969// Defend against cloned attroperties (jQuery gh-1709)1970uniqueCache = outerCache[ node.uniqueID ] ||1971( outerCache[ node.uniqueID ] = {} );1972
1973cache = uniqueCache[ type ] || [];1974nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];1975diff = nodeIndex && cache[ 2 ];1976node = nodeIndex && parent.childNodes[ nodeIndex ];1977
1978while ( ( node = ++nodeIndex && node && node[ dir ] ||1979
1980// Fallback to seeking `elem` from the start1981( diff = nodeIndex = 0 ) || start.pop() ) ) {1982
1983// When found, cache indexes on `parent` and break1984if ( node.nodeType === 1 && ++diff && node === elem ) {1985uniqueCache[ type ] = [ dirruns, nodeIndex, diff ];1986break;1987}1988}1989
1990} else {1991
1992// Use previously-cached element index if available1993if ( useCache ) {1994
1995// ...in a gzip-friendly way1996node = elem;1997outerCache = node[ expando ] || ( node[ expando ] = {} );1998
1999// Support: IE <9 only2000// Defend against cloned attroperties (jQuery gh-1709)2001uniqueCache = outerCache[ node.uniqueID ] ||2002( outerCache[ node.uniqueID ] = {} );2003
2004cache = uniqueCache[ type ] || [];2005nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];2006diff = nodeIndex;2007}2008
2009// xml :nth-child(...)2010// or :nth-last-child(...) or :nth(-last)?-of-type(...)2011if ( diff === false ) {2012
2013// Use the same loop as above to seek `elem` from the start2014while ( ( node = ++nodeIndex && node && node[ dir ] ||2015( diff = nodeIndex = 0 ) || start.pop() ) ) {2016
2017if ( ( ofType ?2018node.nodeName.toLowerCase() === name :2019node.nodeType === 1 ) &&2020++diff ) {2021
2022// Cache the index of each encountered element2023if ( useCache ) {2024outerCache = node[ expando ] ||2025( node[ expando ] = {} );2026
2027// Support: IE <9 only2028// Defend against cloned attroperties (jQuery gh-1709)2029uniqueCache = outerCache[ node.uniqueID ] ||2030( outerCache[ node.uniqueID ] = {} );2031
2032uniqueCache[ type ] = [ dirruns, diff ];2033}2034
2035if ( node === elem ) {2036break;2037}2038}2039}2040}2041}2042
2043// Incorporate the offset, then check against cycle size2044diff -= last;2045return diff === first || ( diff % first === 0 && diff / first >= 0 );2046}2047};2048},2049
2050"PSEUDO": function( pseudo, argument ) {2051
2052// pseudo-class names are case-insensitive2053// http://www.w3.org/TR/selectors/#pseudo-classes2054// Prioritize by case sensitivity in case custom pseudos are added with uppercase letters2055// Remember that setFilters inherits from pseudos2056var args,2057fn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] ||2058Sizzle.error( "unsupported pseudo: " + pseudo );2059
2060// The user may use createPseudo to indicate that2061// arguments are needed to create the filter function2062// just as Sizzle does2063if ( fn[ expando ] ) {2064return fn( argument );2065}2066
2067// But maintain support for old signatures2068if ( fn.length > 1 ) {2069args = [ pseudo, pseudo, "", argument ];2070return Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ?2071markFunction( function( seed, matches ) {2072var idx,2073matched = fn( seed, argument ),2074i = matched.length;2075while ( i-- ) {2076idx = indexOf( seed, matched[ i ] );2077seed[ idx ] = !( matches[ idx ] = matched[ i ] );2078}2079} ) :2080function( elem ) {2081return fn( elem, 0, args );2082};2083}2084
2085return fn;2086}2087},2088
2089pseudos: {2090
2091// Potentially complex pseudos2092"not": markFunction( function( selector ) {2093
2094// Trim the selector passed to compile2095// to avoid treating leading and trailing2096// spaces as combinators2097var input = [],2098results = [],2099matcher = compile( selector.replace( rtrim, "$1" ) );2100
2101return matcher[ expando ] ?2102markFunction( function( seed, matches, _context, xml ) {2103var elem,2104unmatched = matcher( seed, null, xml, [] ),2105i = seed.length;2106
2107// Match elements unmatched by `matcher`2108while ( i-- ) {2109if ( ( elem = unmatched[ i ] ) ) {2110seed[ i ] = !( matches[ i ] = elem );2111}2112}2113} ) :2114function( elem, _context, xml ) {2115input[ 0 ] = elem;2116matcher( input, null, xml, results );2117
2118// Don't keep the element (issue #299)2119input[ 0 ] = null;2120return !results.pop();2121};2122} ),2123
2124"has": markFunction( function( selector ) {2125return function( elem ) {2126return Sizzle( selector, elem ).length > 0;2127};2128} ),2129
2130"contains": markFunction( function( text ) {2131text = text.replace( runescape, funescape );2132return function( elem ) {2133return ( elem.textContent || getText( elem ) ).indexOf( text ) > -1;2134};2135} ),2136
2137// "Whether an element is represented by a :lang() selector2138// is based solely on the element's language value2139// being equal to the identifier C,2140// or beginning with the identifier C immediately followed by "-".2141// The matching of C against the element's language value is performed case-insensitively.2142// The identifier C does not have to be a valid language name."2143// http://www.w3.org/TR/selectors/#lang-pseudo2144"lang": markFunction( function( lang ) {2145
2146// lang value must be a valid identifier2147if ( !ridentifier.test( lang || "" ) ) {2148Sizzle.error( "unsupported lang: " + lang );2149}2150lang = lang.replace( runescape, funescape ).toLowerCase();2151return function( elem ) {2152var elemLang;2153do {2154if ( ( elemLang = documentIsHTML ?2155elem.lang :2156elem.getAttribute( "xml:lang" ) || elem.getAttribute( "lang" ) ) ) {2157
2158elemLang = elemLang.toLowerCase();2159return elemLang === lang || elemLang.indexOf( lang + "-" ) === 0;2160}2161} while ( ( elem = elem.parentNode ) && elem.nodeType === 1 );2162return false;2163};2164} ),2165
2166// Miscellaneous2167"target": function( elem ) {2168var hash = window.location && window.location.hash;2169return hash && hash.slice( 1 ) === elem.id;2170},2171
2172"root": function( elem ) {2173return elem === docElem;2174},2175
2176"focus": function( elem ) {2177return elem === document.activeElement &&2178( !document.hasFocus || document.hasFocus() ) &&2179!!( elem.type || elem.href || ~elem.tabIndex );2180},2181
2182// Boolean properties2183"enabled": createDisabledPseudo( false ),2184"disabled": createDisabledPseudo( true ),2185
2186"checked": function( elem ) {2187
2188// In CSS3, :checked should return both checked and selected elements2189// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked2190var nodeName = elem.nodeName.toLowerCase();2191return ( nodeName === "input" && !!elem.checked ) ||2192( nodeName === "option" && !!elem.selected );2193},2194
2195"selected": function( elem ) {2196
2197// Accessing this property makes selected-by-default2198// options in Safari work properly2199if ( elem.parentNode ) {2200// eslint-disable-next-line no-unused-expressions2201elem.parentNode.selectedIndex;2202}2203
2204return elem.selected === true;2205},2206
2207// Contents2208"empty": function( elem ) {2209
2210// http://www.w3.org/TR/selectors/#empty-pseudo2211// :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5),2212// but not by others (comment: 8; processing instruction: 7; etc.)2213// nodeType < 6 works because attributes (2) do not appear as children2214for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {2215if ( elem.nodeType < 6 ) {2216return false;2217}2218}2219return true;2220},2221
2222"parent": function( elem ) {2223return !Expr.pseudos[ "empty" ]( elem );2224},2225
2226// Element/input types2227"header": function( elem ) {2228return rheader.test( elem.nodeName );2229},2230
2231"input": function( elem ) {2232return rinputs.test( elem.nodeName );2233},2234
2235"button": function( elem ) {2236var name = elem.nodeName.toLowerCase();2237return name === "input" && elem.type === "button" || name === "button";2238},2239
2240"text": function( elem ) {2241var attr;2242return elem.nodeName.toLowerCase() === "input" &&2243elem.type === "text" &&2244
2245// Support: IE<82246// New HTML5 attribute values (e.g., "search") appear with elem.type === "text"2247( ( attr = elem.getAttribute( "type" ) ) == null ||2248attr.toLowerCase() === "text" );2249},2250
2251// Position-in-collection2252"first": createPositionalPseudo( function() {2253return [ 0 ];2254} ),2255
2256"last": createPositionalPseudo( function( _matchIndexes, length ) {2257return [ length - 1 ];2258} ),2259
2260"eq": createPositionalPseudo( function( _matchIndexes, length, argument ) {2261return [ argument < 0 ? argument + length : argument ];2262} ),2263
2264"even": createPositionalPseudo( function( matchIndexes, length ) {2265var i = 0;2266for ( ; i < length; i += 2 ) {2267matchIndexes.push( i );2268}2269return matchIndexes;2270} ),2271
2272"odd": createPositionalPseudo( function( matchIndexes, length ) {2273var i = 1;2274for ( ; i < length; i += 2 ) {2275matchIndexes.push( i );2276}2277return matchIndexes;2278} ),2279
2280"lt": createPositionalPseudo( function( matchIndexes, length, argument ) {2281var i = argument < 0 ?2282argument + length :2283argument > length ?2284length :2285argument;2286for ( ; --i >= 0; ) {2287matchIndexes.push( i );2288}2289return matchIndexes;2290} ),2291
2292"gt": createPositionalPseudo( function( matchIndexes, length, argument ) {2293var i = argument < 0 ? argument + length : argument;2294for ( ; ++i < length; ) {2295matchIndexes.push( i );2296}2297return matchIndexes;2298} )2299}2300};2301
2302Expr.pseudos[ "nth" ] = Expr.pseudos[ "eq" ];2303
2304// Add button/input type pseudos
2305for ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) {2306Expr.pseudos[ i ] = createInputPseudo( i );2307}
2308for ( i in { submit: true, reset: true } ) {2309Expr.pseudos[ i ] = createButtonPseudo( i );2310}
2311
2312// Easy API for creating new setFilters
2313function setFilters() {}2314setFilters.prototype = Expr.filters = Expr.pseudos;2315Expr.setFilters = new setFilters();2316
2317tokenize = Sizzle.tokenize = function( selector, parseOnly ) {2318var matched, match, tokens, type,2319soFar, groups, preFilters,2320cached = tokenCache[ selector + " " ];2321
2322if ( cached ) {2323return parseOnly ? 0 : cached.slice( 0 );2324}2325
2326soFar = selector;2327groups = [];2328preFilters = Expr.preFilter;2329
2330while ( soFar ) {2331
2332// Comma and first run2333if ( !matched || ( match = rcomma.exec( soFar ) ) ) {2334if ( match ) {2335
2336// Don't consume trailing commas as valid2337soFar = soFar.slice( match[ 0 ].length ) || soFar;2338}2339groups.push( ( tokens = [] ) );2340}2341
2342matched = false;2343
2344// Combinators2345if ( ( match = rcombinators.exec( soFar ) ) ) {2346matched = match.shift();2347tokens.push( {2348value: matched,2349
2350// Cast descendant combinators to space2351type: match[ 0 ].replace( rtrim, " " )2352} );2353soFar = soFar.slice( matched.length );2354}2355
2356// Filters2357for ( type in Expr.filter ) {2358if ( ( match = matchExpr[ type ].exec( soFar ) ) && ( !preFilters[ type ] ||2359( match = preFilters[ type ]( match ) ) ) ) {2360matched = match.shift();2361tokens.push( {2362value: matched,2363type: type,2364matches: match2365} );2366soFar = soFar.slice( matched.length );2367}2368}2369
2370if ( !matched ) {2371break;2372}2373}2374
2375// Return the length of the invalid excess2376// if we're just parsing2377// Otherwise, throw an error or return tokens2378return parseOnly ?2379soFar.length :2380soFar ?2381Sizzle.error( selector ) :2382
2383// Cache the tokens2384tokenCache( selector, groups ).slice( 0 );2385};2386
2387function toSelector( tokens ) {2388var i = 0,2389len = tokens.length,2390selector = "";2391for ( ; i < len; i++ ) {2392selector += tokens[ i ].value;2393}2394return selector;2395}
2396
2397function addCombinator( matcher, combinator, base ) {2398var dir = combinator.dir,2399skip = combinator.next,2400key = skip || dir,2401checkNonElements = base && key === "parentNode",2402doneName = done++;2403
2404return combinator.first ?2405
2406// Check against closest ancestor/preceding element2407function( elem, context, xml ) {2408while ( ( elem = elem[ dir ] ) ) {2409if ( elem.nodeType === 1 || checkNonElements ) {2410return matcher( elem, context, xml );2411}2412}2413return false;2414} :2415
2416// Check against all ancestor/preceding elements2417function( elem, context, xml ) {2418var oldCache, uniqueCache, outerCache,2419newCache = [ dirruns, doneName ];2420
2421// We can't set arbitrary data on XML nodes, so they don't benefit from combinator caching2422if ( xml ) {2423while ( ( elem = elem[ dir ] ) ) {2424if ( elem.nodeType === 1 || checkNonElements ) {2425if ( matcher( elem, context, xml ) ) {2426return true;2427}2428}2429}2430} else {2431while ( ( elem = elem[ dir ] ) ) {2432if ( elem.nodeType === 1 || checkNonElements ) {2433outerCache = elem[ expando ] || ( elem[ expando ] = {} );2434
2435// Support: IE <9 only2436// Defend against cloned attroperties (jQuery gh-1709)2437uniqueCache = outerCache[ elem.uniqueID ] ||2438( outerCache[ elem.uniqueID ] = {} );2439
2440if ( skip && skip === elem.nodeName.toLowerCase() ) {2441elem = elem[ dir ] || elem;2442} else if ( ( oldCache = uniqueCache[ key ] ) &&2443oldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) {2444
2445// Assign to newCache so results back-propagate to previous elements2446return ( newCache[ 2 ] = oldCache[ 2 ] );2447} else {2448
2449// Reuse newcache so results back-propagate to previous elements2450uniqueCache[ key ] = newCache;2451
2452// A match means we're done; a fail means we have to keep checking2453if ( ( newCache[ 2 ] = matcher( elem, context, xml ) ) ) {2454return true;2455}2456}2457}2458}2459}2460return false;2461};2462}
2463
2464function elementMatcher( matchers ) {2465return matchers.length > 1 ?2466function( elem, context, xml ) {2467var i = matchers.length;2468while ( i-- ) {2469if ( !matchers[ i ]( elem, context, xml ) ) {2470return false;2471}2472}2473return true;2474} :2475matchers[ 0 ];2476}
2477
2478function multipleContexts( selector, contexts, results ) {2479var i = 0,2480len = contexts.length;2481for ( ; i < len; i++ ) {2482Sizzle( selector, contexts[ i ], results );2483}2484return results;2485}
2486
2487function condense( unmatched, map, filter, context, xml ) {2488var elem,2489newUnmatched = [],2490i = 0,2491len = unmatched.length,2492mapped = map != null;2493
2494for ( ; i < len; i++ ) {2495if ( ( elem = unmatched[ i ] ) ) {2496if ( !filter || filter( elem, context, xml ) ) {2497newUnmatched.push( elem );2498if ( mapped ) {2499map.push( i );2500}2501}2502}2503}2504
2505return newUnmatched;2506}
2507
2508function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) {2509if ( postFilter && !postFilter[ expando ] ) {2510postFilter = setMatcher( postFilter );2511}2512if ( postFinder && !postFinder[ expando ] ) {2513postFinder = setMatcher( postFinder, postSelector );2514}2515return markFunction( function( seed, results, context, xml ) {2516var temp, i, elem,2517preMap = [],2518postMap = [],2519preexisting = results.length,2520
2521// Get initial elements from seed or context2522elems = seed || multipleContexts(2523selector || "*",2524context.nodeType ? [ context ] : context,2525[]2526),2527
2528// Prefilter to get matcher input, preserving a map for seed-results synchronization2529matcherIn = preFilter && ( seed || !selector ) ?2530condense( elems, preMap, preFilter, context, xml ) :2531elems,2532
2533matcherOut = matcher ?2534
2535// If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results,2536postFinder || ( seed ? preFilter : preexisting || postFilter ) ?2537
2538// ...intermediate processing is necessary2539[] :2540
2541// ...otherwise use results directly2542results :2543matcherIn;2544
2545// Find primary matches2546if ( matcher ) {2547matcher( matcherIn, matcherOut, context, xml );2548}2549
2550// Apply postFilter2551if ( postFilter ) {2552temp = condense( matcherOut, postMap );2553postFilter( temp, [], context, xml );2554
2555// Un-match failing elements by moving them back to matcherIn2556i = temp.length;2557while ( i-- ) {2558if ( ( elem = temp[ i ] ) ) {2559matcherOut[ postMap[ i ] ] = !( matcherIn[ postMap[ i ] ] = elem );2560}2561}2562}2563
2564if ( seed ) {2565if ( postFinder || preFilter ) {2566if ( postFinder ) {2567
2568// Get the final matcherOut by condensing this intermediate into postFinder contexts2569temp = [];2570i = matcherOut.length;2571while ( i-- ) {2572if ( ( elem = matcherOut[ i ] ) ) {2573
2574// Restore matcherIn since elem is not yet a final match2575temp.push( ( matcherIn[ i ] = elem ) );2576}2577}2578postFinder( null, ( matcherOut = [] ), temp, xml );2579}2580
2581// Move matched elements from seed to results to keep them synchronized2582i = matcherOut.length;2583while ( i-- ) {2584if ( ( elem = matcherOut[ i ] ) &&2585( temp = postFinder ? indexOf( seed, elem ) : preMap[ i ] ) > -1 ) {2586
2587seed[ temp ] = !( results[ temp ] = elem );2588}2589}2590}2591
2592// Add elements to results, through postFinder if defined2593} else {2594matcherOut = condense(2595matcherOut === results ?2596matcherOut.splice( preexisting, matcherOut.length ) :2597matcherOut
2598);2599if ( postFinder ) {2600postFinder( null, results, matcherOut, xml );2601} else {2602push.apply( results, matcherOut );2603}2604}2605} );2606}
2607
2608function matcherFromTokens( tokens ) {2609var checkContext, matcher, j,2610len = tokens.length,2611leadingRelative = Expr.relative[ tokens[ 0 ].type ],2612implicitRelative = leadingRelative || Expr.relative[ " " ],2613i = leadingRelative ? 1 : 0,2614
2615// The foundational matcher ensures that elements are reachable from top-level context(s)2616matchContext = addCombinator( function( elem ) {2617return elem === checkContext;2618}, implicitRelative, true ),2619matchAnyContext = addCombinator( function( elem ) {2620return indexOf( checkContext, elem ) > -1;2621}, implicitRelative, true ),2622matchers = [ function( elem, context, xml ) {2623var ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || (2624( checkContext = context ).nodeType ?2625matchContext( elem, context, xml ) :2626matchAnyContext( elem, context, xml ) );2627
2628// Avoid hanging onto element (issue #299)2629checkContext = null;2630return ret;2631} ];2632
2633for ( ; i < len; i++ ) {2634if ( ( matcher = Expr.relative[ tokens[ i ].type ] ) ) {2635matchers = [ addCombinator( elementMatcher( matchers ), matcher ) ];2636} else {2637matcher = Expr.filter[ tokens[ i ].type ].apply( null, tokens[ i ].matches );2638
2639// Return special upon seeing a positional matcher2640if ( matcher[ expando ] ) {2641
2642// Find the next relative operator (if any) for proper handling2643j = ++i;2644for ( ; j < len; j++ ) {2645if ( Expr.relative[ tokens[ j ].type ] ) {2646break;2647}2648}2649return setMatcher(2650i > 1 && elementMatcher( matchers ),2651i > 1 && toSelector(2652
2653// If the preceding token was a descendant combinator, insert an implicit any-element `*`2654tokens
2655.slice( 0, i - 1 )2656.concat( { value: tokens[ i - 2 ].type === " " ? "*" : "" } )2657).replace( rtrim, "$1" ),2658matcher,2659i < j && matcherFromTokens( tokens.slice( i, j ) ),2660j < len && matcherFromTokens( ( tokens = tokens.slice( j ) ) ),2661j < len && toSelector( tokens )2662);2663}2664matchers.push( matcher );2665}2666}2667
2668return elementMatcher( matchers );2669}
2670
2671function matcherFromGroupMatchers( elementMatchers, setMatchers ) {2672var bySet = setMatchers.length > 0,2673byElement = elementMatchers.length > 0,2674superMatcher = function( seed, context, xml, results, outermost ) {2675var elem, j, matcher,2676matchedCount = 0,2677i = "0",2678unmatched = seed && [],2679setMatched = [],2680contextBackup = outermostContext,2681
2682// We must always have either seed elements or outermost context2683elems = seed || byElement && Expr.find[ "TAG" ]( "*", outermost ),2684
2685// Use integer dirruns iff this is the outermost matcher2686dirrunsUnique = ( dirruns += contextBackup == null ? 1 : Math.random() || 0.1 ),2687len = elems.length;2688
2689if ( outermost ) {2690
2691// Support: IE 11+, Edge 17 - 18+2692// IE/Edge sometimes throw a "Permission denied" error when strict-comparing2693// two documents; shallow comparisons work.2694// eslint-disable-next-line eqeqeq2695outermostContext = context == document || context || outermost;2696}2697
2698// Add elements passing elementMatchers directly to results2699// Support: IE<9, Safari2700// Tolerate NodeList properties (IE: "length"; Safari: <number>) matching elements by id2701for ( ; i !== len && ( elem = elems[ i ] ) != null; i++ ) {2702if ( byElement && elem ) {2703j = 0;2704
2705// Support: IE 11+, Edge 17 - 18+2706// IE/Edge sometimes throw a "Permission denied" error when strict-comparing2707// two documents; shallow comparisons work.2708// eslint-disable-next-line eqeqeq2709if ( !context && elem.ownerDocument != document ) {2710setDocument( elem );2711xml = !documentIsHTML;2712}2713while ( ( matcher = elementMatchers[ j++ ] ) ) {2714if ( matcher( elem, context || document, xml ) ) {2715results.push( elem );2716break;2717}2718}2719if ( outermost ) {2720dirruns = dirrunsUnique;2721}2722}2723
2724// Track unmatched elements for set filters2725if ( bySet ) {2726
2727// They will have gone through all possible matchers2728if ( ( elem = !matcher && elem ) ) {2729matchedCount--;2730}2731
2732// Lengthen the array for every element, matched or not2733if ( seed ) {2734unmatched.push( elem );2735}2736}2737}2738
2739// `i` is now the count of elements visited above, and adding it to `matchedCount`2740// makes the latter nonnegative.2741matchedCount += i;2742
2743// Apply set filters to unmatched elements2744// NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount`2745// equals `i`), unless we didn't visit _any_ elements in the above loop because we have2746// no element matchers and no seed.2747// Incrementing an initially-string "0" `i` allows `i` to remain a string only in that2748// case, which will result in a "00" `matchedCount` that differs from `i` but is also2749// numerically zero.2750if ( bySet && i !== matchedCount ) {2751j = 0;2752while ( ( matcher = setMatchers[ j++ ] ) ) {2753matcher( unmatched, setMatched, context, xml );2754}2755
2756if ( seed ) {2757
2758// Reintegrate element matches to eliminate the need for sorting2759if ( matchedCount > 0 ) {2760while ( i-- ) {2761if ( !( unmatched[ i ] || setMatched[ i ] ) ) {2762setMatched[ i ] = pop.call( results );2763}2764}2765}2766
2767// Discard index placeholder values to get only actual matches2768setMatched = condense( setMatched );2769}2770
2771// Add matches to results2772push.apply( results, setMatched );2773
2774// Seedless set matches succeeding multiple successful matchers stipulate sorting2775if ( outermost && !seed && setMatched.length > 0 &&2776( matchedCount + setMatchers.length ) > 1 ) {2777
2778Sizzle.uniqueSort( results );2779}2780}2781
2782// Override manipulation of globals by nested matchers2783if ( outermost ) {2784dirruns = dirrunsUnique;2785outermostContext = contextBackup;2786}2787
2788return unmatched;2789};2790
2791return bySet ?2792markFunction( superMatcher ) :2793superMatcher;2794}
2795
2796compile = Sizzle.compile = function( selector, match /* Internal Use Only */ ) {2797var i,2798setMatchers = [],2799elementMatchers = [],2800cached = compilerCache[ selector + " " ];2801
2802if ( !cached ) {2803
2804// Generate a function of recursive functions that can be used to check each element2805if ( !match ) {2806match = tokenize( selector );2807}2808i = match.length;2809while ( i-- ) {2810cached = matcherFromTokens( match[ i ] );2811if ( cached[ expando ] ) {2812setMatchers.push( cached );2813} else {2814elementMatchers.push( cached );2815}2816}2817
2818// Cache the compiled function2819cached = compilerCache(2820selector,2821matcherFromGroupMatchers( elementMatchers, setMatchers )2822);2823
2824// Save selector and tokenization2825cached.selector = selector;2826}2827return cached;2828};2829
2830/**
2831* A low-level selection function that works with Sizzle's compiled
2832* selector functions
2833* @param {String|Function} selector A selector or a pre-compiled
2834* selector function built with Sizzle.compile
2835* @param {Element} context
2836* @param {Array} [results]
2837* @param {Array} [seed] A set of elements to match against
2838*/
2839select = Sizzle.select = function( selector, context, results, seed ) {2840var i, tokens, token, type, find,2841compiled = typeof selector === "function" && selector,2842match = !seed && tokenize( ( selector = compiled.selector || selector ) );2843
2844results = results || [];2845
2846// Try to minimize operations if there is only one selector in the list and no seed2847// (the latter of which guarantees us context)2848if ( match.length === 1 ) {2849
2850// Reduce context if the leading compound selector is an ID2851tokens = match[ 0 ] = match[ 0 ].slice( 0 );2852if ( tokens.length > 2 && ( token = tokens[ 0 ] ).type === "ID" &&2853context.nodeType === 9 && documentIsHTML && Expr.relative[ tokens[ 1 ].type ] ) {2854
2855context = ( Expr.find[ "ID" ]( token.matches[ 0 ]2856.replace( runescape, funescape ), context ) || [] )[ 0 ];2857if ( !context ) {2858return results;2859
2860// Precompiled matchers will still verify ancestry, so step up a level2861} else if ( compiled ) {2862context = context.parentNode;2863}2864
2865selector = selector.slice( tokens.shift().value.length );2866}2867
2868// Fetch a seed set for right-to-left matching2869i = matchExpr[ "needsContext" ].test( selector ) ? 0 : tokens.length;2870while ( i-- ) {2871token = tokens[ i ];2872
2873// Abort if we hit a combinator2874if ( Expr.relative[ ( type = token.type ) ] ) {2875break;2876}2877if ( ( find = Expr.find[ type ] ) ) {2878
2879// Search, expanding context for leading sibling combinators2880if ( ( seed = find(2881token.matches[ 0 ].replace( runescape, funescape ),2882rsibling.test( tokens[ 0 ].type ) && testContext( context.parentNode ) ||2883context
2884) ) ) {2885
2886// If seed is empty or no tokens remain, we can return early2887tokens.splice( i, 1 );2888selector = seed.length && toSelector( tokens );2889if ( !selector ) {2890push.apply( results, seed );2891return results;2892}2893
2894break;2895}2896}2897}2898}2899
2900// Compile and execute a filtering function if one is not provided2901// Provide `match` to avoid retokenization if we modified the selector above2902( compiled || compile( selector, match ) )(2903seed,2904context,2905!documentIsHTML,2906results,2907!context || rsibling.test( selector ) && testContext( context.parentNode ) || context2908);2909return results;2910};2911
2912// One-time assignments
2913
2914// Sort stability
2915support.sortStable = expando.split( "" ).sort( sortOrder ).join( "" ) === expando;2916
2917// Support: Chrome 14-35+
2918// Always assume duplicates if they aren't passed to the comparison function
2919support.detectDuplicates = !!hasDuplicate;2920
2921// Initialize against the default document
2922setDocument();2923
2924// Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27)
2925// Detached nodes confoundingly follow *each other*
2926support.sortDetached = assert( function( el ) {2927
2928// Should return 1, but returns 4 (following)2929return el.compareDocumentPosition( document.createElement( "fieldset" ) ) & 1;2930} );2931
2932// Support: IE<8
2933// Prevent attribute/property "interpolation"
2934// https://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx
2935if ( !assert( function( el ) {2936el.innerHTML = "<a href='#'></a>";2937return el.firstChild.getAttribute( "href" ) === "#";2938} ) ) {2939addHandle( "type|href|height|width", function( elem, name, isXML ) {2940if ( !isXML ) {2941return elem.getAttribute( name, name.toLowerCase() === "type" ? 1 : 2 );2942}2943} );2944}
2945
2946// Support: IE<9
2947// Use defaultValue in place of getAttribute("value")
2948if ( !support.attributes || !assert( function( el ) {2949el.innerHTML = "<input/>";2950el.firstChild.setAttribute( "value", "" );2951return el.firstChild.getAttribute( "value" ) === "";2952} ) ) {2953addHandle( "value", function( elem, _name, isXML ) {2954if ( !isXML && elem.nodeName.toLowerCase() === "input" ) {2955return elem.defaultValue;2956}2957} );2958}
2959
2960// Support: IE<9
2961// Use getAttributeNode to fetch booleans when getAttribute lies
2962if ( !assert( function( el ) {2963return el.getAttribute( "disabled" ) == null;2964} ) ) {2965addHandle( booleans, function( elem, name, isXML ) {2966var val;2967if ( !isXML ) {2968return elem[ name ] === true ? name.toLowerCase() :2969( val = elem.getAttributeNode( name ) ) && val.specified ?2970val.value :2971null;2972}2973} );2974}
2975
2976return Sizzle;2977
2978} )( window );2979
2980
2981
2982jQuery.find = Sizzle;2983jQuery.expr = Sizzle.selectors;2984
2985// Deprecated
2986jQuery.expr[ ":" ] = jQuery.expr.pseudos;2987jQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort;2988jQuery.text = Sizzle.getText;2989jQuery.isXMLDoc = Sizzle.isXML;2990jQuery.contains = Sizzle.contains;2991jQuery.escapeSelector = Sizzle.escape;2992
2993
2994
2995
2996var dir = function( elem, dir, until ) {2997var matched = [],2998truncate = until !== undefined;2999
3000while ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) {3001if ( elem.nodeType === 1 ) {3002if ( truncate && jQuery( elem ).is( until ) ) {3003break;3004}3005matched.push( elem );3006}3007}3008return matched;3009};3010
3011
3012var siblings = function( n, elem ) {3013var matched = [];3014
3015for ( ; n; n = n.nextSibling ) {3016if ( n.nodeType === 1 && n !== elem ) {3017matched.push( n );3018}3019}3020
3021return matched;3022};3023
3024
3025var rneedsContext = jQuery.expr.match.needsContext;3026
3027
3028
3029function nodeName( elem, name ) {3030
3031return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase();3032
3033}
3034var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i );3035
3036
3037
3038// Implement the identical functionality for filter and not
3039function winnow( elements, qualifier, not ) {3040if ( isFunction( qualifier ) ) {3041return jQuery.grep( elements, function( elem, i ) {3042return !!qualifier.call( elem, i, elem ) !== not;3043} );3044}3045
3046// Single element3047if ( qualifier.nodeType ) {3048return jQuery.grep( elements, function( elem ) {3049return ( elem === qualifier ) !== not;3050} );3051}3052
3053// Arraylike of elements (jQuery, arguments, Array)3054if ( typeof qualifier !== "string" ) {3055return jQuery.grep( elements, function( elem ) {3056return ( indexOf.call( qualifier, elem ) > -1 ) !== not;3057} );3058}3059
3060// Filtered directly for both simple and complex selectors3061return jQuery.filter( qualifier, elements, not );3062}
3063
3064jQuery.filter = function( expr, elems, not ) {3065var elem = elems[ 0 ];3066
3067if ( not ) {3068expr = ":not(" + expr + ")";3069}3070
3071if ( elems.length === 1 && elem.nodeType === 1 ) {3072return jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [];3073}3074
3075return jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) {3076return elem.nodeType === 1;3077} ) );3078};3079
3080jQuery.fn.extend( {3081find: function( selector ) {3082var i, ret,3083len = this.length,3084self = this;3085
3086if ( typeof selector !== "string" ) {3087return this.pushStack( jQuery( selector ).filter( function() {3088for ( i = 0; i < len; i++ ) {3089if ( jQuery.contains( self[ i ], this ) ) {3090return true;3091}3092}3093} ) );3094}3095
3096ret = this.pushStack( [] );3097
3098for ( i = 0; i < len; i++ ) {3099jQuery.find( selector, self[ i ], ret );3100}3101
3102return len > 1 ? jQuery.uniqueSort( ret ) : ret;3103},3104filter: function( selector ) {3105return this.pushStack( winnow( this, selector || [], false ) );3106},3107not: function( selector ) {3108return this.pushStack( winnow( this, selector || [], true ) );3109},3110is: function( selector ) {3111return !!winnow(3112this,3113
3114// If this is a positional/relative selector, check membership in the returned set3115// so $("p:first").is("p:last") won't return true for a doc with two "p".3116typeof selector === "string" && rneedsContext.test( selector ) ?3117jQuery( selector ) :3118selector || [],3119false3120).length;3121}3122} );3123
3124
3125// Initialize a jQuery object
3126
3127
3128// A central reference to the root jQuery(document)
3129var rootjQuery,3130
3131// A simple way to check for HTML strings3132// Prioritize #id over <tag> to avoid XSS via location.hash (#9521)3133// Strict HTML recognition (#11290: must start with <)3134// Shortcut simple #id case for speed3135rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/,3136
3137init = jQuery.fn.init = function( selector, context, root ) {3138var match, elem;3139
3140// HANDLE: $(""), $(null), $(undefined), $(false)3141if ( !selector ) {3142return this;3143}3144
3145// Method init() accepts an alternate rootjQuery3146// so migrate can support jQuery.sub (gh-2101)3147root = root || rootjQuery;3148
3149// Handle HTML strings3150if ( typeof selector === "string" ) {3151if ( selector[ 0 ] === "<" &&3152selector[ selector.length - 1 ] === ">" &&3153selector.length >= 3 ) {3154
3155// Assume that strings that start and end with <> are HTML and skip the regex check3156match = [ null, selector, null ];3157
3158} else {3159match = rquickExpr.exec( selector );3160}3161
3162// Match html or make sure no context is specified for #id3163if ( match && ( match[ 1 ] || !context ) ) {3164
3165// HANDLE: $(html) -> $(array)3166if ( match[ 1 ] ) {3167context = context instanceof jQuery ? context[ 0 ] : context;3168
3169// Option to run scripts is true for back-compat3170// Intentionally let the error be thrown if parseHTML is not present3171jQuery.merge( this, jQuery.parseHTML(3172match[ 1 ],3173context && context.nodeType ? context.ownerDocument || context : document,3174true3175) );3176
3177// HANDLE: $(html, props)3178if ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) {3179for ( match in context ) {3180
3181// Properties of context are called as methods if possible3182if ( isFunction( this[ match ] ) ) {3183this[ match ]( context[ match ] );3184
3185// ...and otherwise set as attributes3186} else {3187this.attr( match, context[ match ] );3188}3189}3190}3191
3192return this;3193
3194// HANDLE: $(#id)3195} else {3196elem = document.getElementById( match[ 2 ] );3197
3198if ( elem ) {3199
3200// Inject the element directly into the jQuery object3201this[ 0 ] = elem;3202this.length = 1;3203}3204return this;3205}3206
3207// HANDLE: $(expr, $(...))3208} else if ( !context || context.jquery ) {3209return ( context || root ).find( selector );3210
3211// HANDLE: $(expr, context)3212// (which is just equivalent to: $(context).find(expr)3213} else {3214return this.constructor( context ).find( selector );3215}3216
3217// HANDLE: $(DOMElement)3218} else if ( selector.nodeType ) {3219this[ 0 ] = selector;3220this.length = 1;3221return this;3222
3223// HANDLE: $(function)3224// Shortcut for document ready3225} else if ( isFunction( selector ) ) {3226return root.ready !== undefined ?3227root.ready( selector ) :3228
3229// Execute immediately if ready is not present3230selector( jQuery );3231}3232
3233return jQuery.makeArray( selector, this );3234};3235
3236// Give the init function the jQuery prototype for later instantiation
3237init.prototype = jQuery.fn;3238
3239// Initialize central reference
3240rootjQuery = jQuery( document );3241
3242
3243var rparentsprev = /^(?:parents|prev(?:Until|All))/,3244
3245// Methods guaranteed to produce a unique set when starting from a unique set3246guaranteedUnique = {3247children: true,3248contents: true,3249next: true,3250prev: true3251};3252
3253jQuery.fn.extend( {3254has: function( target ) {3255var targets = jQuery( target, this ),3256l = targets.length;3257
3258return this.filter( function() {3259var i = 0;3260for ( ; i < l; i++ ) {3261if ( jQuery.contains( this, targets[ i ] ) ) {3262return true;3263}3264}3265} );3266},3267
3268closest: function( selectors, context ) {3269var cur,3270i = 0,3271l = this.length,3272matched = [],3273targets = typeof selectors !== "string" && jQuery( selectors );3274
3275// Positional selectors never match, since there's no _selection_ context3276if ( !rneedsContext.test( selectors ) ) {3277for ( ; i < l; i++ ) {3278for ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) {3279
3280// Always skip document fragments3281if ( cur.nodeType < 11 && ( targets ?3282targets.index( cur ) > -1 :3283
3284// Don't pass non-elements to Sizzle3285cur.nodeType === 1 &&3286jQuery.find.matchesSelector( cur, selectors ) ) ) {3287
3288matched.push( cur );3289break;3290}3291}3292}3293}3294
3295return this.pushStack( matched.length > 1 ? jQuery.uniqueSort( matched ) : matched );3296},3297
3298// Determine the position of an element within the set3299index: function( elem ) {3300
3301// No argument, return index in parent3302if ( !elem ) {3303return ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1;3304}3305
3306// Index in selector3307if ( typeof elem === "string" ) {3308return indexOf.call( jQuery( elem ), this[ 0 ] );3309}3310
3311// Locate the position of the desired element3312return indexOf.call( this,3313
3314// If it receives a jQuery object, the first element is used3315elem.jquery ? elem[ 0 ] : elem3316);3317},3318
3319add: function( selector, context ) {3320return this.pushStack(3321jQuery.uniqueSort(3322jQuery.merge( this.get(), jQuery( selector, context ) )3323)3324);3325},3326
3327addBack: function( selector ) {3328return this.add( selector == null ?3329this.prevObject : this.prevObject.filter( selector )3330);3331}3332} );3333
3334function sibling( cur, dir ) {3335while ( ( cur = cur[ dir ] ) && cur.nodeType !== 1 ) {}3336return cur;3337}
3338
3339jQuery.each( {3340parent: function( elem ) {3341var parent = elem.parentNode;3342return parent && parent.nodeType !== 11 ? parent : null;3343},3344parents: function( elem ) {3345return dir( elem, "parentNode" );3346},3347parentsUntil: function( elem, _i, until ) {3348return dir( elem, "parentNode", until );3349},3350next: function( elem ) {3351return sibling( elem, "nextSibling" );3352},3353prev: function( elem ) {3354return sibling( elem, "previousSibling" );3355},3356nextAll: function( elem ) {3357return dir( elem, "nextSibling" );3358},3359prevAll: function( elem ) {3360return dir( elem, "previousSibling" );3361},3362nextUntil: function( elem, _i, until ) {3363return dir( elem, "nextSibling", until );3364},3365prevUntil: function( elem, _i, until ) {3366return dir( elem, "previousSibling", until );3367},3368siblings: function( elem ) {3369return siblings( ( elem.parentNode || {} ).firstChild, elem );3370},3371children: function( elem ) {3372return siblings( elem.firstChild );3373},3374contents: function( elem ) {3375if ( elem.contentDocument != null &&3376
3377// Support: IE 11+3378// <object> elements with no `data` attribute has an object3379// `contentDocument` with a `null` prototype.3380getProto( elem.contentDocument ) ) {3381
3382return elem.contentDocument;3383}3384
3385// Support: IE 9 - 11 only, iOS 7 only, Android Browser <=4.3 only3386// Treat the template element as a regular one in browsers that3387// don't support it.3388if ( nodeName( elem, "template" ) ) {3389elem = elem.content || elem;3390}3391
3392return jQuery.merge( [], elem.childNodes );3393}3394}, function( name, fn ) {3395jQuery.fn[ name ] = function( until, selector ) {3396var matched = jQuery.map( this, fn, until );3397
3398if ( name.slice( -5 ) !== "Until" ) {3399selector = until;3400}3401
3402if ( selector && typeof selector === "string" ) {3403matched = jQuery.filter( selector, matched );3404}3405
3406if ( this.length > 1 ) {3407
3408// Remove duplicates3409if ( !guaranteedUnique[ name ] ) {3410jQuery.uniqueSort( matched );3411}3412
3413// Reverse order for parents* and prev-derivatives3414if ( rparentsprev.test( name ) ) {3415matched.reverse();3416}3417}3418
3419return this.pushStack( matched );3420};3421} );3422var rnothtmlwhite = ( /[^\x20\t\r\n\f]+/g );3423
3424
3425
3426// Convert String-formatted options into Object-formatted ones
3427function createOptions( options ) {3428var object = {};3429jQuery.each( options.match( rnothtmlwhite ) || [], function( _, flag ) {3430object[ flag ] = true;3431} );3432return object;3433}
3434
3435/*
3436* Create a callback list using the following parameters:
3437*
3438* options: an optional list of space-separated options that will change how
3439* the callback list behaves or a more traditional option object
3440*
3441* By default a callback list will act like an event callback list and can be
3442* "fired" multiple times.
3443*
3444* Possible options:
3445*
3446* once: will ensure the callback list can only be fired once (like a Deferred)
3447*
3448* memory: will keep track of previous values and will call any callback added
3449* after the list has been fired right away with the latest "memorized"
3450* values (like a Deferred)
3451*
3452* unique: will ensure a callback can only be added once (no duplicate in the list)
3453*
3454* stopOnFalse: interrupt callings when a callback returns false
3455*
3456*/
3457jQuery.Callbacks = function( options ) {3458
3459// Convert options from String-formatted to Object-formatted if needed3460// (we check in cache first)3461options = typeof options === "string" ?3462createOptions( options ) :3463jQuery.extend( {}, options );3464
3465var // Flag to know if list is currently firing3466firing,3467
3468// Last fire value for non-forgettable lists3469memory,3470
3471// Flag to know if list was already fired3472fired,3473
3474// Flag to prevent firing3475locked,3476
3477// Actual callback list3478list = [],3479
3480// Queue of execution data for repeatable lists3481queue = [],3482
3483// Index of currently firing callback (modified by add/remove as needed)3484firingIndex = -1,3485
3486// Fire callbacks3487fire = function() {3488
3489// Enforce single-firing3490locked = locked || options.once;3491
3492// Execute callbacks for all pending executions,3493// respecting firingIndex overrides and runtime changes3494fired = firing = true;3495for ( ; queue.length; firingIndex = -1 ) {3496memory = queue.shift();3497while ( ++firingIndex < list.length ) {3498
3499// Run callback and check for early termination3500if ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false &&3501options.stopOnFalse ) {3502
3503// Jump to end and forget the data so .add doesn't re-fire3504firingIndex = list.length;3505memory = false;3506}3507}3508}3509
3510// Forget the data if we're done with it3511if ( !options.memory ) {3512memory = false;3513}3514
3515firing = false;3516
3517// Clean up if we're done firing for good3518if ( locked ) {3519
3520// Keep an empty list if we have data for future add calls3521if ( memory ) {3522list = [];3523
3524// Otherwise, this object is spent3525} else {3526list = "";3527}3528}3529},3530
3531// Actual Callbacks object3532self = {3533
3534// Add a callback or a collection of callbacks to the list3535add: function() {3536if ( list ) {3537
3538// If we have memory from a past run, we should fire after adding3539if ( memory && !firing ) {3540firingIndex = list.length - 1;3541queue.push( memory );3542}3543
3544( function add( args ) {3545jQuery.each( args, function( _, arg ) {3546if ( isFunction( arg ) ) {3547if ( !options.unique || !self.has( arg ) ) {3548list.push( arg );3549}3550} else if ( arg && arg.length && toType( arg ) !== "string" ) {3551
3552// Inspect recursively3553add( arg );3554}3555} );3556} )( arguments );3557
3558if ( memory && !firing ) {3559fire();3560}3561}3562return this;3563},3564
3565// Remove a callback from the list3566remove: function() {3567jQuery.each( arguments, function( _, arg ) {3568var index;3569while ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) {3570list.splice( index, 1 );3571
3572// Handle firing indexes3573if ( index <= firingIndex ) {3574firingIndex--;3575}3576}3577} );3578return this;3579},3580
3581// Check if a given callback is in the list.3582// If no argument is given, return whether or not list has callbacks attached.3583has: function( fn ) {3584return fn ?3585jQuery.inArray( fn, list ) > -1 :3586list.length > 0;3587},3588
3589// Remove all callbacks from the list3590empty: function() {3591if ( list ) {3592list = [];3593}3594return this;3595},3596
3597// Disable .fire and .add3598// Abort any current/pending executions3599// Clear all callbacks and values3600disable: function() {3601locked = queue = [];3602list = memory = "";3603return this;3604},3605disabled: function() {3606return !list;3607},3608
3609// Disable .fire3610// Also disable .add unless we have memory (since it would have no effect)3611// Abort any pending executions3612lock: function() {3613locked = queue = [];3614if ( !memory && !firing ) {3615list = memory = "";3616}3617return this;3618},3619locked: function() {3620return !!locked;3621},3622
3623// Call all callbacks with the given context and arguments3624fireWith: function( context, args ) {3625if ( !locked ) {3626args = args || [];3627args = [ context, args.slice ? args.slice() : args ];3628queue.push( args );3629if ( !firing ) {3630fire();3631}3632}3633return this;3634},3635
3636// Call all the callbacks with the given arguments3637fire: function() {3638self.fireWith( this, arguments );3639return this;3640},3641
3642// To know if the callbacks have already been called at least once3643fired: function() {3644return !!fired;3645}3646};3647
3648return self;3649};3650
3651
3652function Identity( v ) {3653return v;3654}
3655function Thrower( ex ) {3656throw ex;3657}
3658
3659function adoptValue( value, resolve, reject, noValue ) {3660var method;3661
3662try {3663
3664// Check for promise aspect first to privilege synchronous behavior3665if ( value && isFunction( ( method = value.promise ) ) ) {3666method.call( value ).done( resolve ).fail( reject );3667
3668// Other thenables3669} else if ( value && isFunction( ( method = value.then ) ) ) {3670method.call( value, resolve, reject );3671
3672// Other non-thenables3673} else {3674
3675// Control `resolve` arguments by letting Array#slice cast boolean `noValue` to integer:3676// * false: [ value ].slice( 0 ) => resolve( value )3677// * true: [ value ].slice( 1 ) => resolve()3678resolve.apply( undefined, [ value ].slice( noValue ) );3679}3680
3681// For Promises/A+, convert exceptions into rejections3682// Since jQuery.when doesn't unwrap thenables, we can skip the extra checks appearing in3683// Deferred#then to conditionally suppress rejection.3684} catch ( value ) {3685
3686// Support: Android 4.0 only3687// Strict mode functions invoked without .call/.apply get global-object context3688reject.apply( undefined, [ value ] );3689}3690}
3691
3692jQuery.extend( {3693
3694Deferred: function( func ) {3695var tuples = [3696
3697// action, add listener, callbacks,3698// ... .then handlers, argument index, [final state]3699[ "notify", "progress", jQuery.Callbacks( "memory" ),3700jQuery.Callbacks( "memory" ), 2 ],3701[ "resolve", "done", jQuery.Callbacks( "once memory" ),3702jQuery.Callbacks( "once memory" ), 0, "resolved" ],3703[ "reject", "fail", jQuery.Callbacks( "once memory" ),3704jQuery.Callbacks( "once memory" ), 1, "rejected" ]3705],3706state = "pending",3707promise = {3708state: function() {3709return state;3710},3711always: function() {3712deferred.done( arguments ).fail( arguments );3713return this;3714},3715"catch": function( fn ) {3716return promise.then( null, fn );3717},3718
3719// Keep pipe for back-compat3720pipe: function( /* fnDone, fnFail, fnProgress */ ) {3721var fns = arguments;3722
3723return jQuery.Deferred( function( newDefer ) {3724jQuery.each( tuples, function( _i, tuple ) {3725
3726// Map tuples (progress, done, fail) to arguments (done, fail, progress)3727var fn = isFunction( fns[ tuple[ 4 ] ] ) && fns[ tuple[ 4 ] ];3728
3729// deferred.progress(function() { bind to newDefer or newDefer.notify })3730// deferred.done(function() { bind to newDefer or newDefer.resolve })3731// deferred.fail(function() { bind to newDefer or newDefer.reject })3732deferred[ tuple[ 1 ] ]( function() {3733var returned = fn && fn.apply( this, arguments );3734if ( returned && isFunction( returned.promise ) ) {3735returned.promise()3736.progress( newDefer.notify )3737.done( newDefer.resolve )3738.fail( newDefer.reject );3739} else {3740newDefer[ tuple[ 0 ] + "With" ](3741this,3742fn ? [ returned ] : arguments3743);3744}3745} );3746} );3747fns = null;3748} ).promise();3749},3750then: function( onFulfilled, onRejected, onProgress ) {3751var maxDepth = 0;3752function resolve( depth, deferred, handler, special ) {3753return function() {3754var that = this,3755args = arguments,3756mightThrow = function() {3757var returned, then;3758
3759// Support: Promises/A+ section 2.3.3.3.33760// https://promisesaplus.com/#point-593761// Ignore double-resolution attempts3762if ( depth < maxDepth ) {3763return;3764}3765
3766returned = handler.apply( that, args );3767
3768// Support: Promises/A+ section 2.3.13769// https://promisesaplus.com/#point-483770if ( returned === deferred.promise() ) {3771throw new TypeError( "Thenable self-resolution" );3772}3773
3774// Support: Promises/A+ sections 2.3.3.1, 3.53775// https://promisesaplus.com/#point-543776// https://promisesaplus.com/#point-753777// Retrieve `then` only once3778then = returned &&3779
3780// Support: Promises/A+ section 2.3.43781// https://promisesaplus.com/#point-643782// Only check objects and functions for thenability3783( typeof returned === "object" ||3784typeof returned === "function" ) &&3785returned.then;3786
3787// Handle a returned thenable3788if ( isFunction( then ) ) {3789
3790// Special processors (notify) just wait for resolution3791if ( special ) {3792then.call(3793returned,3794resolve( maxDepth, deferred, Identity, special ),3795resolve( maxDepth, deferred, Thrower, special )3796);3797
3798// Normal processors (resolve) also hook into progress3799} else {3800
3801// ...and disregard older resolution values3802maxDepth++;3803
3804then.call(3805returned,3806resolve( maxDepth, deferred, Identity, special ),3807resolve( maxDepth, deferred, Thrower, special ),3808resolve( maxDepth, deferred, Identity,3809deferred.notifyWith )3810);3811}3812
3813// Handle all other returned values3814} else {3815
3816// Only substitute handlers pass on context3817// and multiple values (non-spec behavior)3818if ( handler !== Identity ) {3819that = undefined;3820args = [ returned ];3821}3822
3823// Process the value(s)3824// Default process is resolve3825( special || deferred.resolveWith )( that, args );3826}3827},3828
3829// Only normal processors (resolve) catch and reject exceptions3830process = special ?3831mightThrow :3832function() {3833try {3834mightThrow();3835} catch ( e ) {3836
3837if ( jQuery.Deferred.exceptionHook ) {3838jQuery.Deferred.exceptionHook( e,3839process.stackTrace );3840}3841
3842// Support: Promises/A+ section 2.3.3.3.4.13843// https://promisesaplus.com/#point-613844// Ignore post-resolution exceptions3845if ( depth + 1 >= maxDepth ) {3846
3847// Only substitute handlers pass on context3848// and multiple values (non-spec behavior)3849if ( handler !== Thrower ) {3850that = undefined;3851args = [ e ];3852}3853
3854deferred.rejectWith( that, args );3855}3856}3857};3858
3859// Support: Promises/A+ section 2.3.3.3.13860// https://promisesaplus.com/#point-573861// Re-resolve promises immediately to dodge false rejection from3862// subsequent errors3863if ( depth ) {3864process();3865} else {3866
3867// Call an optional hook to record the stack, in case of exception3868// since it's otherwise lost when execution goes async3869if ( jQuery.Deferred.getStackHook ) {3870process.stackTrace = jQuery.Deferred.getStackHook();3871}3872window.setTimeout( process );3873}3874};3875}3876
3877return jQuery.Deferred( function( newDefer ) {3878
3879// progress_handlers.add( ... )3880tuples[ 0 ][ 3 ].add(3881resolve(38820,3883newDefer,3884isFunction( onProgress ) ?3885onProgress :3886Identity,3887newDefer.notifyWith3888)3889);3890
3891// fulfilled_handlers.add( ... )3892tuples[ 1 ][ 3 ].add(3893resolve(38940,3895newDefer,3896isFunction( onFulfilled ) ?3897onFulfilled :3898Identity
3899)3900);3901
3902// rejected_handlers.add( ... )3903tuples[ 2 ][ 3 ].add(3904resolve(39050,3906newDefer,3907isFunction( onRejected ) ?3908onRejected :3909Thrower
3910)3911);3912} ).promise();3913},3914
3915// Get a promise for this deferred3916// If obj is provided, the promise aspect is added to the object3917promise: function( obj ) {3918return obj != null ? jQuery.extend( obj, promise ) : promise;3919}3920},3921deferred = {};3922
3923// Add list-specific methods3924jQuery.each( tuples, function( i, tuple ) {3925var list = tuple[ 2 ],3926stateString = tuple[ 5 ];3927
3928// promise.progress = list.add3929// promise.done = list.add3930// promise.fail = list.add3931promise[ tuple[ 1 ] ] = list.add;3932
3933// Handle state3934if ( stateString ) {3935list.add(3936function() {3937
3938// state = "resolved" (i.e., fulfilled)3939// state = "rejected"3940state = stateString;3941},3942
3943// rejected_callbacks.disable3944// fulfilled_callbacks.disable3945tuples[ 3 - i ][ 2 ].disable,3946
3947// rejected_handlers.disable3948// fulfilled_handlers.disable3949tuples[ 3 - i ][ 3 ].disable,3950
3951// progress_callbacks.lock3952tuples[ 0 ][ 2 ].lock,3953
3954// progress_handlers.lock3955tuples[ 0 ][ 3 ].lock3956);3957}3958
3959// progress_handlers.fire3960// fulfilled_handlers.fire3961// rejected_handlers.fire3962list.add( tuple[ 3 ].fire );3963
3964// deferred.notify = function() { deferred.notifyWith(...) }3965// deferred.resolve = function() { deferred.resolveWith(...) }3966// deferred.reject = function() { deferred.rejectWith(...) }3967deferred[ tuple[ 0 ] ] = function() {3968deferred[ tuple[ 0 ] + "With" ]( this === deferred ? undefined : this, arguments );3969return this;3970};3971
3972// deferred.notifyWith = list.fireWith3973// deferred.resolveWith = list.fireWith3974// deferred.rejectWith = list.fireWith3975deferred[ tuple[ 0 ] + "With" ] = list.fireWith;3976} );3977
3978// Make the deferred a promise3979promise.promise( deferred );3980
3981// Call given func if any3982if ( func ) {3983func.call( deferred, deferred );3984}3985
3986// All done!3987return deferred;3988},3989
3990// Deferred helper3991when: function( singleValue ) {3992var3993
3994// count of uncompleted subordinates3995remaining = arguments.length,3996
3997// count of unprocessed arguments3998i = remaining,3999
4000// subordinate fulfillment data4001resolveContexts = Array( i ),4002resolveValues = slice.call( arguments ),4003
4004// the primary Deferred4005primary = jQuery.Deferred(),4006
4007// subordinate callback factory4008updateFunc = function( i ) {4009return function( value ) {4010resolveContexts[ i ] = this;4011resolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;4012if ( !( --remaining ) ) {4013primary.resolveWith( resolveContexts, resolveValues );4014}4015};4016};4017
4018// Single- and empty arguments are adopted like Promise.resolve4019if ( remaining <= 1 ) {4020adoptValue( singleValue, primary.done( updateFunc( i ) ).resolve, primary.reject,4021!remaining );4022
4023// Use .then() to unwrap secondary thenables (cf. gh-3000)4024if ( primary.state() === "pending" ||4025isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) {4026
4027return primary.then();4028}4029}4030
4031// Multiple arguments are aggregated like Promise.all array elements4032while ( i-- ) {4033adoptValue( resolveValues[ i ], updateFunc( i ), primary.reject );4034}4035
4036return primary.promise();4037}4038} );4039
4040
4041// These usually indicate a programmer mistake during development,
4042// warn about them ASAP rather than swallowing them by default.
4043var rerrorNames = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;4044
4045jQuery.Deferred.exceptionHook = function( error, stack ) {4046
4047// Support: IE 8 - 9 only4048// Console exists when dev tools are open, which can happen at any time4049if ( window.console && window.console.warn && error && rerrorNames.test( error.name ) ) {4050window.console.warn( "jQuery.Deferred exception: " + error.message, error.stack, stack );4051}4052};4053
4054
4055
4056
4057jQuery.readyException = function( error ) {4058window.setTimeout( function() {4059throw error;4060} );4061};4062
4063
4064
4065
4066// The deferred used on DOM ready
4067var readyList = jQuery.Deferred();4068
4069jQuery.fn.ready = function( fn ) {4070
4071readyList
4072.then( fn )4073
4074// Wrap jQuery.readyException in a function so that the lookup4075// happens at the time of error handling instead of callback4076// registration.4077.catch( function( error ) {4078jQuery.readyException( error );4079} );4080
4081return this;4082};4083
4084jQuery.extend( {4085
4086// Is the DOM ready to be used? Set to true once it occurs.4087isReady: false,4088
4089// A counter to track how many items to wait for before4090// the ready event fires. See #67814091readyWait: 1,4092
4093// Handle when the DOM is ready4094ready: function( wait ) {4095
4096// Abort if there are pending holds or we're already ready4097if ( wait === true ? --jQuery.readyWait : jQuery.isReady ) {4098return;4099}4100
4101// Remember that the DOM is ready4102jQuery.isReady = true;4103
4104// If a normal DOM Ready event fired, decrement, and wait if need be4105if ( wait !== true && --jQuery.readyWait > 0 ) {4106return;4107}4108
4109// If there are functions bound, to execute4110readyList.resolveWith( document, [ jQuery ] );4111}4112} );4113
4114jQuery.ready.then = readyList.then;4115
4116// The ready event handler and self cleanup method
4117function completed() {4118document.removeEventListener( "DOMContentLoaded", completed );4119window.removeEventListener( "load", completed );4120jQuery.ready();4121}
4122
4123// Catch cases where $(document).ready() is called
4124// after the browser event has already occurred.
4125// Support: IE <=9 - 10 only
4126// Older IE sometimes signals "interactive" too soon
4127if ( document.readyState === "complete" ||4128( document.readyState !== "loading" && !document.documentElement.doScroll ) ) {4129
4130// Handle it asynchronously to allow scripts the opportunity to delay ready4131window.setTimeout( jQuery.ready );4132
4133} else {4134
4135// Use the handy event callback4136document.addEventListener( "DOMContentLoaded", completed );4137
4138// A fallback to window.onload, that will always work4139window.addEventListener( "load", completed );4140}
4141
4142
4143
4144
4145// Multifunctional method to get and set values of a collection
4146// The value/s can optionally be executed if it's a function
4147var access = function( elems, fn, key, value, chainable, emptyGet, raw ) {4148var i = 0,4149len = elems.length,4150bulk = key == null;4151
4152// Sets many values4153if ( toType( key ) === "object" ) {4154chainable = true;4155for ( i in key ) {4156access( elems, fn, i, key[ i ], true, emptyGet, raw );4157}4158
4159// Sets one value4160} else if ( value !== undefined ) {4161chainable = true;4162
4163if ( !isFunction( value ) ) {4164raw = true;4165}4166
4167if ( bulk ) {4168
4169// Bulk operations run against the entire set4170if ( raw ) {4171fn.call( elems, value );4172fn = null;4173
4174// ...except when executing function values4175} else {4176bulk = fn;4177fn = function( elem, _key, value ) {4178return bulk.call( jQuery( elem ), value );4179};4180}4181}4182
4183if ( fn ) {4184for ( ; i < len; i++ ) {4185fn(4186elems[ i ], key, raw ?4187value :4188value.call( elems[ i ], i, fn( elems[ i ], key ) )4189);4190}4191}4192}4193
4194if ( chainable ) {4195return elems;4196}4197
4198// Gets4199if ( bulk ) {4200return fn.call( elems );4201}4202
4203return len ? fn( elems[ 0 ], key ) : emptyGet;4204};4205
4206
4207// Matches dashed string for camelizing
4208var rmsPrefix = /^-ms-/,4209rdashAlpha = /-([a-z])/g;4210
4211// Used by camelCase as callback to replace()
4212function fcamelCase( _all, letter ) {4213return letter.toUpperCase();4214}
4215
4216// Convert dashed to camelCase; used by the css and data modules
4217// Support: IE <=9 - 11, Edge 12 - 15
4218// Microsoft forgot to hump their vendor prefix (#9572)
4219function camelCase( string ) {4220return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase );4221}
4222var acceptData = function( owner ) {4223
4224// Accepts only:4225// - Node4226// - Node.ELEMENT_NODE4227// - Node.DOCUMENT_NODE4228// - Object4229// - Any4230return owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType );4231};4232
4233
4234
4235
4236function Data() {4237this.expando = jQuery.expando + Data.uid++;4238}
4239
4240Data.uid = 1;4241
4242Data.prototype = {4243
4244cache: function( owner ) {4245
4246// Check if the owner object already has a cache4247var value = owner[ this.expando ];4248
4249// If not, create one4250if ( !value ) {4251value = {};4252
4253// We can accept data for non-element nodes in modern browsers,4254// but we should not, see #8335.4255// Always return an empty object.4256if ( acceptData( owner ) ) {4257
4258// If it is a node unlikely to be stringify-ed or looped over4259// use plain assignment4260if ( owner.nodeType ) {4261owner[ this.expando ] = value;4262
4263// Otherwise secure it in a non-enumerable property4264// configurable must be true to allow the property to be4265// deleted when data is removed4266} else {4267Object.defineProperty( owner, this.expando, {4268value: value,4269configurable: true4270} );4271}4272}4273}4274
4275return value;4276},4277set: function( owner, data, value ) {4278var prop,4279cache = this.cache( owner );4280
4281// Handle: [ owner, key, value ] args4282// Always use camelCase key (gh-2257)4283if ( typeof data === "string" ) {4284cache[ camelCase( data ) ] = value;4285
4286// Handle: [ owner, { properties } ] args4287} else {4288
4289// Copy the properties one-by-one to the cache object4290for ( prop in data ) {4291cache[ camelCase( prop ) ] = data[ prop ];4292}4293}4294return cache;4295},4296get: function( owner, key ) {4297return key === undefined ?4298this.cache( owner ) :4299
4300// Always use camelCase key (gh-2257)4301owner[ this.expando ] && owner[ this.expando ][ camelCase( key ) ];4302},4303access: function( owner, key, value ) {4304
4305// In cases where either:4306//4307// 1. No key was specified4308// 2. A string key was specified, but no value provided4309//4310// Take the "read" path and allow the get method to determine4311// which value to return, respectively either:4312//4313// 1. The entire cache object4314// 2. The data stored at the key4315//4316if ( key === undefined ||4317( ( key && typeof key === "string" ) && value === undefined ) ) {4318
4319return this.get( owner, key );4320}4321
4322// When the key is not a string, or both a key and value4323// are specified, set or extend (existing objects) with either:4324//4325// 1. An object of properties4326// 2. A key and value4327//4328this.set( owner, key, value );4329
4330// Since the "set" path can have two possible entry points4331// return the expected data based on which path was taken[*]4332return value !== undefined ? value : key;4333},4334remove: function( owner, key ) {4335var i,4336cache = owner[ this.expando ];4337
4338if ( cache === undefined ) {4339return;4340}4341
4342if ( key !== undefined ) {4343
4344// Support array or space separated string of keys4345if ( Array.isArray( key ) ) {4346
4347// If key is an array of keys...4348// We always set camelCase keys, so remove that.4349key = key.map( camelCase );4350} else {4351key = camelCase( key );4352
4353// If a key with the spaces exists, use it.4354// Otherwise, create an array by matching non-whitespace4355key = key in cache ?4356[ key ] :4357( key.match( rnothtmlwhite ) || [] );4358}4359
4360i = key.length;4361
4362while ( i-- ) {4363delete cache[ key[ i ] ];4364}4365}4366
4367// Remove the expando if there's no more data4368if ( key === undefined || jQuery.isEmptyObject( cache ) ) {4369
4370// Support: Chrome <=35 - 454371// Webkit & Blink performance suffers when deleting properties4372// from DOM nodes, so set to undefined instead4373// https://bugs.chromium.org/p/chromium/issues/detail?id=378607 (bug restricted)4374if ( owner.nodeType ) {4375owner[ this.expando ] = undefined;4376} else {4377delete owner[ this.expando ];4378}4379}4380},4381hasData: function( owner ) {4382var cache = owner[ this.expando ];4383return cache !== undefined && !jQuery.isEmptyObject( cache );4384}4385};4386var dataPriv = new Data();4387
4388var dataUser = new Data();4389
4390
4391
4392// Implementation Summary
4393//
4394// 1. Enforce API surface and semantic compatibility with 1.9.x branch
4395// 2. Improve the module's maintainability by reducing the storage
4396// paths to a single mechanism.
4397// 3. Use the same single mechanism to support "private" and "user" data.
4398// 4. _Never_ expose "private" data to user code (TODO: Drop _data, _removeData)
4399// 5. Avoid exposing implementation details on user objects (eg. expando properties)
4400// 6. Provide a clear path for implementation upgrade to WeakMap in 2014
4401
4402var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,4403rmultiDash = /[A-Z]/g;4404
4405function getData( data ) {4406if ( data === "true" ) {4407return true;4408}4409
4410if ( data === "false" ) {4411return false;4412}4413
4414if ( data === "null" ) {4415return null;4416}4417
4418// Only convert to a number if it doesn't change the string4419if ( data === +data + "" ) {4420return +data;4421}4422
4423if ( rbrace.test( data ) ) {4424return JSON.parse( data );4425}4426
4427return data;4428}
4429
4430function dataAttr( elem, key, data ) {4431var name;4432
4433// If nothing was found internally, try to fetch any4434// data from the HTML5 data-* attribute4435if ( data === undefined && elem.nodeType === 1 ) {4436name = "data-" + key.replace( rmultiDash, "-$&" ).toLowerCase();4437data = elem.getAttribute( name );4438
4439if ( typeof data === "string" ) {4440try {4441data = getData( data );4442} catch ( e ) {}4443
4444// Make sure we set the data so it isn't changed later4445dataUser.set( elem, key, data );4446} else {4447data = undefined;4448}4449}4450return data;4451}
4452
4453jQuery.extend( {4454hasData: function( elem ) {4455return dataUser.hasData( elem ) || dataPriv.hasData( elem );4456},4457
4458data: function( elem, name, data ) {4459return dataUser.access( elem, name, data );4460},4461
4462removeData: function( elem, name ) {4463dataUser.remove( elem, name );4464},4465
4466// TODO: Now that all calls to _data and _removeData have been replaced4467// with direct calls to dataPriv methods, these can be deprecated.4468_data: function( elem, name, data ) {4469return dataPriv.access( elem, name, data );4470},4471
4472_removeData: function( elem, name ) {4473dataPriv.remove( elem, name );4474}4475} );4476
4477jQuery.fn.extend( {4478data: function( key, value ) {4479var i, name, data,4480elem = this[ 0 ],4481attrs = elem && elem.attributes;4482
4483// Gets all values4484if ( key === undefined ) {4485if ( this.length ) {4486data = dataUser.get( elem );4487
4488if ( elem.nodeType === 1 && !dataPriv.get( elem, "hasDataAttrs" ) ) {4489i = attrs.length;4490while ( i-- ) {4491
4492// Support: IE 11 only4493// The attrs elements can be null (#14894)4494if ( attrs[ i ] ) {4495name = attrs[ i ].name;4496if ( name.indexOf( "data-" ) === 0 ) {4497name = camelCase( name.slice( 5 ) );4498dataAttr( elem, name, data[ name ] );4499}4500}4501}4502dataPriv.set( elem, "hasDataAttrs", true );4503}4504}4505
4506return data;4507}4508
4509// Sets multiple values4510if ( typeof key === "object" ) {4511return this.each( function() {4512dataUser.set( this, key );4513} );4514}4515
4516return access( this, function( value ) {4517var data;4518
4519// The calling jQuery object (element matches) is not empty4520// (and therefore has an element appears at this[ 0 ]) and the4521// `value` parameter was not undefined. An empty jQuery object4522// will result in `undefined` for elem = this[ 0 ] which will4523// throw an exception if an attempt to read a data cache is made.4524if ( elem && value === undefined ) {4525
4526// Attempt to get data from the cache4527// The key will always be camelCased in Data4528data = dataUser.get( elem, key );4529if ( data !== undefined ) {4530return data;4531}4532
4533// Attempt to "discover" the data in4534// HTML5 custom data-* attrs4535data = dataAttr( elem, key );4536if ( data !== undefined ) {4537return data;4538}4539
4540// We tried really hard, but the data doesn't exist.4541return;4542}4543
4544// Set the data...4545this.each( function() {4546
4547// We always store the camelCased key4548dataUser.set( this, key, value );4549} );4550}, null, value, arguments.length > 1, null, true );4551},4552
4553removeData: function( key ) {4554return this.each( function() {4555dataUser.remove( this, key );4556} );4557}4558} );4559
4560
4561jQuery.extend( {4562queue: function( elem, type, data ) {4563var queue;4564
4565if ( elem ) {4566type = ( type || "fx" ) + "queue";4567queue = dataPriv.get( elem, type );4568
4569// Speed up dequeue by getting out quickly if this is just a lookup4570if ( data ) {4571if ( !queue || Array.isArray( data ) ) {4572queue = dataPriv.access( elem, type, jQuery.makeArray( data ) );4573} else {4574queue.push( data );4575}4576}4577return queue || [];4578}4579},4580
4581dequeue: function( elem, type ) {4582type = type || "fx";4583
4584var queue = jQuery.queue( elem, type ),4585startLength = queue.length,4586fn = queue.shift(),4587hooks = jQuery._queueHooks( elem, type ),4588next = function() {4589jQuery.dequeue( elem, type );4590};4591
4592// If the fx queue is dequeued, always remove the progress sentinel4593if ( fn === "inprogress" ) {4594fn = queue.shift();4595startLength--;4596}4597
4598if ( fn ) {4599
4600// Add a progress sentinel to prevent the fx queue from being4601// automatically dequeued4602if ( type === "fx" ) {4603queue.unshift( "inprogress" );4604}4605
4606// Clear up the last queue stop function4607delete hooks.stop;4608fn.call( elem, next, hooks );4609}4610
4611if ( !startLength && hooks ) {4612hooks.empty.fire();4613}4614},4615
4616// Not public - generate a queueHooks object, or return the current one4617_queueHooks: function( elem, type ) {4618var key = type + "queueHooks";4619return dataPriv.get( elem, key ) || dataPriv.access( elem, key, {4620empty: jQuery.Callbacks( "once memory" ).add( function() {4621dataPriv.remove( elem, [ type + "queue", key ] );4622} )4623} );4624}4625} );4626
4627jQuery.fn.extend( {4628queue: function( type, data ) {4629var setter = 2;4630
4631if ( typeof type !== "string" ) {4632data = type;4633type = "fx";4634setter--;4635}4636
4637if ( arguments.length < setter ) {4638return jQuery.queue( this[ 0 ], type );4639}4640
4641return data === undefined ?4642this :4643this.each( function() {4644var queue = jQuery.queue( this, type, data );4645
4646// Ensure a hooks for this queue4647jQuery._queueHooks( this, type );4648
4649if ( type === "fx" && queue[ 0 ] !== "inprogress" ) {4650jQuery.dequeue( this, type );4651}4652} );4653},4654dequeue: function( type ) {4655return this.each( function() {4656jQuery.dequeue( this, type );4657} );4658},4659clearQueue: function( type ) {4660return this.queue( type || "fx", [] );4661},4662
4663// Get a promise resolved when queues of a certain type4664// are emptied (fx is the type by default)4665promise: function( type, obj ) {4666var tmp,4667count = 1,4668defer = jQuery.Deferred(),4669elements = this,4670i = this.length,4671resolve = function() {4672if ( !( --count ) ) {4673defer.resolveWith( elements, [ elements ] );4674}4675};4676
4677if ( typeof type !== "string" ) {4678obj = type;4679type = undefined;4680}4681type = type || "fx";4682
4683while ( i-- ) {4684tmp = dataPriv.get( elements[ i ], type + "queueHooks" );4685if ( tmp && tmp.empty ) {4686count++;4687tmp.empty.add( resolve );4688}4689}4690resolve();4691return defer.promise( obj );4692}4693} );4694var pnum = ( /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/ ).source;4695
4696var rcssNum = new RegExp( "^(?:([+-])=|)(" + pnum + ")([a-z%]*)$", "i" );4697
4698
4699var cssExpand = [ "Top", "Right", "Bottom", "Left" ];4700
4701var documentElement = document.documentElement;4702
4703
4704
4705var isAttached = function( elem ) {4706return jQuery.contains( elem.ownerDocument, elem );4707},4708composed = { composed: true };4709
4710// Support: IE 9 - 11+, Edge 12 - 18+, iOS 10.0 - 10.2 only4711// Check attachment across shadow DOM boundaries when possible (gh-3504)4712// Support: iOS 10.0-10.2 only4713// Early iOS 10 versions support `attachShadow` but not `getRootNode`,4714// leading to errors. We need to check for `getRootNode`.4715if ( documentElement.getRootNode ) {4716isAttached = function( elem ) {4717return jQuery.contains( elem.ownerDocument, elem ) ||4718elem.getRootNode( composed ) === elem.ownerDocument;4719};4720}4721var isHiddenWithinTree = function( elem, el ) {4722
4723// isHiddenWithinTree might be called from jQuery#filter function;4724// in that case, element will be second argument4725elem = el || elem;4726
4727// Inline style trumps all4728return elem.style.display === "none" ||4729elem.style.display === "" &&4730
4731// Otherwise, check computed style4732// Support: Firefox <=43 - 454733// Disconnected elements can have computed display: none, so first confirm that elem is4734// in the document.4735isAttached( elem ) &&4736
4737jQuery.css( elem, "display" ) === "none";4738};4739
4740
4741
4742function adjustCSS( elem, prop, valueParts, tween ) {4743var adjusted, scale,4744maxIterations = 20,4745currentValue = tween ?4746function() {4747return tween.cur();4748} :4749function() {4750return jQuery.css( elem, prop, "" );4751},4752initial = currentValue(),4753unit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ),4754
4755// Starting value computation is required for potential unit mismatches4756initialInUnit = elem.nodeType &&4757( jQuery.cssNumber[ prop ] || unit !== "px" && +initial ) &&4758rcssNum.exec( jQuery.css( elem, prop ) );4759
4760if ( initialInUnit && initialInUnit[ 3 ] !== unit ) {4761
4762// Support: Firefox <=544763// Halve the iteration target value to prevent interference from CSS upper bounds (gh-2144)4764initial = initial / 2;4765
4766// Trust units reported by jQuery.css4767unit = unit || initialInUnit[ 3 ];4768
4769// Iteratively approximate from a nonzero starting point4770initialInUnit = +initial || 1;4771
4772while ( maxIterations-- ) {4773
4774// Evaluate and update our best guess (doubling guesses that zero out).4775// Finish if the scale equals or crosses 1 (making the old*new product non-positive).4776jQuery.style( elem, prop, initialInUnit + unit );4777if ( ( 1 - scale ) * ( 1 - ( scale = currentValue() / initial || 0.5 ) ) <= 0 ) {4778maxIterations = 0;4779}4780initialInUnit = initialInUnit / scale;4781
4782}4783
4784initialInUnit = initialInUnit * 2;4785jQuery.style( elem, prop, initialInUnit + unit );4786
4787// Make sure we update the tween properties later on4788valueParts = valueParts || [];4789}4790
4791if ( valueParts ) {4792initialInUnit = +initialInUnit || +initial || 0;4793
4794// Apply relative offset (+=/-=) if specified4795adjusted = valueParts[ 1 ] ?4796initialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] :4797+valueParts[ 2 ];4798if ( tween ) {4799tween.unit = unit;4800tween.start = initialInUnit;4801tween.end = adjusted;4802}4803}4804return adjusted;4805}
4806
4807
4808var defaultDisplayMap = {};4809
4810function getDefaultDisplay( elem ) {4811var temp,4812doc = elem.ownerDocument,4813nodeName = elem.nodeName,4814display = defaultDisplayMap[ nodeName ];4815
4816if ( display ) {4817return display;4818}4819
4820temp = doc.body.appendChild( doc.createElement( nodeName ) );4821display = jQuery.css( temp, "display" );4822
4823temp.parentNode.removeChild( temp );4824
4825if ( display === "none" ) {4826display = "block";4827}4828defaultDisplayMap[ nodeName ] = display;4829
4830return display;4831}
4832
4833function showHide( elements, show ) {4834var display, elem,4835values = [],4836index = 0,4837length = elements.length;4838
4839// Determine new display value for elements that need to change4840for ( ; index < length; index++ ) {4841elem = elements[ index ];4842if ( !elem.style ) {4843continue;4844}4845
4846display = elem.style.display;4847if ( show ) {4848
4849// Since we force visibility upon cascade-hidden elements, an immediate (and slow)4850// check is required in this first loop unless we have a nonempty display value (either4851// inline or about-to-be-restored)4852if ( display === "none" ) {4853values[ index ] = dataPriv.get( elem, "display" ) || null;4854if ( !values[ index ] ) {4855elem.style.display = "";4856}4857}4858if ( elem.style.display === "" && isHiddenWithinTree( elem ) ) {4859values[ index ] = getDefaultDisplay( elem );4860}4861} else {4862if ( display !== "none" ) {4863values[ index ] = "none";4864
4865// Remember what we're overwriting4866dataPriv.set( elem, "display", display );4867}4868}4869}4870
4871// Set the display of the elements in a second loop to avoid constant reflow4872for ( index = 0; index < length; index++ ) {4873if ( values[ index ] != null ) {4874elements[ index ].style.display = values[ index ];4875}4876}4877
4878return elements;4879}
4880
4881jQuery.fn.extend( {4882show: function() {4883return showHide( this, true );4884},4885hide: function() {4886return showHide( this );4887},4888toggle: function( state ) {4889if ( typeof state === "boolean" ) {4890return state ? this.show() : this.hide();4891}4892
4893return this.each( function() {4894if ( isHiddenWithinTree( this ) ) {4895jQuery( this ).show();4896} else {4897jQuery( this ).hide();4898}4899} );4900}4901} );4902var rcheckableType = ( /^(?:checkbox|radio)$/i );4903
4904var rtagName = ( /<([a-z][^\/\0>\x20\t\r\n\f]*)/i );4905
4906var rscriptType = ( /^$|^module$|\/(?:java|ecma)script/i );4907
4908
4909
4910( function() {4911var fragment = document.createDocumentFragment(),4912div = fragment.appendChild( document.createElement( "div" ) ),4913input = document.createElement( "input" );4914
4915// Support: Android 4.0 - 4.3 only4916// Check state lost if the name is set (#11217)4917// Support: Windows Web Apps (WWA)4918// `name` and `type` must use .setAttribute for WWA (#14901)4919input.setAttribute( "type", "radio" );4920input.setAttribute( "checked", "checked" );4921input.setAttribute( "name", "t" );4922
4923div.appendChild( input );4924
4925// Support: Android <=4.1 only4926// Older WebKit doesn't clone checked state correctly in fragments4927support.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked;4928
4929// Support: IE <=11 only4930// Make sure textarea (and checkbox) defaultValue is properly cloned4931div.innerHTML = "<textarea>x</textarea>";4932support.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue;4933
4934// Support: IE <=9 only4935// IE <=9 replaces <option> tags with their contents when inserted outside of4936// the select element.4937div.innerHTML = "<option></option>";4938support.option = !!div.lastChild;4939} )();4940
4941
4942// We have to close these tags to support XHTML (#13200)
4943var wrapMap = {4944
4945// XHTML parsers do not magically insert elements in the4946// same way that tag soup parsers do. So we cannot shorten4947// this by omitting <tbody> or other required elements.4948thead: [ 1, "<table>", "</table>" ],4949col: [ 2, "<table><colgroup>", "</colgroup></table>" ],4950tr: [ 2, "<table><tbody>", "</tbody></table>" ],4951td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ],4952
4953_default: [ 0, "", "" ]4954};4955
4956wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead;4957wrapMap.th = wrapMap.td;4958
4959// Support: IE <=9 only
4960if ( !support.option ) {4961wrapMap.optgroup = wrapMap.option = [ 1, "<select multiple='multiple'>", "</select>" ];4962}
4963
4964
4965function getAll( context, tag ) {4966
4967// Support: IE <=9 - 11 only4968// Use typeof to avoid zero-argument method invocation on host objects (#15151)4969var ret;4970
4971if ( typeof context.getElementsByTagName !== "undefined" ) {4972ret = context.getElementsByTagName( tag || "*" );4973
4974} else if ( typeof context.querySelectorAll !== "undefined" ) {4975ret = context.querySelectorAll( tag || "*" );4976
4977} else {4978ret = [];4979}4980
4981if ( tag === undefined || tag && nodeName( context, tag ) ) {4982return jQuery.merge( [ context ], ret );4983}4984
4985return ret;4986}
4987
4988
4989// Mark scripts as having already been evaluated
4990function setGlobalEval( elems, refElements ) {4991var i = 0,4992l = elems.length;4993
4994for ( ; i < l; i++ ) {4995dataPriv.set(4996elems[ i ],4997"globalEval",4998!refElements || dataPriv.get( refElements[ i ], "globalEval" )4999);5000}5001}
5002
5003
5004var rhtml = /<|&#?\w+;/;5005
5006function buildFragment( elems, context, scripts, selection, ignored ) {5007var elem, tmp, tag, wrap, attached, j,5008fragment = context.createDocumentFragment(),5009nodes = [],5010i = 0,5011l = elems.length;5012
5013for ( ; i < l; i++ ) {5014elem = elems[ i ];5015
5016if ( elem || elem === 0 ) {5017
5018// Add nodes directly5019if ( toType( elem ) === "object" ) {5020
5021// Support: Android <=4.0 only, PhantomJS 1 only5022// push.apply(_, arraylike) throws on ancient WebKit5023jQuery.merge( nodes, elem.nodeType ? [ elem ] : elem );5024
5025// Convert non-html into a text node5026} else if ( !rhtml.test( elem ) ) {5027nodes.push( context.createTextNode( elem ) );5028
5029// Convert html into DOM nodes5030} else {5031tmp = tmp || fragment.appendChild( context.createElement( "div" ) );5032
5033// Deserialize a standard representation5034tag = ( rtagName.exec( elem ) || [ "", "" ] )[ 1 ].toLowerCase();5035wrap = wrapMap[ tag ] || wrapMap._default;5036tmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ];5037
5038// Descend through wrappers to the right content5039j = wrap[ 0 ];5040while ( j-- ) {5041tmp = tmp.lastChild;5042}5043
5044// Support: Android <=4.0 only, PhantomJS 1 only5045// push.apply(_, arraylike) throws on ancient WebKit5046jQuery.merge( nodes, tmp.childNodes );5047
5048// Remember the top-level container5049tmp = fragment.firstChild;5050
5051// Ensure the created nodes are orphaned (#12392)5052tmp.textContent = "";5053}5054}5055}5056
5057// Remove wrapper from fragment5058fragment.textContent = "";5059
5060i = 0;5061while ( ( elem = nodes[ i++ ] ) ) {5062
5063// Skip elements already in the context collection (trac-4087)5064if ( selection && jQuery.inArray( elem, selection ) > -1 ) {5065if ( ignored ) {5066ignored.push( elem );5067}5068continue;5069}5070
5071attached = isAttached( elem );5072
5073// Append to fragment5074tmp = getAll( fragment.appendChild( elem ), "script" );5075
5076// Preserve script evaluation history5077if ( attached ) {5078setGlobalEval( tmp );5079}5080
5081// Capture executables5082if ( scripts ) {5083j = 0;5084while ( ( elem = tmp[ j++ ] ) ) {5085if ( rscriptType.test( elem.type || "" ) ) {5086scripts.push( elem );5087}5088}5089}5090}5091
5092return fragment;5093}
5094
5095
5096var rtypenamespace = /^([^.]*)(?:\.(.+)|)/;5097
5098function returnTrue() {5099return true;5100}
5101
5102function returnFalse() {5103return false;5104}
5105
5106// Support: IE <=9 - 11+
5107// focus() and blur() are asynchronous, except when they are no-op.
5108// So expect focus to be synchronous when the element is already active,
5109// and blur to be synchronous when the element is not already active.
5110// (focus and blur are always synchronous in other supported browsers,
5111// this just defines when we can count on it).
5112function expectSync( elem, type ) {5113return ( elem === safeActiveElement() ) === ( type === "focus" );5114}
5115
5116// Support: IE <=9 only
5117// Accessing document.activeElement can throw unexpectedly
5118// https://bugs.jquery.com/ticket/13393
5119function safeActiveElement() {5120try {5121return document.activeElement;5122} catch ( err ) { }5123}
5124
5125function on( elem, types, selector, data, fn, one ) {5126var origFn, type;5127
5128// Types can be a map of types/handlers5129if ( typeof types === "object" ) {5130
5131// ( types-Object, selector, data )5132if ( typeof selector !== "string" ) {5133
5134// ( types-Object, data )5135data = data || selector;5136selector = undefined;5137}5138for ( type in types ) {5139on( elem, type, selector, data, types[ type ], one );5140}5141return elem;5142}5143
5144if ( data == null && fn == null ) {5145
5146// ( types, fn )5147fn = selector;5148data = selector = undefined;5149} else if ( fn == null ) {5150if ( typeof selector === "string" ) {5151
5152// ( types, selector, fn )5153fn = data;5154data = undefined;5155} else {5156
5157// ( types, data, fn )5158fn = data;5159data = selector;5160selector = undefined;5161}5162}5163if ( fn === false ) {5164fn = returnFalse;5165} else if ( !fn ) {5166return elem;5167}5168
5169if ( one === 1 ) {5170origFn = fn;5171fn = function( event ) {5172
5173// Can use an empty set, since event contains the info5174jQuery().off( event );5175return origFn.apply( this, arguments );5176};5177
5178// Use same guid so caller can remove using origFn5179fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ );5180}5181return elem.each( function() {5182jQuery.event.add( this, types, fn, data, selector );5183} );5184}
5185
5186/*
5187* Helper functions for managing events -- not part of the public interface.
5188* Props to Dean Edwards' addEvent library for many of the ideas.
5189*/
5190jQuery.event = {5191
5192global: {},5193
5194add: function( elem, types, handler, data, selector ) {5195
5196var handleObjIn, eventHandle, tmp,5197events, t, handleObj,5198special, handlers, type, namespaces, origType,5199elemData = dataPriv.get( elem );5200
5201// Only attach events to objects that accept data5202if ( !acceptData( elem ) ) {5203return;5204}5205
5206// Caller can pass in an object of custom data in lieu of the handler5207if ( handler.handler ) {5208handleObjIn = handler;5209handler = handleObjIn.handler;5210selector = handleObjIn.selector;5211}5212
5213// Ensure that invalid selectors throw exceptions at attach time5214// Evaluate against documentElement in case elem is a non-element node (e.g., document)5215if ( selector ) {5216jQuery.find.matchesSelector( documentElement, selector );5217}5218
5219// Make sure that the handler has a unique ID, used to find/remove it later5220if ( !handler.guid ) {5221handler.guid = jQuery.guid++;5222}5223
5224// Init the element's event structure and main handler, if this is the first5225if ( !( events = elemData.events ) ) {5226events = elemData.events = Object.create( null );5227}5228if ( !( eventHandle = elemData.handle ) ) {5229eventHandle = elemData.handle = function( e ) {5230
5231// Discard the second event of a jQuery.event.trigger() and5232// when an event is called after a page has unloaded5233return typeof jQuery !== "undefined" && jQuery.event.triggered !== e.type ?5234jQuery.event.dispatch.apply( elem, arguments ) : undefined;5235};5236}5237
5238// Handle multiple events separated by a space5239types = ( types || "" ).match( rnothtmlwhite ) || [ "" ];5240t = types.length;5241while ( t-- ) {5242tmp = rtypenamespace.exec( types[ t ] ) || [];5243type = origType = tmp[ 1 ];5244namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort();5245
5246// There *must* be a type, no attaching namespace-only handlers5247if ( !type ) {5248continue;5249}5250
5251// If event changes its type, use the special event handlers for the changed type5252special = jQuery.event.special[ type ] || {};5253
5254// If selector defined, determine special event api type, otherwise given type5255type = ( selector ? special.delegateType : special.bindType ) || type;5256
5257// Update special based on newly reset type5258special = jQuery.event.special[ type ] || {};5259
5260// handleObj is passed to all event handlers5261handleObj = jQuery.extend( {5262type: type,5263origType: origType,5264data: data,5265handler: handler,5266guid: handler.guid,5267selector: selector,5268needsContext: selector && jQuery.expr.match.needsContext.test( selector ),5269namespace: namespaces.join( "." )5270}, handleObjIn );5271
5272// Init the event handler queue if we're the first5273if ( !( handlers = events[ type ] ) ) {5274handlers = events[ type ] = [];5275handlers.delegateCount = 0;5276
5277// Only use addEventListener if the special events handler returns false5278if ( !special.setup ||5279special.setup.call( elem, data, namespaces, eventHandle ) === false ) {5280
5281if ( elem.addEventListener ) {5282elem.addEventListener( type, eventHandle );5283}5284}5285}5286
5287if ( special.add ) {5288special.add.call( elem, handleObj );5289
5290if ( !handleObj.handler.guid ) {5291handleObj.handler.guid = handler.guid;5292}5293}5294
5295// Add to the element's handler list, delegates in front5296if ( selector ) {5297handlers.splice( handlers.delegateCount++, 0, handleObj );5298} else {5299handlers.push( handleObj );5300}5301
5302// Keep track of which events have ever been used, for event optimization5303jQuery.event.global[ type ] = true;5304}5305
5306},5307
5308// Detach an event or set of events from an element5309remove: function( elem, types, handler, selector, mappedTypes ) {5310
5311var j, origCount, tmp,5312events, t, handleObj,5313special, handlers, type, namespaces, origType,5314elemData = dataPriv.hasData( elem ) && dataPriv.get( elem );5315
5316if ( !elemData || !( events = elemData.events ) ) {5317return;5318}5319
5320// Once for each type.namespace in types; type may be omitted5321types = ( types || "" ).match( rnothtmlwhite ) || [ "" ];5322t = types.length;5323while ( t-- ) {5324tmp = rtypenamespace.exec( types[ t ] ) || [];5325type = origType = tmp[ 1 ];5326namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort();5327
5328// Unbind all events (on this namespace, if provided) for the element5329if ( !type ) {5330for ( type in events ) {5331jQuery.event.remove( elem, type + types[ t ], handler, selector, true );5332}5333continue;5334}5335
5336special = jQuery.event.special[ type ] || {};5337type = ( selector ? special.delegateType : special.bindType ) || type;5338handlers = events[ type ] || [];5339tmp = tmp[ 2 ] &&5340new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" );5341
5342// Remove matching events5343origCount = j = handlers.length;5344while ( j-- ) {5345handleObj = handlers[ j ];5346
5347if ( ( mappedTypes || origType === handleObj.origType ) &&5348( !handler || handler.guid === handleObj.guid ) &&5349( !tmp || tmp.test( handleObj.namespace ) ) &&5350( !selector || selector === handleObj.selector ||5351selector === "**" && handleObj.selector ) ) {5352handlers.splice( j, 1 );5353
5354if ( handleObj.selector ) {5355handlers.delegateCount--;5356}5357if ( special.remove ) {5358special.remove.call( elem, handleObj );5359}5360}5361}5362
5363// Remove generic event handler if we removed something and no more handlers exist5364// (avoids potential for endless recursion during removal of special event handlers)5365if ( origCount && !handlers.length ) {5366if ( !special.teardown ||5367special.teardown.call( elem, namespaces, elemData.handle ) === false ) {5368
5369jQuery.removeEvent( elem, type, elemData.handle );5370}5371
5372delete events[ type ];5373}5374}5375
5376// Remove data and the expando if it's no longer used5377if ( jQuery.isEmptyObject( events ) ) {5378dataPriv.remove( elem, "handle events" );5379}5380},5381
5382dispatch: function( nativeEvent ) {5383
5384var i, j, ret, matched, handleObj, handlerQueue,5385args = new Array( arguments.length ),5386
5387// Make a writable jQuery.Event from the native event object5388event = jQuery.event.fix( nativeEvent ),5389
5390handlers = (5391dataPriv.get( this, "events" ) || Object.create( null )5392)[ event.type ] || [],5393special = jQuery.event.special[ event.type ] || {};5394
5395// Use the fix-ed jQuery.Event rather than the (read-only) native event5396args[ 0 ] = event;5397
5398for ( i = 1; i < arguments.length; i++ ) {5399args[ i ] = arguments[ i ];5400}5401
5402event.delegateTarget = this;5403
5404// Call the preDispatch hook for the mapped type, and let it bail if desired5405if ( special.preDispatch && special.preDispatch.call( this, event ) === false ) {5406return;5407}5408
5409// Determine handlers5410handlerQueue = jQuery.event.handlers.call( this, event, handlers );5411
5412// Run delegates first; they may want to stop propagation beneath us5413i = 0;5414while ( ( matched = handlerQueue[ i++ ] ) && !event.isPropagationStopped() ) {5415event.currentTarget = matched.elem;5416
5417j = 0;5418while ( ( handleObj = matched.handlers[ j++ ] ) &&5419!event.isImmediatePropagationStopped() ) {5420
5421// If the event is namespaced, then each handler is only invoked if it is5422// specially universal or its namespaces are a superset of the event's.5423if ( !event.rnamespace || handleObj.namespace === false ||5424event.rnamespace.test( handleObj.namespace ) ) {5425
5426event.handleObj = handleObj;5427event.data = handleObj.data;5428
5429ret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle ||5430handleObj.handler ).apply( matched.elem, args );5431
5432if ( ret !== undefined ) {5433if ( ( event.result = ret ) === false ) {5434event.preventDefault();5435event.stopPropagation();5436}5437}5438}5439}5440}5441
5442// Call the postDispatch hook for the mapped type5443if ( special.postDispatch ) {5444special.postDispatch.call( this, event );5445}5446
5447return event.result;5448},5449
5450handlers: function( event, handlers ) {5451var i, handleObj, sel, matchedHandlers, matchedSelectors,5452handlerQueue = [],5453delegateCount = handlers.delegateCount,5454cur = event.target;5455
5456// Find delegate handlers5457if ( delegateCount &&5458
5459// Support: IE <=95460// Black-hole SVG <use> instance trees (trac-13180)5461cur.nodeType &&5462
5463// Support: Firefox <=425464// Suppress spec-violating clicks indicating a non-primary pointer button (trac-3861)5465// https://www.w3.org/TR/DOM-Level-3-Events/#event-type-click5466// Support: IE 11 only5467// ...but not arrow key "clicks" of radio inputs, which can have `button` -1 (gh-2343)5468!( event.type === "click" && event.button >= 1 ) ) {5469
5470for ( ; cur !== this; cur = cur.parentNode || this ) {5471
5472// Don't check non-elements (#13208)5473// Don't process clicks on disabled elements (#6911, #8165, #11382, #11764)5474if ( cur.nodeType === 1 && !( event.type === "click" && cur.disabled === true ) ) {5475matchedHandlers = [];5476matchedSelectors = {};5477for ( i = 0; i < delegateCount; i++ ) {5478handleObj = handlers[ i ];5479
5480// Don't conflict with Object.prototype properties (#13203)5481sel = handleObj.selector + " ";5482
5483if ( matchedSelectors[ sel ] === undefined ) {5484matchedSelectors[ sel ] = handleObj.needsContext ?5485jQuery( sel, this ).index( cur ) > -1 :5486jQuery.find( sel, this, null, [ cur ] ).length;5487}5488if ( matchedSelectors[ sel ] ) {5489matchedHandlers.push( handleObj );5490}5491}5492if ( matchedHandlers.length ) {5493handlerQueue.push( { elem: cur, handlers: matchedHandlers } );5494}5495}5496}5497}5498
5499// Add the remaining (directly-bound) handlers5500cur = this;5501if ( delegateCount < handlers.length ) {5502handlerQueue.push( { elem: cur, handlers: handlers.slice( delegateCount ) } );5503}5504
5505return handlerQueue;5506},5507
5508addProp: function( name, hook ) {5509Object.defineProperty( jQuery.Event.prototype, name, {5510enumerable: true,5511configurable: true,5512
5513get: isFunction( hook ) ?5514function() {5515if ( this.originalEvent ) {5516return hook( this.originalEvent );5517}5518} :5519function() {5520if ( this.originalEvent ) {5521return this.originalEvent[ name ];5522}5523},5524
5525set: function( value ) {5526Object.defineProperty( this, name, {5527enumerable: true,5528configurable: true,5529writable: true,5530value: value5531} );5532}5533} );5534},5535
5536fix: function( originalEvent ) {5537return originalEvent[ jQuery.expando ] ?5538originalEvent :5539new jQuery.Event( originalEvent );5540},5541
5542special: {5543load: {5544
5545// Prevent triggered image.load events from bubbling to window.load5546noBubble: true5547},5548click: {5549
5550// Utilize native event to ensure correct state for checkable inputs5551setup: function( data ) {5552
5553// For mutual compressibility with _default, replace `this` access with a local var.5554// `|| data` is dead code meant only to preserve the variable through minification.5555var el = this || data;5556
5557// Claim the first handler5558if ( rcheckableType.test( el.type ) &&5559el.click && nodeName( el, "input" ) ) {5560
5561// dataPriv.set( el, "click", ... )5562leverageNative( el, "click", returnTrue );5563}5564
5565// Return false to allow normal processing in the caller5566return false;5567},5568trigger: function( data ) {5569
5570// For mutual compressibility with _default, replace `this` access with a local var.5571// `|| data` is dead code meant only to preserve the variable through minification.5572var el = this || data;5573
5574// Force setup before triggering a click5575if ( rcheckableType.test( el.type ) &&5576el.click && nodeName( el, "input" ) ) {5577
5578leverageNative( el, "click" );5579}5580
5581// Return non-false to allow normal event-path propagation5582return true;5583},5584
5585// For cross-browser consistency, suppress native .click() on links5586// Also prevent it if we're currently inside a leveraged native-event stack5587_default: function( event ) {5588var target = event.target;5589return rcheckableType.test( target.type ) &&5590target.click && nodeName( target, "input" ) &&5591dataPriv.get( target, "click" ) ||5592nodeName( target, "a" );5593}5594},5595
5596beforeunload: {5597postDispatch: function( event ) {5598
5599// Support: Firefox 20+5600// Firefox doesn't alert if the returnValue field is not set.5601if ( event.result !== undefined && event.originalEvent ) {5602event.originalEvent.returnValue = event.result;5603}5604}5605}5606}5607};5608
5609// Ensure the presence of an event listener that handles manually-triggered
5610// synthetic events by interrupting progress until reinvoked in response to
5611// *native* events that it fires directly, ensuring that state changes have
5612// already occurred before other listeners are invoked.
5613function leverageNative( el, type, expectSync ) {5614
5615// Missing expectSync indicates a trigger call, which must force setup through jQuery.event.add5616if ( !expectSync ) {5617if ( dataPriv.get( el, type ) === undefined ) {5618jQuery.event.add( el, type, returnTrue );5619}5620return;5621}5622
5623// Register the controller as a special universal handler for all event namespaces5624dataPriv.set( el, type, false );5625jQuery.event.add( el, type, {5626namespace: false,5627handler: function( event ) {5628var notAsync, result,5629saved = dataPriv.get( this, type );5630
5631if ( ( event.isTrigger & 1 ) && this[ type ] ) {5632
5633// Interrupt processing of the outer synthetic .trigger()ed event5634// Saved data should be false in such cases, but might be a leftover capture object5635// from an async native handler (gh-4350)5636if ( !saved.length ) {5637
5638// Store arguments for use when handling the inner native event5639// There will always be at least one argument (an event object), so this array5640// will not be confused with a leftover capture object.5641saved = slice.call( arguments );5642dataPriv.set( this, type, saved );5643
5644// Trigger the native event and capture its result5645// Support: IE <=9 - 11+5646// focus() and blur() are asynchronous5647notAsync = expectSync( this, type );5648this[ type ]();5649result = dataPriv.get( this, type );5650if ( saved !== result || notAsync ) {5651dataPriv.set( this, type, false );5652} else {5653result = {};5654}5655if ( saved !== result ) {5656
5657// Cancel the outer synthetic event5658event.stopImmediatePropagation();5659event.preventDefault();5660
5661// Support: Chrome 86+5662// In Chrome, if an element having a focusout handler is blurred by5663// clicking outside of it, it invokes the handler synchronously. If5664// that handler calls `.remove()` on the element, the data is cleared,5665// leaving `result` undefined. We need to guard against this.5666return result && result.value;5667}5668
5669// If this is an inner synthetic event for an event with a bubbling surrogate5670// (focus or blur), assume that the surrogate already propagated from triggering the5671// native event and prevent that from happening again here.5672// This technically gets the ordering wrong w.r.t. to `.trigger()` (in which the5673// bubbling surrogate propagates *after* the non-bubbling base), but that seems5674// less bad than duplication.5675} else if ( ( jQuery.event.special[ type ] || {} ).delegateType ) {5676event.stopPropagation();5677}5678
5679// If this is a native event triggered above, everything is now in order5680// Fire an inner synthetic event with the original arguments5681} else if ( saved.length ) {5682
5683// ...and capture the result5684dataPriv.set( this, type, {5685value: jQuery.event.trigger(5686
5687// Support: IE <=9 - 11+5688// Extend with the prototype to reset the above stopImmediatePropagation()5689jQuery.extend( saved[ 0 ], jQuery.Event.prototype ),5690saved.slice( 1 ),5691this5692)5693} );5694
5695// Abort handling of the native event5696event.stopImmediatePropagation();5697}5698}5699} );5700}
5701
5702jQuery.removeEvent = function( elem, type, handle ) {5703
5704// This "if" is needed for plain objects5705if ( elem.removeEventListener ) {5706elem.removeEventListener( type, handle );5707}5708};5709
5710jQuery.Event = function( src, props ) {5711
5712// Allow instantiation without the 'new' keyword5713if ( !( this instanceof jQuery.Event ) ) {5714return new jQuery.Event( src, props );5715}5716
5717// Event object5718if ( src && src.type ) {5719this.originalEvent = src;5720this.type = src.type;5721
5722// Events bubbling up the document may have been marked as prevented5723// by a handler lower down the tree; reflect the correct value.5724this.isDefaultPrevented = src.defaultPrevented ||5725src.defaultPrevented === undefined &&5726
5727// Support: Android <=2.3 only5728src.returnValue === false ?5729returnTrue :5730returnFalse;5731
5732// Create target properties5733// Support: Safari <=6 - 7 only5734// Target should not be a text node (#504, #13143)5735this.target = ( src.target && src.target.nodeType === 3 ) ?5736src.target.parentNode :5737src.target;5738
5739this.currentTarget = src.currentTarget;5740this.relatedTarget = src.relatedTarget;5741
5742// Event type5743} else {5744this.type = src;5745}5746
5747// Put explicitly provided properties onto the event object5748if ( props ) {5749jQuery.extend( this, props );5750}5751
5752// Create a timestamp if incoming event doesn't have one5753this.timeStamp = src && src.timeStamp || Date.now();5754
5755// Mark it as fixed5756this[ jQuery.expando ] = true;5757};5758
5759// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding
5760// https://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html
5761jQuery.Event.prototype = {5762constructor: jQuery.Event,5763isDefaultPrevented: returnFalse,5764isPropagationStopped: returnFalse,5765isImmediatePropagationStopped: returnFalse,5766isSimulated: false,5767
5768preventDefault: function() {5769var e = this.originalEvent;5770
5771this.isDefaultPrevented = returnTrue;5772
5773if ( e && !this.isSimulated ) {5774e.preventDefault();5775}5776},5777stopPropagation: function() {5778var e = this.originalEvent;5779
5780this.isPropagationStopped = returnTrue;5781
5782if ( e && !this.isSimulated ) {5783e.stopPropagation();5784}5785},5786stopImmediatePropagation: function() {5787var e = this.originalEvent;5788
5789this.isImmediatePropagationStopped = returnTrue;5790
5791if ( e && !this.isSimulated ) {5792e.stopImmediatePropagation();5793}5794
5795this.stopPropagation();5796}5797};5798
5799// Includes all common event props including KeyEvent and MouseEvent specific props
5800jQuery.each( {5801altKey: true,5802bubbles: true,5803cancelable: true,5804changedTouches: true,5805ctrlKey: true,5806detail: true,5807eventPhase: true,5808metaKey: true,5809pageX: true,5810pageY: true,5811shiftKey: true,5812view: true,5813"char": true,5814code: true,5815charCode: true,5816key: true,5817keyCode: true,5818button: true,5819buttons: true,5820clientX: true,5821clientY: true,5822offsetX: true,5823offsetY: true,5824pointerId: true,5825pointerType: true,5826screenX: true,5827screenY: true,5828targetTouches: true,5829toElement: true,5830touches: true,5831which: true5832}, jQuery.event.addProp );5833
5834jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateType ) {5835jQuery.event.special[ type ] = {5836
5837// Utilize native event if possible so blur/focus sequence is correct5838setup: function() {5839
5840// Claim the first handler5841// dataPriv.set( this, "focus", ... )5842// dataPriv.set( this, "blur", ... )5843leverageNative( this, type, expectSync );5844
5845// Return false to allow normal processing in the caller5846return false;5847},5848trigger: function() {5849
5850// Force setup before trigger5851leverageNative( this, type );5852
5853// Return non-false to allow normal event-path propagation5854return true;5855},5856
5857// Suppress native focus or blur as it's already being fired5858// in leverageNative.5859_default: function() {5860return true;5861},5862
5863delegateType: delegateType5864};5865} );5866
5867// Create mouseenter/leave events using mouseover/out and event-time checks
5868// so that event delegation works in jQuery.
5869// Do the same for pointerenter/pointerleave and pointerover/pointerout
5870//
5871// Support: Safari 7 only
5872// Safari sends mouseenter too often; see:
5873// https://bugs.chromium.org/p/chromium/issues/detail?id=470258
5874// for the description of the bug (it existed in older Chrome versions as well).
5875jQuery.each( {5876mouseenter: "mouseover",5877mouseleave: "mouseout",5878pointerenter: "pointerover",5879pointerleave: "pointerout"5880}, function( orig, fix ) {5881jQuery.event.special[ orig ] = {5882delegateType: fix,5883bindType: fix,5884
5885handle: function( event ) {5886var ret,5887target = this,5888related = event.relatedTarget,5889handleObj = event.handleObj;5890
5891// For mouseenter/leave call the handler if related is outside the target.5892// NB: No relatedTarget if the mouse left/entered the browser window5893if ( !related || ( related !== target && !jQuery.contains( target, related ) ) ) {5894event.type = handleObj.origType;5895ret = handleObj.handler.apply( this, arguments );5896event.type = fix;5897}5898return ret;5899}5900};5901} );5902
5903jQuery.fn.extend( {5904
5905on: function( types, selector, data, fn ) {5906return on( this, types, selector, data, fn );5907},5908one: function( types, selector, data, fn ) {5909return on( this, types, selector, data, fn, 1 );5910},5911off: function( types, selector, fn ) {5912var handleObj, type;5913if ( types && types.preventDefault && types.handleObj ) {5914
5915// ( event ) dispatched jQuery.Event5916handleObj = types.handleObj;5917jQuery( types.delegateTarget ).off(5918handleObj.namespace ?5919handleObj.origType + "." + handleObj.namespace :5920handleObj.origType,5921handleObj.selector,5922handleObj.handler5923);5924return this;5925}5926if ( typeof types === "object" ) {5927
5928// ( types-object [, selector] )5929for ( type in types ) {5930this.off( type, selector, types[ type ] );5931}5932return this;5933}5934if ( selector === false || typeof selector === "function" ) {5935
5936// ( types [, fn] )5937fn = selector;5938selector = undefined;5939}5940if ( fn === false ) {5941fn = returnFalse;5942}5943return this.each( function() {5944jQuery.event.remove( this, types, fn, selector );5945} );5946}5947} );5948
5949
5950var
5951
5952// Support: IE <=10 - 11, Edge 12 - 13 only5953// In IE/Edge using regex groups here causes severe slowdowns.5954// See https://connect.microsoft.com/IE/feedback/details/1736512/5955rnoInnerhtml = /<script|<style|<link/i,5956
5957// checked="checked" or checked5958rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i,5959rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;5960
5961// Prefer a tbody over its parent table for containing new rows
5962function manipulationTarget( elem, content ) {5963if ( nodeName( elem, "table" ) &&5964nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ) {5965
5966return jQuery( elem ).children( "tbody" )[ 0 ] || elem;5967}5968
5969return elem;5970}
5971
5972// Replace/restore the type attribute of script elements for safe DOM manipulation
5973function disableScript( elem ) {5974elem.type = ( elem.getAttribute( "type" ) !== null ) + "/" + elem.type;5975return elem;5976}
5977function restoreScript( elem ) {5978if ( ( elem.type || "" ).slice( 0, 5 ) === "true/" ) {5979elem.type = elem.type.slice( 5 );5980} else {5981elem.removeAttribute( "type" );5982}5983
5984return elem;5985}
5986
5987function cloneCopyEvent( src, dest ) {5988var i, l, type, pdataOld, udataOld, udataCur, events;5989
5990if ( dest.nodeType !== 1 ) {5991return;5992}5993
5994// 1. Copy private data: events, handlers, etc.5995if ( dataPriv.hasData( src ) ) {5996pdataOld = dataPriv.get( src );5997events = pdataOld.events;5998
5999if ( events ) {6000dataPriv.remove( dest, "handle events" );6001
6002for ( type in events ) {6003for ( i = 0, l = events[ type ].length; i < l; i++ ) {6004jQuery.event.add( dest, type, events[ type ][ i ] );6005}6006}6007}6008}6009
6010// 2. Copy user data6011if ( dataUser.hasData( src ) ) {6012udataOld = dataUser.access( src );6013udataCur = jQuery.extend( {}, udataOld );6014
6015dataUser.set( dest, udataCur );6016}6017}
6018
6019// Fix IE bugs, see support tests
6020function fixInput( src, dest ) {6021var nodeName = dest.nodeName.toLowerCase();6022
6023// Fails to persist the checked state of a cloned checkbox or radio button.6024if ( nodeName === "input" && rcheckableType.test( src.type ) ) {6025dest.checked = src.checked;6026
6027// Fails to return the selected option to the default selected state when cloning options6028} else if ( nodeName === "input" || nodeName === "textarea" ) {6029dest.defaultValue = src.defaultValue;6030}6031}
6032
6033function domManip( collection, args, callback, ignored ) {6034
6035// Flatten any nested arrays6036args = flat( args );6037
6038var fragment, first, scripts, hasScripts, node, doc,6039i = 0,6040l = collection.length,6041iNoClone = l - 1,6042value = args[ 0 ],6043valueIsFunction = isFunction( value );6044
6045// We can't cloneNode fragments that contain checked, in WebKit6046if ( valueIsFunction ||6047( l > 1 && typeof value === "string" &&6048!support.checkClone && rchecked.test( value ) ) ) {6049return collection.each( function( index ) {6050var self = collection.eq( index );6051if ( valueIsFunction ) {6052args[ 0 ] = value.call( this, index, self.html() );6053}6054domManip( self, args, callback, ignored );6055} );6056}6057
6058if ( l ) {6059fragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored );6060first = fragment.firstChild;6061
6062if ( fragment.childNodes.length === 1 ) {6063fragment = first;6064}6065
6066// Require either new content or an interest in ignored elements to invoke the callback6067if ( first || ignored ) {6068scripts = jQuery.map( getAll( fragment, "script" ), disableScript );6069hasScripts = scripts.length;6070
6071// Use the original fragment for the last item6072// instead of the first because it can end up6073// being emptied incorrectly in certain situations (#8070).6074for ( ; i < l; i++ ) {6075node = fragment;6076
6077if ( i !== iNoClone ) {6078node = jQuery.clone( node, true, true );6079
6080// Keep references to cloned scripts for later restoration6081if ( hasScripts ) {6082
6083// Support: Android <=4.0 only, PhantomJS 1 only6084// push.apply(_, arraylike) throws on ancient WebKit6085jQuery.merge( scripts, getAll( node, "script" ) );6086}6087}6088
6089callback.call( collection[ i ], node, i );6090}6091
6092if ( hasScripts ) {6093doc = scripts[ scripts.length - 1 ].ownerDocument;6094
6095// Reenable scripts6096jQuery.map( scripts, restoreScript );6097
6098// Evaluate executable scripts on first document insertion6099for ( i = 0; i < hasScripts; i++ ) {6100node = scripts[ i ];6101if ( rscriptType.test( node.type || "" ) &&6102!dataPriv.access( node, "globalEval" ) &&6103jQuery.contains( doc, node ) ) {6104
6105if ( node.src && ( node.type || "" ).toLowerCase() !== "module" ) {6106
6107// Optional AJAX dependency, but won't run scripts if not present6108if ( jQuery._evalUrl && !node.noModule ) {6109jQuery._evalUrl( node.src, {6110nonce: node.nonce || node.getAttribute( "nonce" )6111}, doc );6112}6113} else {6114DOMEval( node.textContent.replace( rcleanScript, "" ), node, doc );6115}6116}6117}6118}6119}6120}6121
6122return collection;6123}
6124
6125function remove( elem, selector, keepData ) {6126var node,6127nodes = selector ? jQuery.filter( selector, elem ) : elem,6128i = 0;6129
6130for ( ; ( node = nodes[ i ] ) != null; i++ ) {6131if ( !keepData && node.nodeType === 1 ) {6132jQuery.cleanData( getAll( node ) );6133}6134
6135if ( node.parentNode ) {6136if ( keepData && isAttached( node ) ) {6137setGlobalEval( getAll( node, "script" ) );6138}6139node.parentNode.removeChild( node );6140}6141}6142
6143return elem;6144}
6145
6146jQuery.extend( {6147htmlPrefilter: function( html ) {6148return html;6149},6150
6151clone: function( elem, dataAndEvents, deepDataAndEvents ) {6152var i, l, srcElements, destElements,6153clone = elem.cloneNode( true ),6154inPage = isAttached( elem );6155
6156// Fix IE cloning issues6157if ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) &&6158!jQuery.isXMLDoc( elem ) ) {6159
6160// We eschew Sizzle here for performance reasons: https://jsperf.com/getall-vs-sizzle/26161destElements = getAll( clone );6162srcElements = getAll( elem );6163
6164for ( i = 0, l = srcElements.length; i < l; i++ ) {6165fixInput( srcElements[ i ], destElements[ i ] );6166}6167}6168
6169// Copy the events from the original to the clone6170if ( dataAndEvents ) {6171if ( deepDataAndEvents ) {6172srcElements = srcElements || getAll( elem );6173destElements = destElements || getAll( clone );6174
6175for ( i = 0, l = srcElements.length; i < l; i++ ) {6176cloneCopyEvent( srcElements[ i ], destElements[ i ] );6177}6178} else {6179cloneCopyEvent( elem, clone );6180}6181}6182
6183// Preserve script evaluation history6184destElements = getAll( clone, "script" );6185if ( destElements.length > 0 ) {6186setGlobalEval( destElements, !inPage && getAll( elem, "script" ) );6187}6188
6189// Return the cloned set6190return clone;6191},6192
6193cleanData: function( elems ) {6194var data, elem, type,6195special = jQuery.event.special,6196i = 0;6197
6198for ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {6199if ( acceptData( elem ) ) {6200if ( ( data = elem[ dataPriv.expando ] ) ) {6201if ( data.events ) {6202for ( type in data.events ) {6203if ( special[ type ] ) {6204jQuery.event.remove( elem, type );6205
6206// This is a shortcut to avoid jQuery.event.remove's overhead6207} else {6208jQuery.removeEvent( elem, type, data.handle );6209}6210}6211}6212
6213// Support: Chrome <=35 - 45+6214// Assign undefined instead of using delete, see Data#remove6215elem[ dataPriv.expando ] = undefined;6216}6217if ( elem[ dataUser.expando ] ) {6218
6219// Support: Chrome <=35 - 45+6220// Assign undefined instead of using delete, see Data#remove6221elem[ dataUser.expando ] = undefined;6222}6223}6224}6225}6226} );6227
6228jQuery.fn.extend( {6229detach: function( selector ) {6230return remove( this, selector, true );6231},6232
6233remove: function( selector ) {6234return remove( this, selector );6235},6236
6237text: function( value ) {6238return access( this, function( value ) {6239return value === undefined ?6240jQuery.text( this ) :6241this.empty().each( function() {6242if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {6243this.textContent = value;6244}6245} );6246}, null, value, arguments.length );6247},6248
6249append: function() {6250return domManip( this, arguments, function( elem ) {6251if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {6252var target = manipulationTarget( this, elem );6253target.appendChild( elem );6254}6255} );6256},6257
6258prepend: function() {6259return domManip( this, arguments, function( elem ) {6260if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {6261var target = manipulationTarget( this, elem );6262target.insertBefore( elem, target.firstChild );6263}6264} );6265},6266
6267before: function() {6268return domManip( this, arguments, function( elem ) {6269if ( this.parentNode ) {6270this.parentNode.insertBefore( elem, this );6271}6272} );6273},6274
6275after: function() {6276return domManip( this, arguments, function( elem ) {6277if ( this.parentNode ) {6278this.parentNode.insertBefore( elem, this.nextSibling );6279}6280} );6281},6282
6283empty: function() {6284var elem,6285i = 0;6286
6287for ( ; ( elem = this[ i ] ) != null; i++ ) {6288if ( elem.nodeType === 1 ) {6289
6290// Prevent memory leaks6291jQuery.cleanData( getAll( elem, false ) );6292
6293// Remove any remaining nodes6294elem.textContent = "";6295}6296}6297
6298return this;6299},6300
6301clone: function( dataAndEvents, deepDataAndEvents ) {6302dataAndEvents = dataAndEvents == null ? false : dataAndEvents;6303deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;6304
6305return this.map( function() {6306return jQuery.clone( this, dataAndEvents, deepDataAndEvents );6307} );6308},6309
6310html: function( value ) {6311return access( this, function( value ) {6312var elem = this[ 0 ] || {},6313i = 0,6314l = this.length;6315
6316if ( value === undefined && elem.nodeType === 1 ) {6317return elem.innerHTML;6318}6319
6320// See if we can take a shortcut and just use innerHTML6321if ( typeof value === "string" && !rnoInnerhtml.test( value ) &&6322!wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) {6323
6324value = jQuery.htmlPrefilter( value );6325
6326try {6327for ( ; i < l; i++ ) {6328elem = this[ i ] || {};6329
6330// Remove element nodes and prevent memory leaks6331if ( elem.nodeType === 1 ) {6332jQuery.cleanData( getAll( elem, false ) );6333elem.innerHTML = value;6334}6335}6336
6337elem = 0;6338
6339// If using innerHTML throws an exception, use the fallback method6340} catch ( e ) {}6341}6342
6343if ( elem ) {6344this.empty().append( value );6345}6346}, null, value, arguments.length );6347},6348
6349replaceWith: function() {6350var ignored = [];6351
6352// Make the changes, replacing each non-ignored context element with the new content6353return domManip( this, arguments, function( elem ) {6354var parent = this.parentNode;6355
6356if ( jQuery.inArray( this, ignored ) < 0 ) {6357jQuery.cleanData( getAll( this ) );6358if ( parent ) {6359parent.replaceChild( elem, this );6360}6361}6362
6363// Force callback invocation6364}, ignored );6365}6366} );6367
6368jQuery.each( {6369appendTo: "append",6370prependTo: "prepend",6371insertBefore: "before",6372insertAfter: "after",6373replaceAll: "replaceWith"6374}, function( name, original ) {6375jQuery.fn[ name ] = function( selector ) {6376var elems,6377ret = [],6378insert = jQuery( selector ),6379last = insert.length - 1,6380i = 0;6381
6382for ( ; i <= last; i++ ) {6383elems = i === last ? this : this.clone( true );6384jQuery( insert[ i ] )[ original ]( elems );6385
6386// Support: Android <=4.0 only, PhantomJS 1 only6387// .get() because push.apply(_, arraylike) throws on ancient WebKit6388push.apply( ret, elems.get() );6389}6390
6391return this.pushStack( ret );6392};6393} );6394var rnumnonpx = new RegExp( "^(" + pnum + ")(?!px)[a-z%]+$", "i" );6395
6396var getStyles = function( elem ) {6397
6398// Support: IE <=11 only, Firefox <=30 (#15098, #14150)6399// IE throws on elements created in popups6400// FF meanwhile throws on frame elements through "defaultView.getComputedStyle"6401var view = elem.ownerDocument.defaultView;6402
6403if ( !view || !view.opener ) {6404view = window;6405}6406
6407return view.getComputedStyle( elem );6408};6409
6410var swap = function( elem, options, callback ) {6411var ret, name,6412old = {};6413
6414// Remember the old values, and insert the new ones6415for ( name in options ) {6416old[ name ] = elem.style[ name ];6417elem.style[ name ] = options[ name ];6418}6419
6420ret = callback.call( elem );6421
6422// Revert the old values6423for ( name in options ) {6424elem.style[ name ] = old[ name ];6425}6426
6427return ret;6428};6429
6430
6431var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );6432
6433
6434
6435( function() {6436
6437// Executing both pixelPosition & boxSizingReliable tests require only one layout6438// so they're executed at the same time to save the second computation.6439function computeStyleTests() {6440
6441// This is a singleton, we need to execute it only once6442if ( !div ) {6443return;6444}6445
6446container.style.cssText = "position:absolute;left:-11111px;width:60px;" +6447"margin-top:1px;padding:0;border:0";6448div.style.cssText =6449"position:relative;display:block;box-sizing:border-box;overflow:scroll;" +6450"margin:auto;border:1px;padding:1px;" +6451"width:60%;top:1%";6452documentElement.appendChild( container ).appendChild( div );6453
6454var divStyle = window.getComputedStyle( div );6455pixelPositionVal = divStyle.top !== "1%";6456
6457// Support: Android 4.0 - 4.3 only, Firefox <=3 - 446458reliableMarginLeftVal = roundPixelMeasures( divStyle.marginLeft ) === 12;6459
6460// Support: Android 4.0 - 4.3 only, Safari <=9.1 - 10.1, iOS <=7.0 - 9.36461// Some styles come back with percentage values, even though they shouldn't6462div.style.right = "60%";6463pixelBoxStylesVal = roundPixelMeasures( divStyle.right ) === 36;6464
6465// Support: IE 9 - 11 only6466// Detect misreporting of content dimensions for box-sizing:border-box elements6467boxSizingReliableVal = roundPixelMeasures( divStyle.width ) === 36;6468
6469// Support: IE 9 only6470// Detect overflow:scroll screwiness (gh-3699)6471// Support: Chrome <=646472// Don't get tricked when zoom affects offsetWidth (gh-4029)6473div.style.position = "absolute";6474scrollboxSizeVal = roundPixelMeasures( div.offsetWidth / 3 ) === 12;6475
6476documentElement.removeChild( container );6477
6478// Nullify the div so it wouldn't be stored in the memory and6479// it will also be a sign that checks already performed6480div = null;6481}6482
6483function roundPixelMeasures( measure ) {6484return Math.round( parseFloat( measure ) );6485}6486
6487var pixelPositionVal, boxSizingReliableVal, scrollboxSizeVal, pixelBoxStylesVal,6488reliableTrDimensionsVal, reliableMarginLeftVal,6489container = document.createElement( "div" ),6490div = document.createElement( "div" );6491
6492// Finish early in limited (non-browser) environments6493if ( !div.style ) {6494return;6495}6496
6497// Support: IE <=9 - 11 only6498// Style of cloned element affects source element cloned (#8908)6499div.style.backgroundClip = "content-box";6500div.cloneNode( true ).style.backgroundClip = "";6501support.clearCloneStyle = div.style.backgroundClip === "content-box";6502
6503jQuery.extend( support, {6504boxSizingReliable: function() {6505computeStyleTests();6506return boxSizingReliableVal;6507},6508pixelBoxStyles: function() {6509computeStyleTests();6510return pixelBoxStylesVal;6511},6512pixelPosition: function() {6513computeStyleTests();6514return pixelPositionVal;6515},6516reliableMarginLeft: function() {6517computeStyleTests();6518return reliableMarginLeftVal;6519},6520scrollboxSize: function() {6521computeStyleTests();6522return scrollboxSizeVal;6523},6524
6525// Support: IE 9 - 11+, Edge 15 - 18+6526// IE/Edge misreport `getComputedStyle` of table rows with width/height6527// set in CSS while `offset*` properties report correct values.6528// Behavior in IE 9 is more subtle than in newer versions & it passes6529// some versions of this test; make sure not to make it pass there!6530//6531// Support: Firefox 70+6532// Only Firefox includes border widths6533// in computed dimensions. (gh-4529)6534reliableTrDimensions: function() {6535var table, tr, trChild, trStyle;6536if ( reliableTrDimensionsVal == null ) {6537table = document.createElement( "table" );6538tr = document.createElement( "tr" );6539trChild = document.createElement( "div" );6540
6541table.style.cssText = "position:absolute;left:-11111px;border-collapse:separate";6542tr.style.cssText = "border:1px solid";6543
6544// Support: Chrome 86+6545// Height set through cssText does not get applied.6546// Computed height then comes back as 0.6547tr.style.height = "1px";6548trChild.style.height = "9px";6549
6550// Support: Android 8 Chrome 86+6551// In our bodyBackground.html iframe,6552// display for all div elements is set to "inline",6553// which causes a problem only in Android 8 Chrome 86.6554// Ensuring the div is display: block6555// gets around this issue.6556trChild.style.display = "block";6557
6558documentElement
6559.appendChild( table )6560.appendChild( tr )6561.appendChild( trChild );6562
6563trStyle = window.getComputedStyle( tr );6564reliableTrDimensionsVal = ( parseInt( trStyle.height, 10 ) +6565parseInt( trStyle.borderTopWidth, 10 ) +6566parseInt( trStyle.borderBottomWidth, 10 ) ) === tr.offsetHeight;6567
6568documentElement.removeChild( table );6569}6570return reliableTrDimensionsVal;6571}6572} );6573} )();6574
6575
6576function curCSS( elem, name, computed ) {6577var width, minWidth, maxWidth, ret,6578
6579// Support: Firefox 51+6580// Retrieving style before computed somehow6581// fixes an issue with getting wrong values6582// on detached elements6583style = elem.style;6584
6585computed = computed || getStyles( elem );6586
6587// getPropertyValue is needed for:6588// .css('filter') (IE 9 only, #12537)6589// .css('--customProperty) (#3144)6590if ( computed ) {6591ret = computed.getPropertyValue( name ) || computed[ name ];6592
6593if ( ret === "" && !isAttached( elem ) ) {6594ret = jQuery.style( elem, name );6595}6596
6597// A tribute to the "awesome hack by Dean Edwards"6598// Android Browser returns percentage for some values,6599// but width seems to be reliably pixels.6600// This is against the CSSOM draft spec:6601// https://drafts.csswg.org/cssom/#resolved-values6602if ( !support.pixelBoxStyles() && rnumnonpx.test( ret ) && rboxStyle.test( name ) ) {6603
6604// Remember the original values6605width = style.width;6606minWidth = style.minWidth;6607maxWidth = style.maxWidth;6608
6609// Put in the new values to get a computed value out6610style.minWidth = style.maxWidth = style.width = ret;6611ret = computed.width;6612
6613// Revert the changed values6614style.width = width;6615style.minWidth = minWidth;6616style.maxWidth = maxWidth;6617}6618}6619
6620return ret !== undefined ?6621
6622// Support: IE <=9 - 11 only6623// IE returns zIndex value as an integer.6624ret + "" :6625ret;6626}
6627
6628
6629function addGetHookIf( conditionFn, hookFn ) {6630
6631// Define the hook, we'll check on the first run if it's really needed.6632return {6633get: function() {6634if ( conditionFn() ) {6635
6636// Hook not needed (or it's not possible to use it due6637// to missing dependency), remove it.6638delete this.get;6639return;6640}6641
6642// Hook needed; redefine it so that the support test is not executed again.6643return ( this.get = hookFn ).apply( this, arguments );6644}6645};6646}
6647
6648
6649var cssPrefixes = [ "Webkit", "Moz", "ms" ],6650emptyStyle = document.createElement( "div" ).style,6651vendorProps = {};6652
6653// Return a vendor-prefixed property or undefined
6654function vendorPropName( name ) {6655
6656// Check for vendor prefixed names6657var capName = name[ 0 ].toUpperCase() + name.slice( 1 ),6658i = cssPrefixes.length;6659
6660while ( i-- ) {6661name = cssPrefixes[ i ] + capName;6662if ( name in emptyStyle ) {6663return name;6664}6665}6666}
6667
6668// Return a potentially-mapped jQuery.cssProps or vendor prefixed property
6669function finalPropName( name ) {6670var final = jQuery.cssProps[ name ] || vendorProps[ name ];6671
6672if ( final ) {6673return final;6674}6675if ( name in emptyStyle ) {6676return name;6677}6678return vendorProps[ name ] = vendorPropName( name ) || name;6679}
6680
6681
6682var
6683
6684// Swappable if display is none or starts with table6685// except "table", "table-cell", or "table-caption"6686// See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display6687rdisplayswap = /^(none|table(?!-c[ea]).+)/,6688rcustomProp = /^--/,6689cssShow = { position: "absolute", visibility: "hidden", display: "block" },6690cssNormalTransform = {6691letterSpacing: "0",6692fontWeight: "400"6693};6694
6695function setPositiveNumber( _elem, value, subtract ) {6696
6697// Any relative (+/-) values have already been6698// normalized at this point6699var matches = rcssNum.exec( value );6700return matches ?6701
6702// Guard against undefined "subtract", e.g., when used as in cssHooks6703Math.max( 0, matches[ 2 ] - ( subtract || 0 ) ) + ( matches[ 3 ] || "px" ) :6704value;6705}
6706
6707function boxModelAdjustment( elem, dimension, box, isBorderBox, styles, computedVal ) {6708var i = dimension === "width" ? 1 : 0,6709extra = 0,6710delta = 0;6711
6712// Adjustment may not be necessary6713if ( box === ( isBorderBox ? "border" : "content" ) ) {6714return 0;6715}6716
6717for ( ; i < 4; i += 2 ) {6718
6719// Both box models exclude margin6720if ( box === "margin" ) {6721delta += jQuery.css( elem, box + cssExpand[ i ], true, styles );6722}6723
6724// If we get here with a content-box, we're seeking "padding" or "border" or "margin"6725if ( !isBorderBox ) {6726
6727// Add padding6728delta += jQuery.css( elem, "padding" + cssExpand[ i ], true, styles );6729
6730// For "border" or "margin", add border6731if ( box !== "padding" ) {6732delta += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles );6733
6734// But still keep track of it otherwise6735} else {6736extra += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles );6737}6738
6739// If we get here with a border-box (content + padding + border), we're seeking "content" or6740// "padding" or "margin"6741} else {6742
6743// For "content", subtract padding6744if ( box === "content" ) {6745delta -= jQuery.css( elem, "padding" + cssExpand[ i ], true, styles );6746}6747
6748// For "content" or "padding", subtract border6749if ( box !== "margin" ) {6750delta -= jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles );6751}6752}6753}6754
6755// Account for positive content-box scroll gutter when requested by providing computedVal6756if ( !isBorderBox && computedVal >= 0 ) {6757
6758// offsetWidth/offsetHeight is a rounded sum of content, padding, scroll gutter, and border6759// Assuming integer scroll gutter, subtract the rest and round down6760delta += Math.max( 0, Math.ceil(6761elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] -6762computedVal -6763delta -6764extra -67650.56766
6767// If offsetWidth/offsetHeight is unknown, then we can't determine content-box scroll gutter6768// Use an explicit zero to avoid NaN (gh-3964)6769) ) || 0;6770}6771
6772return delta;6773}
6774
6775function getWidthOrHeight( elem, dimension, extra ) {6776
6777// Start with computed style6778var styles = getStyles( elem ),6779
6780// To avoid forcing a reflow, only fetch boxSizing if we need it (gh-4322).6781// Fake content-box until we know it's needed to know the true value.6782boxSizingNeeded = !support.boxSizingReliable() || extra,6783isBorderBox = boxSizingNeeded &&6784jQuery.css( elem, "boxSizing", false, styles ) === "border-box",6785valueIsBorderBox = isBorderBox,6786
6787val = curCSS( elem, dimension, styles ),6788offsetProp = "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 );6789
6790// Support: Firefox <=546791// Return a confounding non-pixel value or feign ignorance, as appropriate.6792if ( rnumnonpx.test( val ) ) {6793if ( !extra ) {6794return val;6795}6796val = "auto";6797}6798
6799
6800// Support: IE 9 - 11 only6801// Use offsetWidth/offsetHeight for when box sizing is unreliable.6802// In those cases, the computed value can be trusted to be border-box.6803if ( ( !support.boxSizingReliable() && isBorderBox ||6804
6805// Support: IE 10 - 11+, Edge 15 - 18+6806// IE/Edge misreport `getComputedStyle` of table rows with width/height6807// set in CSS while `offset*` properties report correct values.6808// Interestingly, in some cases IE 9 doesn't suffer from this issue.6809!support.reliableTrDimensions() && nodeName( elem, "tr" ) ||6810
6811// Fall back to offsetWidth/offsetHeight when value is "auto"6812// This happens for inline elements with no explicit setting (gh-3571)6813val === "auto" ||6814
6815// Support: Android <=4.1 - 4.3 only6816// Also use offsetWidth/offsetHeight for misreported inline dimensions (gh-3602)6817!parseFloat( val ) && jQuery.css( elem, "display", false, styles ) === "inline" ) &&6818
6819// Make sure the element is visible & connected6820elem.getClientRects().length ) {6821
6822isBorderBox = jQuery.css( elem, "boxSizing", false, styles ) === "border-box";6823
6824// Where available, offsetWidth/offsetHeight approximate border box dimensions.6825// Where not available (e.g., SVG), assume unreliable box-sizing and interpret the6826// retrieved value as a content box dimension.6827valueIsBorderBox = offsetProp in elem;6828if ( valueIsBorderBox ) {6829val = elem[ offsetProp ];6830}6831}6832
6833// Normalize "" and auto6834val = parseFloat( val ) || 0;6835
6836// Adjust for the element's box model6837return ( val +6838boxModelAdjustment(6839elem,6840dimension,6841extra || ( isBorderBox ? "border" : "content" ),6842valueIsBorderBox,6843styles,6844
6845// Provide the current computed size to request scroll gutter calculation (gh-3589)6846val
6847)6848) + "px";6849}
6850
6851jQuery.extend( {6852
6853// Add in style property hooks for overriding the default6854// behavior of getting and setting a style property6855cssHooks: {6856opacity: {6857get: function( elem, computed ) {6858if ( computed ) {6859
6860// We should always get a number back from opacity6861var ret = curCSS( elem, "opacity" );6862return ret === "" ? "1" : ret;6863}6864}6865}6866},6867
6868// Don't automatically add "px" to these possibly-unitless properties6869cssNumber: {6870"animationIterationCount": true,6871"columnCount": true,6872"fillOpacity": true,6873"flexGrow": true,6874"flexShrink": true,6875"fontWeight": true,6876"gridArea": true,6877"gridColumn": true,6878"gridColumnEnd": true,6879"gridColumnStart": true,6880"gridRow": true,6881"gridRowEnd": true,6882"gridRowStart": true,6883"lineHeight": true,6884"opacity": true,6885"order": true,6886"orphans": true,6887"widows": true,6888"zIndex": true,6889"zoom": true6890},6891
6892// Add in properties whose names you wish to fix before6893// setting or getting the value6894cssProps: {},6895
6896// Get and set the style property on a DOM Node6897style: function( elem, name, value, extra ) {6898
6899// Don't set styles on text and comment nodes6900if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) {6901return;6902}6903
6904// Make sure that we're working with the right name6905var ret, type, hooks,6906origName = camelCase( name ),6907isCustomProp = rcustomProp.test( name ),6908style = elem.style;6909
6910// Make sure that we're working with the right name. We don't6911// want to query the value if it is a CSS custom property6912// since they are user-defined.6913if ( !isCustomProp ) {6914name = finalPropName( origName );6915}6916
6917// Gets hook for the prefixed version, then unprefixed version6918hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];6919
6920// Check if we're setting a value6921if ( value !== undefined ) {6922type = typeof value;6923
6924// Convert "+=" or "-=" to relative numbers (#7345)6925if ( type === "string" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) {6926value = adjustCSS( elem, name, ret );6927
6928// Fixes bug #92376929type = "number";6930}6931
6932// Make sure that null and NaN values aren't set (#7116)6933if ( value == null || value !== value ) {6934return;6935}6936
6937// If a number was passed in, add the unit (except for certain CSS properties)6938// The isCustomProp check can be removed in jQuery 4.0 when we only auto-append6939// "px" to a few hardcoded values.6940if ( type === "number" && !isCustomProp ) {6941value += ret && ret[ 3 ] || ( jQuery.cssNumber[ origName ] ? "" : "px" );6942}6943
6944// background-* props affect original clone's values6945if ( !support.clearCloneStyle && value === "" && name.indexOf( "background" ) === 0 ) {6946style[ name ] = "inherit";6947}6948
6949// If a hook was provided, use that value, otherwise just set the specified value6950if ( !hooks || !( "set" in hooks ) ||6951( value = hooks.set( elem, value, extra ) ) !== undefined ) {6952
6953if ( isCustomProp ) {6954style.setProperty( name, value );6955} else {6956style[ name ] = value;6957}6958}6959
6960} else {6961
6962// If a hook was provided get the non-computed value from there6963if ( hooks && "get" in hooks &&6964( ret = hooks.get( elem, false, extra ) ) !== undefined ) {6965
6966return ret;6967}6968
6969// Otherwise just get the value from the style object6970return style[ name ];6971}6972},6973
6974css: function( elem, name, extra, styles ) {6975var val, num, hooks,6976origName = camelCase( name ),6977isCustomProp = rcustomProp.test( name );6978
6979// Make sure that we're working with the right name. We don't6980// want to modify the value if it is a CSS custom property6981// since they are user-defined.6982if ( !isCustomProp ) {6983name = finalPropName( origName );6984}6985
6986// Try prefixed name followed by the unprefixed name6987hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];6988
6989// If a hook was provided get the computed value from there6990if ( hooks && "get" in hooks ) {6991val = hooks.get( elem, true, extra );6992}6993
6994// Otherwise, if a way to get the computed value exists, use that6995if ( val === undefined ) {6996val = curCSS( elem, name, styles );6997}6998
6999// Convert "normal" to computed value7000if ( val === "normal" && name in cssNormalTransform ) {7001val = cssNormalTransform[ name ];7002}7003
7004// Make numeric if forced or a qualifier was provided and val looks numeric7005if ( extra === "" || extra ) {7006num = parseFloat( val );7007return extra === true || isFinite( num ) ? num || 0 : val;7008}7009
7010return val;7011}7012} );7013
7014jQuery.each( [ "height", "width" ], function( _i, dimension ) {7015jQuery.cssHooks[ dimension ] = {7016get: function( elem, computed, extra ) {7017if ( computed ) {7018
7019// Certain elements can have dimension info if we invisibly show them7020// but it must have a current display style that would benefit7021return rdisplayswap.test( jQuery.css( elem, "display" ) ) &&7022
7023// Support: Safari 8+7024// Table columns in Safari have non-zero offsetWidth & zero7025// getBoundingClientRect().width unless display is changed.7026// Support: IE <=11 only7027// Running getBoundingClientRect on a disconnected node7028// in IE throws an error.7029( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ?7030swap( elem, cssShow, function() {7031return getWidthOrHeight( elem, dimension, extra );7032} ) :7033getWidthOrHeight( elem, dimension, extra );7034}7035},7036
7037set: function( elem, value, extra ) {7038var matches,7039styles = getStyles( elem ),7040
7041// Only read styles.position if the test has a chance to fail7042// to avoid forcing a reflow.7043scrollboxSizeBuggy = !support.scrollboxSize() &&7044styles.position === "absolute",7045
7046// To avoid forcing a reflow, only fetch boxSizing if we need it (gh-3991)7047boxSizingNeeded = scrollboxSizeBuggy || extra,7048isBorderBox = boxSizingNeeded &&7049jQuery.css( elem, "boxSizing", false, styles ) === "border-box",7050subtract = extra ?7051boxModelAdjustment(7052elem,7053dimension,7054extra,7055isBorderBox,7056styles
7057) :70580;7059
7060// Account for unreliable border-box dimensions by comparing offset* to computed and7061// faking a content-box to get border and padding (gh-3699)7062if ( isBorderBox && scrollboxSizeBuggy ) {7063subtract -= Math.ceil(7064elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] -7065parseFloat( styles[ dimension ] ) -7066boxModelAdjustment( elem, dimension, "border", false, styles ) -70670.57068);7069}7070
7071// Convert to pixels if value adjustment is needed7072if ( subtract && ( matches = rcssNum.exec( value ) ) &&7073( matches[ 3 ] || "px" ) !== "px" ) {7074
7075elem.style[ dimension ] = value;7076value = jQuery.css( elem, dimension );7077}7078
7079return setPositiveNumber( elem, value, subtract );7080}7081};7082} );7083
7084jQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,7085function( elem, computed ) {7086if ( computed ) {7087return ( parseFloat( curCSS( elem, "marginLeft" ) ) ||7088elem.getBoundingClientRect().left -7089swap( elem, { marginLeft: 0 }, function() {7090return elem.getBoundingClientRect().left;7091} )7092) + "px";7093}7094}7095);7096
7097// These hooks are used by animate to expand properties
7098jQuery.each( {7099margin: "",7100padding: "",7101border: "Width"7102}, function( prefix, suffix ) {7103jQuery.cssHooks[ prefix + suffix ] = {7104expand: function( value ) {7105var i = 0,7106expanded = {},7107
7108// Assumes a single number if not a string7109parts = typeof value === "string" ? value.split( " " ) : [ value ];7110
7111for ( ; i < 4; i++ ) {7112expanded[ prefix + cssExpand[ i ] + suffix ] =7113parts[ i ] || parts[ i - 2 ] || parts[ 0 ];7114}7115
7116return expanded;7117}7118};7119
7120if ( prefix !== "margin" ) {7121jQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber;7122}7123} );7124
7125jQuery.fn.extend( {7126css: function( name, value ) {7127return access( this, function( elem, name, value ) {7128var styles, len,7129map = {},7130i = 0;7131
7132if ( Array.isArray( name ) ) {7133styles = getStyles( elem );7134len = name.length;7135
7136for ( ; i < len; i++ ) {7137map[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles );7138}7139
7140return map;7141}7142
7143return value !== undefined ?7144jQuery.style( elem, name, value ) :7145jQuery.css( elem, name );7146}, name, value, arguments.length > 1 );7147}7148} );7149
7150
7151// Based off of the plugin by Clint Helfers, with permission.
7152// https://web.archive.org/web/20100324014747/http://blindsignals.com/index.php/2009/07/jquery-delay/
7153jQuery.fn.delay = function( time, type ) {7154time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time;7155type = type || "fx";7156
7157return this.queue( type, function( next, hooks ) {7158var timeout = window.setTimeout( next, time );7159hooks.stop = function() {7160window.clearTimeout( timeout );7161};7162} );7163};7164
7165
7166( function() {7167var input = document.createElement( "input" ),7168select = document.createElement( "select" ),7169opt = select.appendChild( document.createElement( "option" ) );7170
7171input.type = "checkbox";7172
7173// Support: Android <=4.3 only7174// Default value for a checkbox should be "on"7175support.checkOn = input.value !== "";7176
7177// Support: IE <=11 only7178// Must access selectedIndex to make default options select7179support.optSelected = opt.selected;7180
7181// Support: IE <=11 only7182// An input loses its value after becoming a radio7183input = document.createElement( "input" );7184input.value = "t";7185input.type = "radio";7186support.radioValue = input.value === "t";7187} )();7188
7189
7190var boolHook,7191attrHandle = jQuery.expr.attrHandle;7192
7193jQuery.fn.extend( {7194attr: function( name, value ) {7195return access( this, jQuery.attr, name, value, arguments.length > 1 );7196},7197
7198removeAttr: function( name ) {7199return this.each( function() {7200jQuery.removeAttr( this, name );7201} );7202}7203} );7204
7205jQuery.extend( {7206attr: function( elem, name, value ) {7207var ret, hooks,7208nType = elem.nodeType;7209
7210// Don't get/set attributes on text, comment and attribute nodes7211if ( nType === 3 || nType === 8 || nType === 2 ) {7212return;7213}7214
7215// Fallback to prop when attributes are not supported7216if ( typeof elem.getAttribute === "undefined" ) {7217return jQuery.prop( elem, name, value );7218}7219
7220// Attribute hooks are determined by the lowercase version7221// Grab necessary hook if one is defined7222if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {7223hooks = jQuery.attrHooks[ name.toLowerCase() ] ||7224( jQuery.expr.match.bool.test( name ) ? boolHook : undefined );7225}7226
7227if ( value !== undefined ) {7228if ( value === null ) {7229jQuery.removeAttr( elem, name );7230return;7231}7232
7233if ( hooks && "set" in hooks &&7234( ret = hooks.set( elem, value, name ) ) !== undefined ) {7235return ret;7236}7237
7238elem.setAttribute( name, value + "" );7239return value;7240}7241
7242if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {7243return ret;7244}7245
7246ret = jQuery.find.attr( elem, name );7247
7248// Non-existent attributes return null, we normalize to undefined7249return ret == null ? undefined : ret;7250},7251
7252attrHooks: {7253type: {7254set: function( elem, value ) {7255if ( !support.radioValue && value === "radio" &&7256nodeName( elem, "input" ) ) {7257var val = elem.value;7258elem.setAttribute( "type", value );7259if ( val ) {7260elem.value = val;7261}7262return value;7263}7264}7265}7266},7267
7268removeAttr: function( elem, value ) {7269var name,7270i = 0,7271
7272// Attribute names can contain non-HTML whitespace characters7273// https://html.spec.whatwg.org/multipage/syntax.html#attributes-27274attrNames = value && value.match( rnothtmlwhite );7275
7276if ( attrNames && elem.nodeType === 1 ) {7277while ( ( name = attrNames[ i++ ] ) ) {7278elem.removeAttribute( name );7279}7280}7281}7282} );7283
7284// Hooks for boolean attributes
7285boolHook = {7286set: function( elem, value, name ) {7287if ( value === false ) {7288
7289// Remove boolean attributes when set to false7290jQuery.removeAttr( elem, name );7291} else {7292elem.setAttribute( name, name );7293}7294return name;7295}7296};7297
7298jQuery.each( jQuery.expr.match.bool.source.match( /\w+/g ), function( _i, name ) {7299var getter = attrHandle[ name ] || jQuery.find.attr;7300
7301attrHandle[ name ] = function( elem, name, isXML ) {7302var ret, handle,7303lowercaseName = name.toLowerCase();7304
7305if ( !isXML ) {7306
7307// Avoid an infinite loop by temporarily removing this function from the getter7308handle = attrHandle[ lowercaseName ];7309attrHandle[ lowercaseName ] = ret;7310ret = getter( elem, name, isXML ) != null ?7311lowercaseName :7312null;7313attrHandle[ lowercaseName ] = handle;7314}7315return ret;7316};7317} );7318
7319
7320
7321
7322var rfocusable = /^(?:input|select|textarea|button)$/i,7323rclickable = /^(?:a|area)$/i;7324
7325jQuery.fn.extend( {7326prop: function( name, value ) {7327return access( this, jQuery.prop, name, value, arguments.length > 1 );7328},7329
7330removeProp: function( name ) {7331return this.each( function() {7332delete this[ jQuery.propFix[ name ] || name ];7333} );7334}7335} );7336
7337jQuery.extend( {7338prop: function( elem, name, value ) {7339var ret, hooks,7340nType = elem.nodeType;7341
7342// Don't get/set properties on text, comment and attribute nodes7343if ( nType === 3 || nType === 8 || nType === 2 ) {7344return;7345}7346
7347if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {7348
7349// Fix name and attach hooks7350name = jQuery.propFix[ name ] || name;7351hooks = jQuery.propHooks[ name ];7352}7353
7354if ( value !== undefined ) {7355if ( hooks && "set" in hooks &&7356( ret = hooks.set( elem, value, name ) ) !== undefined ) {7357return ret;7358}7359
7360return ( elem[ name ] = value );7361}7362
7363if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {7364return ret;7365}7366
7367return elem[ name ];7368},7369
7370propHooks: {7371tabIndex: {7372get: function( elem ) {7373
7374// Support: IE <=9 - 11 only7375// elem.tabIndex doesn't always return the7376// correct value when it hasn't been explicitly set7377// https://web.archive.org/web/20141116233347/http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/7378// Use proper attribute retrieval(#12072)7379var tabindex = jQuery.find.attr( elem, "tabindex" );7380
7381if ( tabindex ) {7382return parseInt( tabindex, 10 );7383}7384
7385if (7386rfocusable.test( elem.nodeName ) ||7387rclickable.test( elem.nodeName ) &&7388elem.href7389) {7390return 0;7391}7392
7393return -1;7394}7395}7396},7397
7398propFix: {7399"for": "htmlFor",7400"class": "className"7401}7402} );7403
7404// Support: IE <=11 only
7405// Accessing the selectedIndex property
7406// forces the browser to respect setting selected
7407// on the option
7408// The getter ensures a default option is selected
7409// when in an optgroup
7410// eslint rule "no-unused-expressions" is disabled for this code
7411// since it considers such accessions noop
7412if ( !support.optSelected ) {7413jQuery.propHooks.selected = {7414get: function( elem ) {7415
7416/* eslint no-unused-expressions: "off" */7417
7418var parent = elem.parentNode;7419if ( parent && parent.parentNode ) {7420parent.parentNode.selectedIndex;7421}7422return null;7423},7424set: function( elem ) {7425
7426/* eslint no-unused-expressions: "off" */7427
7428var parent = elem.parentNode;7429if ( parent ) {7430parent.selectedIndex;7431
7432if ( parent.parentNode ) {7433parent.parentNode.selectedIndex;7434}7435}7436}7437};7438}
7439
7440jQuery.each( [7441"tabIndex",7442"readOnly",7443"maxLength",7444"cellSpacing",7445"cellPadding",7446"rowSpan",7447"colSpan",7448"useMap",7449"frameBorder",7450"contentEditable"7451], function() {7452jQuery.propFix[ this.toLowerCase() ] = this;7453} );7454
7455
7456
7457
7458// Strip and collapse whitespace according to HTML spec7459// https://infra.spec.whatwg.org/#strip-and-collapse-ascii-whitespace7460function stripAndCollapse( value ) {7461var tokens = value.match( rnothtmlwhite ) || [];7462return tokens.join( " " );7463}7464
7465
7466function getClass( elem ) {7467return elem.getAttribute && elem.getAttribute( "class" ) || "";7468}
7469
7470function classesToArray( value ) {7471if ( Array.isArray( value ) ) {7472return value;7473}7474if ( typeof value === "string" ) {7475return value.match( rnothtmlwhite ) || [];7476}7477return [];7478}
7479
7480jQuery.fn.extend( {7481addClass: function( value ) {7482var classes, elem, cur, curValue, clazz, j, finalValue,7483i = 0;7484
7485if ( isFunction( value ) ) {7486return this.each( function( j ) {7487jQuery( this ).addClass( value.call( this, j, getClass( this ) ) );7488} );7489}7490
7491classes = classesToArray( value );7492
7493if ( classes.length ) {7494while ( ( elem = this[ i++ ] ) ) {7495curValue = getClass( elem );7496cur = elem.nodeType === 1 && ( " " + stripAndCollapse( curValue ) + " " );7497
7498if ( cur ) {7499j = 0;7500while ( ( clazz = classes[ j++ ] ) ) {7501if ( cur.indexOf( " " + clazz + " " ) < 0 ) {7502cur += clazz + " ";7503}7504}7505
7506// Only assign if different to avoid unneeded rendering.7507finalValue = stripAndCollapse( cur );7508if ( curValue !== finalValue ) {7509elem.setAttribute( "class", finalValue );7510}7511}7512}7513}7514
7515return this;7516},7517
7518removeClass: function( value ) {7519var classes, elem, cur, curValue, clazz, j, finalValue,7520i = 0;7521
7522if ( isFunction( value ) ) {7523return this.each( function( j ) {7524jQuery( this ).removeClass( value.call( this, j, getClass( this ) ) );7525} );7526}7527
7528if ( !arguments.length ) {7529return this.attr( "class", "" );7530}7531
7532classes = classesToArray( value );7533
7534if ( classes.length ) {7535while ( ( elem = this[ i++ ] ) ) {7536curValue = getClass( elem );7537
7538// This expression is here for better compressibility (see addClass)7539cur = elem.nodeType === 1 && ( " " + stripAndCollapse( curValue ) + " " );7540
7541if ( cur ) {7542j = 0;7543while ( ( clazz = classes[ j++ ] ) ) {7544
7545// Remove *all* instances7546while ( cur.indexOf( " " + clazz + " " ) > -1 ) {7547cur = cur.replace( " " + clazz + " ", " " );7548}7549}7550
7551// Only assign if different to avoid unneeded rendering.7552finalValue = stripAndCollapse( cur );7553if ( curValue !== finalValue ) {7554elem.setAttribute( "class", finalValue );7555}7556}7557}7558}7559
7560return this;7561},7562
7563toggleClass: function( value, stateVal ) {7564var type = typeof value,7565isValidValue = type === "string" || Array.isArray( value );7566
7567if ( typeof stateVal === "boolean" && isValidValue ) {7568return stateVal ? this.addClass( value ) : this.removeClass( value );7569}7570
7571if ( isFunction( value ) ) {7572return this.each( function( i ) {7573jQuery( this ).toggleClass(7574value.call( this, i, getClass( this ), stateVal ),7575stateVal
7576);7577} );7578}7579
7580return this.each( function() {7581var className, i, self, classNames;7582
7583if ( isValidValue ) {7584
7585// Toggle individual class names7586i = 0;7587self = jQuery( this );7588classNames = classesToArray( value );7589
7590while ( ( className = classNames[ i++ ] ) ) {7591
7592// Check each className given, space separated list7593if ( self.hasClass( className ) ) {7594self.removeClass( className );7595} else {7596self.addClass( className );7597}7598}7599
7600// Toggle whole class name7601} else if ( value === undefined || type === "boolean" ) {7602className = getClass( this );7603if ( className ) {7604
7605// Store className if set7606dataPriv.set( this, "__className__", className );7607}7608
7609// If the element has a class name or if we're passed `false`,7610// then remove the whole classname (if there was one, the above saved it).7611// Otherwise bring back whatever was previously saved (if anything),7612// falling back to the empty string if nothing was stored.7613if ( this.setAttribute ) {7614this.setAttribute( "class",7615className || value === false ?7616"" :7617dataPriv.get( this, "__className__" ) || ""7618);7619}7620}7621} );7622},7623
7624hasClass: function( selector ) {7625var className, elem,7626i = 0;7627
7628className = " " + selector + " ";7629while ( ( elem = this[ i++ ] ) ) {7630if ( elem.nodeType === 1 &&7631( " " + stripAndCollapse( getClass( elem ) ) + " " ).indexOf( className ) > -1 ) {7632return true;7633}7634}7635
7636return false;7637}7638} );7639
7640
7641
7642
7643var rreturn = /\r/g;7644
7645jQuery.fn.extend( {7646val: function( value ) {7647var hooks, ret, valueIsFunction,7648elem = this[ 0 ];7649
7650if ( !arguments.length ) {7651if ( elem ) {7652hooks = jQuery.valHooks[ elem.type ] ||7653jQuery.valHooks[ elem.nodeName.toLowerCase() ];7654
7655if ( hooks &&7656"get" in hooks &&7657( ret = hooks.get( elem, "value" ) ) !== undefined7658) {7659return ret;7660}7661
7662ret = elem.value;7663
7664// Handle most common string cases7665if ( typeof ret === "string" ) {7666return ret.replace( rreturn, "" );7667}7668
7669// Handle cases where value is null/undef or number7670return ret == null ? "" : ret;7671}7672
7673return;7674}7675
7676valueIsFunction = isFunction( value );7677
7678return this.each( function( i ) {7679var val;7680
7681if ( this.nodeType !== 1 ) {7682return;7683}7684
7685if ( valueIsFunction ) {7686val = value.call( this, i, jQuery( this ).val() );7687} else {7688val = value;7689}7690
7691// Treat null/undefined as ""; convert numbers to string7692if ( val == null ) {7693val = "";7694
7695} else if ( typeof val === "number" ) {7696val += "";7697
7698} else if ( Array.isArray( val ) ) {7699val = jQuery.map( val, function( value ) {7700return value == null ? "" : value + "";7701} );7702}7703
7704hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ];7705
7706// If set returns undefined, fall back to normal setting7707if ( !hooks || !( "set" in hooks ) || hooks.set( this, val, "value" ) === undefined ) {7708this.value = val;7709}7710} );7711}7712} );7713
7714jQuery.extend( {7715valHooks: {7716option: {7717get: function( elem ) {7718
7719var val = jQuery.find.attr( elem, "value" );7720return val != null ?7721val :7722
7723// Support: IE <=10 - 11 only7724// option.text throws exceptions (#14686, #14858)7725// Strip and collapse whitespace7726// https://html.spec.whatwg.org/#strip-and-collapse-whitespace7727stripAndCollapse( jQuery.text( elem ) );7728}7729},7730select: {7731get: function( elem ) {7732var value, option, i,7733options = elem.options,7734index = elem.selectedIndex,7735one = elem.type === "select-one",7736values = one ? null : [],7737max = one ? index + 1 : options.length;7738
7739if ( index < 0 ) {7740i = max;7741
7742} else {7743i = one ? index : 0;7744}7745
7746// Loop through all the selected options7747for ( ; i < max; i++ ) {7748option = options[ i ];7749
7750// Support: IE <=9 only7751// IE8-9 doesn't update selected after form reset (#2551)7752if ( ( option.selected || i === index ) &&7753
7754// Don't return options that are disabled or in a disabled optgroup7755!option.disabled &&7756( !option.parentNode.disabled ||7757!nodeName( option.parentNode, "optgroup" ) ) ) {7758
7759// Get the specific value for the option7760value = jQuery( option ).val();7761
7762// We don't need an array for one selects7763if ( one ) {7764return value;7765}7766
7767// Multi-Selects return an array7768values.push( value );7769}7770}7771
7772return values;7773},7774
7775set: function( elem, value ) {7776var optionSet, option,7777options = elem.options,7778values = jQuery.makeArray( value ),7779i = options.length;7780
7781while ( i-- ) {7782option = options[ i ];7783
7784/* eslint-disable no-cond-assign */7785
7786if ( option.selected =7787jQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -17788) {7789optionSet = true;7790}7791
7792/* eslint-enable no-cond-assign */7793}7794
7795// Force browsers to behave consistently when non-matching value is set7796if ( !optionSet ) {7797elem.selectedIndex = -1;7798}7799return values;7800}7801}7802}7803} );7804
7805// Radios and checkboxes getter/setter
7806jQuery.each( [ "radio", "checkbox" ], function() {7807jQuery.valHooks[ this ] = {7808set: function( elem, value ) {7809if ( Array.isArray( value ) ) {7810return ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 );7811}7812}7813};7814if ( !support.checkOn ) {7815jQuery.valHooks[ this ].get = function( elem ) {7816return elem.getAttribute( "value" ) === null ? "on" : elem.value;7817};7818}7819} );7820
7821
7822
7823
7824// Return jQuery for attributes-only inclusion
7825
7826
7827support.focusin = "onfocusin" in window;7828
7829
7830var rfocusMorph = /^(?:focusinfocus|focusoutblur)$/,7831stopPropagationCallback = function( e ) {7832e.stopPropagation();7833};7834
7835jQuery.extend( jQuery.event, {7836
7837trigger: function( event, data, elem, onlyHandlers ) {7838
7839var i, cur, tmp, bubbleType, ontype, handle, special, lastElement,7840eventPath = [ elem || document ],7841type = hasOwn.call( event, "type" ) ? event.type : event,7842namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split( "." ) : [];7843
7844cur = lastElement = tmp = elem = elem || document;7845
7846// Don't do events on text and comment nodes7847if ( elem.nodeType === 3 || elem.nodeType === 8 ) {7848return;7849}7850
7851// focus/blur morphs to focusin/out; ensure we're not firing them right now7852if ( rfocusMorph.test( type + jQuery.event.triggered ) ) {7853return;7854}7855
7856if ( type.indexOf( "." ) > -1 ) {7857
7858// Namespaced trigger; create a regexp to match event type in handle()7859namespaces = type.split( "." );7860type = namespaces.shift();7861namespaces.sort();7862}7863ontype = type.indexOf( ":" ) < 0 && "on" + type;7864
7865// Caller can pass in a jQuery.Event object, Object, or just an event type string7866event = event[ jQuery.expando ] ?7867event :7868new jQuery.Event( type, typeof event === "object" && event );7869
7870// Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true)7871event.isTrigger = onlyHandlers ? 2 : 3;7872event.namespace = namespaces.join( "." );7873event.rnamespace = event.namespace ?7874new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" ) :7875null;7876
7877// Clean up the event in case it is being reused7878event.result = undefined;7879if ( !event.target ) {7880event.target = elem;7881}7882
7883// Clone any incoming data and prepend the event, creating the handler arg list7884data = data == null ?7885[ event ] :7886jQuery.makeArray( data, [ event ] );7887
7888// Allow special events to draw outside the lines7889special = jQuery.event.special[ type ] || {};7890if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) {7891return;7892}7893
7894// Determine event propagation path in advance, per W3C events spec (#9951)7895// Bubble up to document, then to window; watch for a global ownerDocument var (#9724)7896if ( !onlyHandlers && !special.noBubble && !isWindow( elem ) ) {7897
7898bubbleType = special.delegateType || type;7899if ( !rfocusMorph.test( bubbleType + type ) ) {7900cur = cur.parentNode;7901}7902for ( ; cur; cur = cur.parentNode ) {7903eventPath.push( cur );7904tmp = cur;7905}7906
7907// Only add window if we got to document (e.g., not plain obj or detached DOM)7908if ( tmp === ( elem.ownerDocument || document ) ) {7909eventPath.push( tmp.defaultView || tmp.parentWindow || window );7910}7911}7912
7913// Fire handlers on the event path7914i = 0;7915while ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) {7916lastElement = cur;7917event.type = i > 1 ?7918bubbleType :7919special.bindType || type;7920
7921// jQuery handler7922handle = ( dataPriv.get( cur, "events" ) || Object.create( null ) )[ event.type ] &&7923dataPriv.get( cur, "handle" );7924if ( handle ) {7925handle.apply( cur, data );7926}7927
7928// Native handler7929handle = ontype && cur[ ontype ];7930if ( handle && handle.apply && acceptData( cur ) ) {7931event.result = handle.apply( cur, data );7932if ( event.result === false ) {7933event.preventDefault();7934}7935}7936}7937event.type = type;7938
7939// If nobody prevented the default action, do it now7940if ( !onlyHandlers && !event.isDefaultPrevented() ) {7941
7942if ( ( !special._default ||7943special._default.apply( eventPath.pop(), data ) === false ) &&7944acceptData( elem ) ) {7945
7946// Call a native DOM method on the target with the same name as the event.7947// Don't do default actions on window, that's where global variables be (#6170)7948if ( ontype && isFunction( elem[ type ] ) && !isWindow( elem ) ) {7949
7950// Don't re-trigger an onFOO event when we call its FOO() method7951tmp = elem[ ontype ];7952
7953if ( tmp ) {7954elem[ ontype ] = null;7955}7956
7957// Prevent re-triggering of the same event, since we already bubbled it above7958jQuery.event.triggered = type;7959
7960if ( event.isPropagationStopped() ) {7961lastElement.addEventListener( type, stopPropagationCallback );7962}7963
7964elem[ type ]();7965
7966if ( event.isPropagationStopped() ) {7967lastElement.removeEventListener( type, stopPropagationCallback );7968}7969
7970jQuery.event.triggered = undefined;7971
7972if ( tmp ) {7973elem[ ontype ] = tmp;7974}7975}7976}7977}7978
7979return event.result;7980},7981
7982// Piggyback on a donor event to simulate a different one7983// Used only for `focus(in | out)` events7984simulate: function( type, elem, event ) {7985var e = jQuery.extend(7986new jQuery.Event(),7987event,7988{7989type: type,7990isSimulated: true7991}7992);7993
7994jQuery.event.trigger( e, null, elem );7995}7996
7997} );7998
7999jQuery.fn.extend( {8000
8001trigger: function( type, data ) {8002return this.each( function() {8003jQuery.event.trigger( type, data, this );8004} );8005},8006triggerHandler: function( type, data ) {8007var elem = this[ 0 ];8008if ( elem ) {8009return jQuery.event.trigger( type, data, elem, true );8010}8011}8012} );8013
8014
8015// Support: Firefox <=44
8016// Firefox doesn't have focus(in | out) events
8017// Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787
8018//
8019// Support: Chrome <=48 - 49, Safari <=9.0 - 9.1
8020// focus(in | out) events fire after focus & blur events,
8021// which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order
8022// Related ticket - https://bugs.chromium.org/p/chromium/issues/detail?id=449857
8023if ( !support.focusin ) {8024jQuery.each( { focus: "focusin", blur: "focusout" }, function( orig, fix ) {8025
8026// Attach a single capturing handler on the document while someone wants focusin/focusout8027var handler = function( event ) {8028jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ) );8029};8030
8031jQuery.event.special[ fix ] = {8032setup: function() {8033
8034// Handle: regular nodes (via `this.ownerDocument`), window8035// (via `this.document`) & document (via `this`).8036var doc = this.ownerDocument || this.document || this,8037attaches = dataPriv.access( doc, fix );8038
8039if ( !attaches ) {8040doc.addEventListener( orig, handler, true );8041}8042dataPriv.access( doc, fix, ( attaches || 0 ) + 1 );8043},8044teardown: function() {8045var doc = this.ownerDocument || this.document || this,8046attaches = dataPriv.access( doc, fix ) - 1;8047
8048if ( !attaches ) {8049doc.removeEventListener( orig, handler, true );8050dataPriv.remove( doc, fix );8051
8052} else {8053dataPriv.access( doc, fix, attaches );8054}8055}8056};8057} );8058}
8059
8060
8061// Cross-browser xml parsing
8062jQuery.parseXML = function( data ) {8063var xml, parserErrorElem;8064if ( !data || typeof data !== "string" ) {8065return null;8066}8067
8068// Support: IE 9 - 11 only8069// IE throws on parseFromString with invalid input.8070try {8071xml = ( new window.DOMParser() ).parseFromString( data, "text/xml" );8072} catch ( e ) {}8073
8074parserErrorElem = xml && xml.getElementsByTagName( "parsererror" )[ 0 ];8075if ( !xml || parserErrorElem ) {8076jQuery.error( "Invalid XML: " + (8077parserErrorElem ?8078jQuery.map( parserErrorElem.childNodes, function( el ) {8079return el.textContent;8080} ).join( "\n" ) :8081data
8082) );8083}8084return xml;8085};8086
8087
8088var
8089rbracket = /\[\]$/,8090rCRLF = /\r?\n/g,8091rsubmitterTypes = /^(?:submit|button|image|reset|file)$/i,8092rsubmittable = /^(?:input|select|textarea|keygen)/i;8093
8094function buildParams( prefix, obj, traditional, add ) {8095var name;8096
8097if ( Array.isArray( obj ) ) {8098
8099// Serialize array item.8100jQuery.each( obj, function( i, v ) {8101if ( traditional || rbracket.test( prefix ) ) {8102
8103// Treat each array item as a scalar.8104add( prefix, v );8105
8106} else {8107
8108// Item is non-scalar (array or object), encode its numeric index.8109buildParams(8110prefix + "[" + ( typeof v === "object" && v != null ? i : "" ) + "]",8111v,8112traditional,8113add
8114);8115}8116} );8117
8118} else if ( !traditional && toType( obj ) === "object" ) {8119
8120// Serialize object item.8121for ( name in obj ) {8122buildParams( prefix + "[" + name + "]", obj[ name ], traditional, add );8123}8124
8125} else {8126
8127// Serialize scalar item.8128add( prefix, obj );8129}8130}
8131
8132// Serialize an array of form elements or a set of
8133// key/values into a query string
8134jQuery.param = function( a, traditional ) {8135var prefix,8136s = [],8137add = function( key, valueOrFunction ) {8138
8139// If value is a function, invoke it and use its return value8140var value = isFunction( valueOrFunction ) ?8141valueOrFunction() :8142valueOrFunction;8143
8144s[ s.length ] = encodeURIComponent( key ) + "=" +8145encodeURIComponent( value == null ? "" : value );8146};8147
8148if ( a == null ) {8149return "";8150}8151
8152// If an array was passed in, assume that it is an array of form elements.8153if ( Array.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) {8154
8155// Serialize the form elements8156jQuery.each( a, function() {8157add( this.name, this.value );8158} );8159
8160} else {8161
8162// If traditional, encode the "old" way (the way 1.3.2 or older8163// did it), otherwise encode params recursively.8164for ( prefix in a ) {8165buildParams( prefix, a[ prefix ], traditional, add );8166}8167}8168
8169// Return the resulting serialization8170return s.join( "&" );8171};8172
8173jQuery.fn.extend( {8174serialize: function() {8175return jQuery.param( this.serializeArray() );8176},8177serializeArray: function() {8178return this.map( function() {8179
8180// Can add propHook for "elements" to filter or add form elements8181var elements = jQuery.prop( this, "elements" );8182return elements ? jQuery.makeArray( elements ) : this;8183} ).filter( function() {8184var type = this.type;8185
8186// Use .is( ":disabled" ) so that fieldset[disabled] works8187return this.name && !jQuery( this ).is( ":disabled" ) &&8188rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&8189( this.checked || !rcheckableType.test( type ) );8190} ).map( function( _i, elem ) {8191var val = jQuery( this ).val();8192
8193if ( val == null ) {8194return null;8195}8196
8197if ( Array.isArray( val ) ) {8198return jQuery.map( val, function( val ) {8199return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) };8200} );8201}8202
8203return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) };8204} ).get();8205}8206} );8207
8208
8209jQuery.fn.extend( {8210wrapAll: function( html ) {8211var wrap;8212
8213if ( this[ 0 ] ) {8214if ( isFunction( html ) ) {8215html = html.call( this[ 0 ] );8216}8217
8218// The elements to wrap the target around8219wrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true );8220
8221if ( this[ 0 ].parentNode ) {8222wrap.insertBefore( this[ 0 ] );8223}8224
8225wrap.map( function() {8226var elem = this;8227
8228while ( elem.firstElementChild ) {8229elem = elem.firstElementChild;8230}8231
8232return elem;8233} ).append( this );8234}8235
8236return this;8237},8238
8239wrapInner: function( html ) {8240if ( isFunction( html ) ) {8241return this.each( function( i ) {8242jQuery( this ).wrapInner( html.call( this, i ) );8243} );8244}8245
8246return this.each( function() {8247var self = jQuery( this ),8248contents = self.contents();8249
8250if ( contents.length ) {8251contents.wrapAll( html );8252
8253} else {8254self.append( html );8255}8256} );8257},8258
8259wrap: function( html ) {8260var htmlIsFunction = isFunction( html );8261
8262return this.each( function( i ) {8263jQuery( this ).wrapAll( htmlIsFunction ? html.call( this, i ) : html );8264} );8265},8266
8267unwrap: function( selector ) {8268this.parent( selector ).not( "body" ).each( function() {8269jQuery( this ).replaceWith( this.childNodes );8270} );8271return this;8272}8273} );8274
8275
8276jQuery.expr.pseudos.hidden = function( elem ) {8277return !jQuery.expr.pseudos.visible( elem );8278};8279jQuery.expr.pseudos.visible = function( elem ) {8280return !!( elem.offsetWidth || elem.offsetHeight || elem.getClientRects().length );8281};8282
8283
8284
8285
8286// Support: Safari 8 only
8287// In Safari 8 documents created via document.implementation.createHTMLDocument
8288// collapse sibling forms: the second one becomes a child of the first one.
8289// Because of that, this security measure has to be disabled in Safari 8.
8290// https://bugs.webkit.org/show_bug.cgi?id=137337
8291support.createHTMLDocument = ( function() {8292var body = document.implementation.createHTMLDocument( "" ).body;8293body.innerHTML = "<form></form><form></form>";8294return body.childNodes.length === 2;8295} )();8296
8297
8298// Argument "data" should be string of html
8299// context (optional): If specified, the fragment will be created in this context,
8300// defaults to document
8301// keepScripts (optional): If true, will include scripts passed in the html string
8302jQuery.parseHTML = function( data, context, keepScripts ) {8303if ( typeof data !== "string" ) {8304return [];8305}8306if ( typeof context === "boolean" ) {8307keepScripts = context;8308context = false;8309}8310
8311var base, parsed, scripts;8312
8313if ( !context ) {8314
8315// Stop scripts or inline event handlers from being executed immediately8316// by using document.implementation8317if ( support.createHTMLDocument ) {8318context = document.implementation.createHTMLDocument( "" );8319
8320// Set the base href for the created document8321// so any parsed elements with URLs8322// are based on the document's URL (gh-2965)8323base = context.createElement( "base" );8324base.href = document.location.href;8325context.head.appendChild( base );8326} else {8327context = document;8328}8329}8330
8331parsed = rsingleTag.exec( data );8332scripts = !keepScripts && [];8333
8334// Single tag8335if ( parsed ) {8336return [ context.createElement( parsed[ 1 ] ) ];8337}8338
8339parsed = buildFragment( [ data ], context, scripts );8340
8341if ( scripts && scripts.length ) {8342jQuery( scripts ).remove();8343}8344
8345return jQuery.merge( [], parsed.childNodes );8346};8347
8348
8349jQuery.offset = {8350setOffset: function( elem, options, i ) {8351var curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition,8352position = jQuery.css( elem, "position" ),8353curElem = jQuery( elem ),8354props = {};8355
8356// Set position first, in-case top/left are set even on static elem8357if ( position === "static" ) {8358elem.style.position = "relative";8359}8360
8361curOffset = curElem.offset();8362curCSSTop = jQuery.css( elem, "top" );8363curCSSLeft = jQuery.css( elem, "left" );8364calculatePosition = ( position === "absolute" || position === "fixed" ) &&8365( curCSSTop + curCSSLeft ).indexOf( "auto" ) > -1;8366
8367// Need to be able to calculate position if either8368// top or left is auto and position is either absolute or fixed8369if ( calculatePosition ) {8370curPosition = curElem.position();8371curTop = curPosition.top;8372curLeft = curPosition.left;8373
8374} else {8375curTop = parseFloat( curCSSTop ) || 0;8376curLeft = parseFloat( curCSSLeft ) || 0;8377}8378
8379if ( isFunction( options ) ) {8380
8381// Use jQuery.extend here to allow modification of coordinates argument (gh-1848)8382options = options.call( elem, i, jQuery.extend( {}, curOffset ) );8383}8384
8385if ( options.top != null ) {8386props.top = ( options.top - curOffset.top ) + curTop;8387}8388if ( options.left != null ) {8389props.left = ( options.left - curOffset.left ) + curLeft;8390}8391
8392if ( "using" in options ) {8393options.using.call( elem, props );8394
8395} else {8396curElem.css( props );8397}8398}8399};8400
8401jQuery.fn.extend( {8402
8403// offset() relates an element's border box to the document origin8404offset: function( options ) {8405
8406// Preserve chaining for setter8407if ( arguments.length ) {8408return options === undefined ?8409this :8410this.each( function( i ) {8411jQuery.offset.setOffset( this, options, i );8412} );8413}8414
8415var rect, win,8416elem = this[ 0 ];8417
8418if ( !elem ) {8419return;8420}8421
8422// Return zeros for disconnected and hidden (display: none) elements (gh-2310)8423// Support: IE <=11 only8424// Running getBoundingClientRect on a8425// disconnected node in IE throws an error8426if ( !elem.getClientRects().length ) {8427return { top: 0, left: 0 };8428}8429
8430// Get document-relative position by adding viewport scroll to viewport-relative gBCR8431rect = elem.getBoundingClientRect();8432win = elem.ownerDocument.defaultView;8433return {8434top: rect.top + win.pageYOffset,8435left: rect.left + win.pageXOffset8436};8437},8438
8439// position() relates an element's margin box to its offset parent's padding box8440// This corresponds to the behavior of CSS absolute positioning8441position: function() {8442if ( !this[ 0 ] ) {8443return;8444}8445
8446var offsetParent, offset, doc,8447elem = this[ 0 ],8448parentOffset = { top: 0, left: 0 };8449
8450// position:fixed elements are offset from the viewport, which itself always has zero offset8451if ( jQuery.css( elem, "position" ) === "fixed" ) {8452
8453// Assume position:fixed implies availability of getBoundingClientRect8454offset = elem.getBoundingClientRect();8455
8456} else {8457offset = this.offset();8458
8459// Account for the *real* offset parent, which can be the document or its root element8460// when a statically positioned element is identified8461doc = elem.ownerDocument;8462offsetParent = elem.offsetParent || doc.documentElement;8463while ( offsetParent &&8464( offsetParent === doc.body || offsetParent === doc.documentElement ) &&8465jQuery.css( offsetParent, "position" ) === "static" ) {8466
8467offsetParent = offsetParent.parentNode;8468}8469if ( offsetParent && offsetParent !== elem && offsetParent.nodeType === 1 ) {8470
8471// Incorporate borders into its offset, since they are outside its content origin8472parentOffset = jQuery( offsetParent ).offset();8473parentOffset.top += jQuery.css( offsetParent, "borderTopWidth", true );8474parentOffset.left += jQuery.css( offsetParent, "borderLeftWidth", true );8475}8476}8477
8478// Subtract parent offsets and element margins8479return {8480top: offset.top - parentOffset.top - jQuery.css( elem, "marginTop", true ),8481left: offset.left - parentOffset.left - jQuery.css( elem, "marginLeft", true )8482};8483},8484
8485// This method will return documentElement in the following cases:8486// 1) For the element inside the iframe without offsetParent, this method will return8487// documentElement of the parent window8488// 2) For the hidden or detached element8489// 3) For body or html element, i.e. in case of the html node - it will return itself8490//8491// but those exceptions were never presented as a real life use-cases8492// and might be considered as more preferable results.8493//8494// This logic, however, is not guaranteed and can change at any point in the future8495offsetParent: function() {8496return this.map( function() {8497var offsetParent = this.offsetParent;8498
8499while ( offsetParent && jQuery.css( offsetParent, "position" ) === "static" ) {8500offsetParent = offsetParent.offsetParent;8501}8502
8503return offsetParent || documentElement;8504} );8505}8506} );8507
8508// Create scrollLeft and scrollTop methods
8509jQuery.each( { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function( method, prop ) {8510var top = "pageYOffset" === prop;8511
8512jQuery.fn[ method ] = function( val ) {8513return access( this, function( elem, method, val ) {8514
8515// Coalesce documents and windows8516var win;8517if ( isWindow( elem ) ) {8518win = elem;8519} else if ( elem.nodeType === 9 ) {8520win = elem.defaultView;8521}8522
8523if ( val === undefined ) {8524return win ? win[ prop ] : elem[ method ];8525}8526
8527if ( win ) {8528win.scrollTo(8529!top ? val : win.pageXOffset,8530top ? val : win.pageYOffset8531);8532
8533} else {8534elem[ method ] = val;8535}8536}, method, val, arguments.length );8537};8538} );8539
8540// Support: Safari <=7 - 9.1, Chrome <=37 - 49
8541// Add the top/left cssHooks using jQuery.fn.position
8542// Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084
8543// Blink bug: https://bugs.chromium.org/p/chromium/issues/detail?id=589347
8544// getComputedStyle returns percent when specified for top/left/bottom/right;
8545// rather than make the css module depend on the offset module, just check for it here
8546jQuery.each( [ "top", "left" ], function( _i, prop ) {8547jQuery.cssHooks[ prop ] = addGetHookIf( support.pixelPosition,8548function( elem, computed ) {8549if ( computed ) {8550computed = curCSS( elem, prop );8551
8552// If curCSS returns percentage, fallback to offset8553return rnumnonpx.test( computed ) ?8554jQuery( elem ).position()[ prop ] + "px" :8555computed;8556}8557}8558);8559} );8560
8561
8562// Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods
8563jQuery.each( { Height: "height", Width: "width" }, function( name, type ) {8564jQuery.each( {8565padding: "inner" + name,8566content: type,8567"": "outer" + name8568}, function( defaultExtra, funcName ) {8569
8570// Margin is only for outerHeight, outerWidth8571jQuery.fn[ funcName ] = function( margin, value ) {8572var chainable = arguments.length && ( defaultExtra || typeof margin !== "boolean" ),8573extra = defaultExtra || ( margin === true || value === true ? "margin" : "border" );8574
8575return access( this, function( elem, type, value ) {8576var doc;8577
8578if ( isWindow( elem ) ) {8579
8580// $( window ).outerWidth/Height return w/h including scrollbars (gh-1729)8581return funcName.indexOf( "outer" ) === 0 ?8582elem[ "inner" + name ] :8583elem.document.documentElement[ "client" + name ];8584}8585
8586// Get document width or height8587if ( elem.nodeType === 9 ) {8588doc = elem.documentElement;8589
8590// Either scroll[Width/Height] or offset[Width/Height] or client[Width/Height],8591// whichever is greatest8592return Math.max(8593elem.body[ "scroll" + name ], doc[ "scroll" + name ],8594elem.body[ "offset" + name ], doc[ "offset" + name ],8595doc[ "client" + name ]8596);8597}8598
8599return value === undefined ?8600
8601// Get width or height on the element, requesting but not forcing parseFloat8602jQuery.css( elem, type, extra ) :8603
8604// Set width or height on the element8605jQuery.style( elem, type, value, extra );8606}, type, chainable ? margin : undefined, chainable );8607};8608} );8609} );8610
8611
8612jQuery.fn.extend( {8613
8614bind: function( types, data, fn ) {8615return this.on( types, null, data, fn );8616},8617unbind: function( types, fn ) {8618return this.off( types, null, fn );8619},8620
8621delegate: function( selector, types, data, fn ) {8622return this.on( types, selector, data, fn );8623},8624undelegate: function( selector, types, fn ) {8625
8626// ( namespace ) or ( selector, types [, fn] )8627return arguments.length === 1 ?8628this.off( selector, "**" ) :8629this.off( types, selector || "**", fn );8630},8631
8632hover: function( fnOver, fnOut ) {8633return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver );8634}8635} );8636
8637jQuery.each(8638( "blur focus focusin focusout resize scroll click dblclick " +8639"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " +8640"change select submit keydown keypress keyup contextmenu" ).split( " " ),8641function( _i, name ) {8642
8643// Handle event binding8644jQuery.fn[ name ] = function( data, fn ) {8645return arguments.length > 0 ?8646this.on( name, null, data, fn ) :8647this.trigger( name );8648};8649}8650);8651
8652
8653
8654
8655// Support: Android <=4.0 only
8656// Make sure we trim BOM and NBSP
8657var rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;8658
8659// Bind a function to a context, optionally partially applying any
8660// arguments.
8661// jQuery.proxy is deprecated to promote standards (specifically Function#bind)
8662// However, it is not slated for removal any time soon
8663jQuery.proxy = function( fn, context ) {8664var tmp, args, proxy;8665
8666if ( typeof context === "string" ) {8667tmp = fn[ context ];8668context = fn;8669fn = tmp;8670}8671
8672// Quick check to determine if target is callable, in the spec8673// this throws a TypeError, but we will just return undefined.8674if ( !isFunction( fn ) ) {8675return undefined;8676}8677
8678// Simulated bind8679args = slice.call( arguments, 2 );8680proxy = function() {8681return fn.apply( context || this, args.concat( slice.call( arguments ) ) );8682};8683
8684// Set the guid of unique handler to the same of original handler, so it can be removed8685proxy.guid = fn.guid = fn.guid || jQuery.guid++;8686
8687return proxy;8688};8689
8690jQuery.holdReady = function( hold ) {8691if ( hold ) {8692jQuery.readyWait++;8693} else {8694jQuery.ready( true );8695}8696};8697jQuery.isArray = Array.isArray;8698jQuery.parseJSON = JSON.parse;8699jQuery.nodeName = nodeName;8700jQuery.isFunction = isFunction;8701jQuery.isWindow = isWindow;8702jQuery.camelCase = camelCase;8703jQuery.type = toType;8704
8705jQuery.now = Date.now;8706
8707jQuery.isNumeric = function( obj ) {8708
8709// As of jQuery 3.0, isNumeric is limited to8710// strings and numbers (primitives or objects)8711// that can be coerced to finite numbers (gh-2662)8712var type = jQuery.type( obj );8713return ( type === "number" || type === "string" ) &&8714
8715// parseFloat NaNs numeric-cast false positives ("")8716// ...but misinterprets leading-number strings, particularly hex literals ("0x...")8717// subtraction forces infinities to NaN8718!isNaN( obj - parseFloat( obj ) );8719};8720
8721jQuery.trim = function( text ) {8722return text == null ?8723"" :8724( text + "" ).replace( rtrim, "" );8725};8726
8727
8728
8729// Register as a named AMD module, since jQuery can be concatenated with other
8730// files that may use define, but not via a proper concatenation script that
8731// understands anonymous AMD modules. A named AMD is safest and most robust
8732// way to register. Lowercase jquery is used because AMD module names are
8733// derived from file names, and jQuery is normally delivered in a lowercase
8734// file name. Do this after creating the global so that if an AMD module wants
8735// to call noConflict to hide this version of jQuery, it will work.
8736
8737// Note that for maximum portability, libraries that are not jQuery should
8738// declare themselves as anonymous modules, and avoid setting a global if an
8739// AMD loader is present. jQuery is a special case. For more information, see
8740// https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon
8741
8742if ( typeof define === "function" && define.amd ) {8743define( "jquery", [], function() {8744return jQuery;8745} );8746}
8747
8748
8749
8750
8751var
8752
8753// Map over jQuery in case of overwrite8754_jQuery = window.jQuery,8755
8756// Map over the $ in case of overwrite8757_$ = window.$;8758
8759jQuery.noConflict = function( deep ) {8760if ( window.$ === jQuery ) {8761window.$ = _$;8762}8763
8764if ( deep && window.jQuery === jQuery ) {8765window.jQuery = _jQuery;8766}8767
8768return jQuery;8769};8770
8771// Expose jQuery and $ identifiers, even in AMD
8772// (#7102#comment:10, https://github.com/jquery/jquery/pull/557)
8773// and CommonJS for browser emulators (#13566)
8774if ( typeof noGlobal === "undefined" ) {8775window.jQuery = window.$ = jQuery;8776}
8777
8778
8779
8780
8781return jQuery;8782} );8783