/*! * jQuery JavaScript Library v1.12.4 * http://jquery.com/ * * Includes Sizzle.js * http://sizzlejs.com/ * * Copyright jQuery Foundation and other contributors * Released under the MIT license * http://jquery.org/license * * Date: 2016-05-20T17:17Z */ (function( global, factory ) { if ( typeof module === "object" && typeof module.exports === "object" ) { // For CommonJS and CommonJS-like environments where a proper `window` // is present, execute the factory and get jQuery. // For environments that do not have a `window` with a `document` // (such as Node.js), expose a factory as module.exports. // This accentuates the need for the creation of a real `window`. // e.g. var jQuery = require("jquery")(window); // See ticket #14549 for more info. module.exports = global.document ? factory( global, true ) : function( w ) { if ( !w.document ) { throw new Error( "jQuery requires a window with a document" ); } return factory( w ); }; } else { factory( global ); } // Pass this if window is not defined yet }(typeof window !== "undefined" ? window : this, function( window, noGlobal ) { // Support: Firefox 18+ // Can't be in strict mode, several libs including ASP.NET trace // the stack via arguments.caller.callee and Firefox dies if // you try to trace through "use strict" call chains. (#13335) //"use strict"; var deletedIds = []; var document = window.document; var slice = deletedIds.slice; var concat = deletedIds.concat; var push = deletedIds.push; var indexOf = deletedIds.indexOf; var class2type = {}; var toString = class2type.toString; var hasOwn = class2type.hasOwnProperty; var support = {}; var version = "1.12.4", // Define a local copy of jQuery jQuery = function( selector, context ) { // The jQuery object is actually just the init constructor 'enhanced' // Need init if jQuery is called (just allow error to be thrown if not included) return new jQuery.fn.init( selector, context ); }, // Support: Android<4.1, IE<9 // Make sure we trim BOM and NBSP rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, // Matches dashed string for camelizing rmsPrefix = /^-ms-/, rdashAlpha = /-([\da-z])/gi, // Used by jQuery.camelCase as callback to replace() fcamelCase = function( all, letter ) { return letter.toUpperCase(); }; jQuery.fn = jQuery.prototype = { // The current version of jQuery being used jquery: version, constructor: jQuery, // Start with an empty selector selector: "", // The default length of a jQuery object is 0 length: 0, toArray: function() { return slice.call( this ); }, // Get the Nth element in the matched element set OR // Get the whole matched element set as a clean array get: function( num ) { return num != null ? // Return just the one element from the set ( num < 0 ? this[ num + this.length ] : this[ num ] ) : // Return all the elements in a clean array slice.call( this ); }, // Take an array of elements and push it onto the stack // (returning the new matched element set) pushStack: function( elems ) { // Build a new jQuery matched element set var ret = jQuery.merge( this.constructor(), elems ); // Add the old object onto the stack (as a reference) ret.prevObject = this; ret.context = this.context; // Return the newly-formed element set return ret; }, // Execute a callback for every element in the matched set. each: function( callback ) { return jQuery.each( this, callback ); }, map: function( callback ) { return this.pushStack( jQuery.map( this, function( elem, i ) { return callback.call( elem, i, elem ); } ) ); }, slice: function() { return this.pushStack( slice.apply( this, arguments ) ); }, first: function() { return this.eq( 0 ); }, last: function() { return this.eq( -1 ); }, eq: function( i ) { var len = this.length, j = +i + ( i < 0 ? len : 0 ); return this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] ); }, end: function() { return this.prevObject || this.constructor(); }, // For internal use only. // Behaves like an Array's method, not like a jQuery method. push: push, sort: deletedIds.sort, splice: deletedIds.splice }; jQuery.extend = jQuery.fn.extend = function() { var src, copyIsArray, copy, name, options, clone, target = arguments[ 0 ] || {}, i = 1, length = arguments.length, deep = false; // Handle a deep copy situation if ( typeof target === "boolean" ) { deep = target; // skip the boolean and the target target = arguments[ i ] || {}; i++; } // Handle case when target is a string or something (possible in deep copy) if ( typeof target !== "object" && !jQuery.isFunction( target ) ) { target = {}; } // extend jQuery itself if only one argument is passed if ( i === length ) { target = this; i--; } for ( ; i < length; i++ ) { // Only deal with non-null/undefined values if ( ( options = arguments[ i ] ) != null ) { // Extend the base object for ( name in options ) { src = target[ name ]; copy = options[ name ]; // Prevent never-ending loop if ( target === copy ) { continue; } // Recurse if we're merging plain objects or arrays if ( deep && copy && ( jQuery.isPlainObject( copy ) || ( copyIsArray = jQuery.isArray( copy ) ) ) ) { if ( copyIsArray ) { copyIsArray = false; clone = src && jQuery.isArray( src ) ? src : []; } else { clone = src && jQuery.isPlainObject( src ) ? src : {}; } // Never move original objects, clone them target[ name ] = jQuery.extend( deep, clone, copy ); // Don't bring in undefined values } else if ( copy !== undefined ) { target[ name ] = copy; } } } } // Return the modified object return target; }; jQuery.extend( { // Unique for each copy of jQuery on the page expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ), // Assume jQuery is ready without the ready module isReady: true, error: function( msg ) { throw new Error( msg ); }, noop: function() {}, // See test/unit/core.js for details concerning isFunction. // Since version 1.3, DOM methods and functions like alert // aren't supported. They return false on IE (#2968). isFunction: function( obj ) { return jQuery.type( obj ) === "function"; }, isArray: Array.isArray || function( obj ) { return jQuery.type( obj ) === "array"; }, isWindow: function( obj ) { /* jshint eqeqeq: false */ return obj != null && obj == obj.window; }, isNumeric: function( obj ) { // parseFloat NaNs numeric-cast false positives (null|true|false|"") // ...but misinterprets leading-number strings, particularly hex literals ("0x...") // subtraction forces infinities to NaN // adding 1 corrects loss of precision from parseFloat (#15100) var realStringObj = obj && obj.toString(); return !jQuery.isArray( obj ) && ( realStringObj - parseFloat( realStringObj ) + 1 ) >= 0; }, isEmptyObject: function( obj ) { var name; for ( name in obj ) { return false; } return true; }, isPlainObject: function( obj ) { var key; // Must be an Object. // Because of IE, we also have to check the presence of the constructor property. // Make sure that DOM nodes and window objects don't pass through, as well if ( !obj || jQuery.type( obj ) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) { return false; } try { // Not own constructor property must be Object if ( obj.constructor && !hasOwn.call( obj, "constructor" ) && !hasOwn.call( obj.constructor.prototype, "isPrototypeOf" ) ) { return false; } } catch ( e ) { // IE8,9 Will throw exceptions on certain host objects #9897 return false; } // Support: IE<9 // Handle iteration over inherited properties before own properties. if ( !support.ownFirst ) { for ( key in obj ) { return hasOwn.call( obj, key ); } } // Own properties are enumerated firstly, so to speed up, // if last one is own, then all properties are own. for ( key in obj ) {} return key === undefined || hasOwn.call( obj, key ); }, type: function( obj ) { if ( obj == null ) { return obj + ""; } return typeof obj === "object" || typeof obj === "function" ? class2type[ toString.call( obj ) ] || "object" : typeof obj; }, // Workarounds based on findings by Jim Driscoll // http://weblogs.java.net/blog/driscoll/archive/2009/09/08/eval-javascript-global-context globalEval: function( data ) { if ( data && jQuery.trim( data ) ) { // We use execScript on Internet Explorer // We use an anonymous function so that context is window // rather than jQuery in Firefox ( window.execScript || function( data ) { window[ "eval" ].call( window, data ); // jscs:ignore requireDotNotation } )( data ); } }, // Convert dashed to camelCase; used by the css and data modules // Microsoft forgot to hump their vendor prefix (#9572) camelCase: function( string ) { return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase ); }, nodeName: function( elem, name ) { return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); }, each: function( obj, callback ) { var length, i = 0; if ( isArrayLike( obj ) ) { length = obj.length; for ( ; i < length; i++ ) { if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { break; } } } else { for ( i in obj ) { if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { break; } } } return obj; }, // Support: Android<4.1, IE<9 trim: function( text ) { return text == null ? "" : ( text + "" ).replace( rtrim, "" ); }, // results is for internal usage only makeArray: function( arr, results ) { var ret = results || []; if ( arr != null ) { if ( isArrayLike( Object( arr ) ) ) { jQuery.merge( ret, typeof arr === "string" ? [ arr ] : arr ); } else { push.call( ret, arr ); } } return ret; }, inArray: function( elem, arr, i ) { var len; if ( arr ) { if ( indexOf ) { return indexOf.call( arr, elem, i ); } len = arr.length; i = i ? i < 0 ? Math.max( 0, len + i ) : i : 0; for ( ; i < len; i++ ) { // Skip accessing in sparse arrays if ( i in arr && arr[ i ] === elem ) { return i; } } } return -1; }, merge: function( first, second ) { var len = +second.length, j = 0, i = first.length; while ( j < len ) { first[ i++ ] = second[ j++ ]; } // Support: IE<9 // Workaround casting of .length to NaN on otherwise arraylike objects (e.g., NodeLists) if ( len !== len ) { while ( second[ j ] !== undefined ) { first[ i++ ] = second[ j++ ]; } } first.length = i; return first; }, grep: function( elems, callback, invert ) { var callbackInverse, matches = [], i = 0, length = elems.length, callbackExpect = !invert; // Go through the array, only saving the items // that pass the validator function for ( ; i < length; i++ ) { callbackInverse = !callback( elems[ i ], i ); if ( callbackInverse !== callbackExpect ) { matches.push( elems[ i ] ); } } return matches; }, // arg is for internal usage only map: function( elems, callback, arg ) { var length, value, i = 0, ret = []; // Go through the array, translating each of the items to their new values if ( isArrayLike( elems ) ) { length = elems.length; for ( ; i < length; i++ ) { value = callback( elems[ i ], i, arg ); if ( value != null ) { ret.push( value ); } } // Go through every key on the object, } else { for ( i in elems ) { value = callback( elems[ i ], i, arg ); if ( value != null ) { ret.push( value ); } } } // Flatten any nested arrays return concat.apply( [], ret ); }, // A global GUID counter for objects guid: 1, // Bind a function to a context, optionally partially applying any // arguments. proxy: function( fn, context ) { var args, proxy, tmp; if ( typeof context === "string" ) { tmp = fn[ context ]; context = fn; fn = tmp; } // Quick check to determine if target is callable, in the spec // this throws a TypeError, but we will just return undefined. if ( !jQuery.isFunction( fn ) ) { return undefined; } // Simulated bind args = slice.call( arguments, 2 ); proxy = function() { return fn.apply( context || this, args.concat( slice.call( arguments ) ) ); }; // Set the guid of unique handler to the same of original handler, so it can be removed proxy.guid = fn.guid = fn.guid || jQuery.guid++; return proxy; }, now: function() { return +( new Date() ); }, // jQuery.support is not used in Core but other projects attach their // properties to it so it needs to exist. support: support } ); // JSHint would error on this code due to the Symbol not being defined in ES5. // Defining this global in .jshintrc would create a danger of using the global // unguarded in another place, it seems safer to just disable JSHint for these // three lines. /* jshint ignore: start */ if ( typeof Symbol === "function" ) { jQuery.fn[ Symbol.iterator ] = deletedIds[ Symbol.iterator ]; } /* jshint ignore: end */ // Populate the class2type map jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), function( i, name ) { class2type[ "[object " + name + "]" ] = name.toLowerCase(); } ); function isArrayLike( obj ) { // Support: iOS 8.2 (not reproducible in simulator) // `in` check used to prevent JIT error (gh-2145) // hasOwn isn't used here due to false negatives // regarding Nodelist length in IE var length = !!obj && "length" in obj && obj.length, type = jQuery.type( obj ); if ( type === "function" || jQuery.isWindow( obj ) ) { return false; } return type === "array" || length === 0 || typeof length === "number" && length > 0 && ( length - 1 ) in obj; } var Sizzle = /*! * Sizzle CSS Selector Engine v2.2.1 * http://sizzlejs.com/ * * Copyright jQuery Foundation and other contributors * Released under the MIT license * http://jquery.org/license * * Date: 2015-10-17 */ (function( window ) { var i, support, Expr, getText, isXML, tokenize, compile, select, outermostContext, sortInput, hasDuplicate, // Local document vars setDocument, document, docElem, documentIsHTML, rbuggyQSA, rbuggyMatches, matches, contains, // Instance-specific data expando = "sizzle" + 1 * new Date(), preferredDoc = window.document, dirruns = 0, done = 0, classCache = createCache(), tokenCache = createCache(), compilerCache = createCache(), sortOrder = function( a, b ) { if ( a === b ) { hasDuplicate = true; } return 0; }, // General-purpose constants MAX_NEGATIVE = 1 << 31, // Instance methods hasOwn = ({}).hasOwnProperty, arr = [], pop = arr.pop, push_native = arr.push, push = arr.push, slice = arr.slice, // Use a stripped-down indexOf as it's faster than native // http://jsperf.com/thor-indexof-vs-for/5 indexOf = function( list, elem ) { var i = 0, len = list.length; for ( ; i < len; i++ ) { if ( list[i] === elem ) { return i; } } return -1; }, booleans = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped", // Regular expressions // http://www.w3.org/TR/css3-selectors/#whitespace whitespace = "[\\x20\\t\\r\\n\\f]", // http://www.w3.org/TR/CSS21/syndata.html#value-def-identifier identifier = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+", // Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors attributes = "\\[" + whitespace + "*(" + identifier + ")(?:" + whitespace + // Operator (capture 2) "*([*^$|!~]?=)" + whitespace + // "Attribute values must be CSS identifiers [capture 5] or strings [capture 3 or capture 4]" "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" + whitespace + "*\\]", pseudos = ":(" + identifier + ")(?:\\((" + // To reduce the number of selectors needing tokenize in the preFilter, prefer arguments: // 1. quoted (capture 3; capture 4 or capture 5) "('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|" + // 2. simple (capture 6) "((?:\\\\.|[^\\\\()[\\]]|" + attributes + ")*)|" + // 3. anything else (capture 2) ".*" + ")\\)|)", // Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter rwhitespace = new RegExp( whitespace + "+", "g" ), rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + whitespace + "+$", "g" ), rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ), rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace + "*" ), rattributeQuotes = new RegExp( "=" + whitespace + "*([^\\]'\"]*?)" + whitespace + "*\\]", "g" ), rpseudo = new RegExp( pseudos ), ridentifier = new RegExp( "^" + identifier + "$" ), matchExpr = { "ID": new RegExp( "^#(" + identifier + ")" ), "CLASS": new RegExp( "^\\.(" + identifier + ")" ), "TAG": new RegExp( "^(" + identifier + "|[*])" ), "ATTR": new RegExp( "^" + attributes ), "PSEUDO": new RegExp( "^" + pseudos ), "CHILD": new RegExp( "^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + whitespace + "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" + whitespace + "*(\\d+)|))" + whitespace + "*\\)|)", "i" ), "bool": new RegExp( "^(?:" + booleans + ")$", "i" ), // For use in libraries implementing .is() // We use this for POS matching in `select` "needsContext": new RegExp( "^" + whitespace + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + whitespace + "*((?:-\\d)?\\d*)" + whitespace + "*\\)|)(?=[^-]|$)", "i" ) }, rinputs = /^(?:input|select|textarea|button)$/i, rheader = /^h\d$/i, rnative = /^[^{]+\{\s*\[native \w/, // Easily-parseable/retrievable ID or TAG or CLASS selectors rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, rsibling = /[+~]/, rescape = /'|\\/g, // CSS escapes http://www.w3.org/TR/CSS21/syndata.html#escaped-characters runescape = new RegExp( "\\\\([\\da-f]{1,6}" + whitespace + "?|(" + whitespace + ")|.)", "ig" ), funescape = function( _, escaped, escapedWhitespace ) { var high = "0x" + escaped - 0x10000; // NaN means non-codepoint // Support: Firefox<24 // Workaround erroneous numeric interpretation of +"0x" return high !== high || escapedWhitespace ? escaped : high < 0 ? // BMP codepoint String.fromCharCode( high + 0x10000 ) : // Supplemental Plane codepoint (surrogate pair) String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 ); }, // Used for iframes // See setDocument() // Removing the function wrapper causes a "Permission Denied" // error in IE unloadHandler = function() { setDocument(); }; // Optimize for push.apply( _, NodeList ) try { push.apply( (arr = slice.call( preferredDoc.childNodes )), preferredDoc.childNodes ); // Support: Android<4.0 // Detect silently failing push.apply arr[ preferredDoc.childNodes.length ].nodeType; } catch ( e ) { push = { apply: arr.length ? // Leverage slice if possible function( target, els ) { push_native.apply( target, slice.call(els) ); } : // Support: IE<9 // Otherwise append directly function( target, els ) { var j = target.length, i = 0; // Can't trust NodeList.length while ( (target[j++] = els[i++]) ) {} target.length = j - 1; } }; } function Sizzle( selector, context, results, seed ) { var m, i, elem, nid, nidselect, match, groups, newSelector, newContext = context && context.ownerDocument, // nodeType defaults to 9, since context defaults to document nodeType = context ? context.nodeType : 9; results = results || []; // Return early from calls with invalid selector or context if ( typeof selector !== "string" || !selector || nodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) { return results; } // Try to shortcut find operations (as opposed to filters) in HTML documents if ( !seed ) { if ( ( context ? context.ownerDocument || context : preferredDoc ) !== document ) { setDocument( context ); } context = context || document; if ( documentIsHTML ) { // If the selector is sufficiently simple, try using a "get*By*" DOM method // (excepting DocumentFragment context, where the methods don't exist) if ( nodeType !== 11 && (match = rquickExpr.exec( selector )) ) { // ID selector if ( (m = match[1]) ) { // Document context if ( nodeType === 9 ) { if ( (elem = context.getElementById( m )) ) { // Support: IE, Opera, Webkit // TODO: identify versions // getElementById can match elements by name instead of ID if ( elem.id === m ) { results.push( elem ); return results; } } else { return results; } // Element context } else { // Support: IE, Opera, Webkit // TODO: identify versions // getElementById can match elements by name instead of ID if ( newContext && (elem = newContext.getElementById( m )) && contains( context, elem ) && elem.id === m ) { results.push( elem ); return results; } } // Type selector } else if ( match[2] ) { push.apply( results, context.getElementsByTagName( selector ) ); return results; // Class selector } else if ( (m = match[3]) && support.getElementsByClassName && context.getElementsByClassName ) { push.apply( results, context.getElementsByClassName( m ) ); return results; } } // Take advantage of querySelectorAll if ( support.qsa && !compilerCache[ selector + " " ] && (!rbuggyQSA || !rbuggyQSA.test( selector )) ) { if ( nodeType !== 1 ) { newContext = context; newSelector = selector; // qSA looks outside Element context, which is not what we want // Thanks to Andrew Dupont for this workaround technique // Support: IE <=8 // Exclude object elements } else if ( context.nodeName.toLowerCase() !== "object" ) { // Capture the context ID, setting it first if necessary if ( (nid = context.getAttribute( "id" )) ) { nid = nid.replace( rescape, "\\$&" ); } else { context.setAttribute( "id", (nid = expando) ); } // Prefix every selector in the list groups = tokenize( selector ); i = groups.length; nidselect = ridentifier.test( nid ) ? "#" + nid : "[id='" + nid + "']"; while ( i-- ) { groups[i] = nidselect + " " + toSelector( groups[i] ); } newSelector = groups.join( "," ); // Expand context for sibling selectors newContext = rsibling.test( selector ) && testContext( context.parentNode ) || context; } if ( newSelector ) { try { push.apply( results, newContext.querySelectorAll( newSelector ) ); return results; } catch ( qsaError ) { } finally { if ( nid === expando ) { context.removeAttribute( "id" ); } } } } } } // All others return select( selector.replace( rtrim, "$1" ), context, results, seed ); } /** * Create key-value caches of limited size * @returns {function(string, object)} Returns the Object data after storing it on itself with * property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength) * deleting the oldest entry */ function createCache() { var keys = []; function cache( key, value ) { // Use (key + " ") to avoid collision with native prototype properties (see Issue #157) if ( keys.push( key + " " ) > Expr.cacheLength ) { // Only keep the most recent entries delete cache[ keys.shift() ]; } return (cache[ key + " " ] = value); } return cache; } /** * Mark a function for special use by Sizzle * @param {Function} fn The function to mark */ function markFunction( fn ) { fn[ expando ] = true; return fn; } /** * Support testing using an element * @param {Function} fn Passed the created div and expects a boolean result */ function assert( fn ) { var div = document.createElement("div"); try { return !!fn( div ); } catch (e) { return false; } finally { // Remove from its parent by default if ( div.parentNode ) { div.parentNode.removeChild( div ); } // release memory in IE div = null; } } /** * Adds the same handler for all of the specified attrs * @param {String} attrs Pipe-separated list of attributes * @param {Function} handler The method that will be applied */ function addHandle( attrs, handler ) { var arr = attrs.split("|"), i = arr.length; while ( i-- ) { Expr.attrHandle[ arr[i] ] = handler; } } /** * Checks document order of two siblings * @param {Element} a * @param {Element} b * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b */ function siblingCheck( a, b ) { var cur = b && a, diff = cur && a.nodeType === 1 && b.nodeType === 1 && ( ~b.sourceIndex || MAX_NEGATIVE ) - ( ~a.sourceIndex || MAX_NEGATIVE ); // Use IE sourceIndex if available on both nodes if ( diff ) { return diff; } // Check if b follows a if ( cur ) { while ( (cur = cur.nextSibling) ) { if ( cur === b ) { return -1; } } } return a ? 1 : -1; } /** * Returns a function to use in pseudos for input types * @param {String} type */ function createInputPseudo( type ) { return function( elem ) { var name = elem.nodeName.toLowerCase(); return name === "input" && elem.type === type; }; } /** * Returns a function to use in pseudos for buttons * @param {String} type */ function createButtonPseudo( type ) { return function( elem ) { var name = elem.nodeName.toLowerCase(); return (name === "input" || name === "button") && elem.type === type; }; } /** * Returns a function to use in pseudos for positionals * @param {Function} fn */ function createPositionalPseudo( fn ) { return markFunction(function( argument ) { argument = +argument; return markFunction(function( seed, matches ) { var j, matchIndexes = fn( [], seed.length, argument ), i = matchIndexes.length; // Match elements found at the specified indexes while ( i-- ) { if ( seed[ (j = matchIndexes[i]) ] ) { seed[j] = !(matches[j] = seed[j]); } } }); }); } /** * Checks a node for validity as a Sizzle context * @param {Element|Object=} context * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value */ function testContext( context ) { return context && typeof context.getElementsByTagName !== "undefined" && context; } // Expose support vars for convenience support = Sizzle.support = {}; /** * Detects XML nodes * @param {Element|Object} elem An element or a document * @returns {Boolean} True iff elem is a non-HTML XML node */ isXML = Sizzle.isXML = function( elem ) { // documentElement is verified for cases where it doesn't yet exist // (such as loading iframes in IE - #4833) var documentElement = elem && (elem.ownerDocument || elem).documentElement; return documentElement ? documentElement.nodeName !== "HTML" : false; }; /** * Sets document-related variables once based on the current document * @param {Element|Object} [doc] An element or document object to use to set the document * @returns {Object} Returns the current document */ setDocument = Sizzle.setDocument = function( node ) { var hasCompare, parent, doc = node ? node.ownerDocument || node : preferredDoc; // Return early if doc is invalid or already selected if ( doc === document || doc.nodeType !== 9 || !doc.documentElement ) { return document; } // Update global variables document = doc; docElem = document.documentElement; documentIsHTML = !isXML( document ); // Support: IE 9-11, Edge // Accessing iframe documents after unload throws "permission denied" errors (jQuery #13936) if ( (parent = document.defaultView) && parent.top !== parent ) { // Support: IE 11 if ( parent.addEventListener ) { parent.addEventListener( "unload", unloadHandler, false ); // Support: IE 9 - 10 only } else if ( parent.attachEvent ) { parent.attachEvent( "onunload", unloadHandler ); } } /* Attributes ---------------------------------------------------------------------- */ // Support: IE<8 // Verify that getAttribute really returns attributes and not properties // (excepting IE8 booleans) support.attributes = assert(function( div ) { div.className = "i"; return !div.getAttribute("className"); }); /* getElement(s)By* ---------------------------------------------------------------------- */ // Check if getElementsByTagName("*") returns only elements support.getElementsByTagName = assert(function( div ) { div.appendChild( document.createComment("") ); return !div.getElementsByTagName("*").length; }); // Support: IE<9 support.getElementsByClassName = rnative.test( document.getElementsByClassName ); // Support: IE<10 // Check if getElementById returns elements by name // The broken getElementById methods don't pick up programatically-set names, // so use a roundabout getElementsByName test support.getById = assert(function( div ) { docElem.appendChild( div ).id = expando; return !document.getElementsByName || !document.getElementsByName( expando ).length; }); // ID find and filter if ( support.getById ) { Expr.find["ID"] = function( id, context ) { if ( typeof context.getElementById !== "undefined" && documentIsHTML ) { var m = context.getElementById( id ); return m ? [ m ] : []; } }; Expr.filter["ID"] = function( id ) { var attrId = id.replace( runescape, funescape ); return function( elem ) { return elem.getAttribute("id") === attrId; }; }; } else { // Support: IE6/7 // getElementById is not reliable as a find shortcut delete Expr.find["ID"]; Expr.filter["ID"] = function( id ) { var attrId = id.replace( runescape, funescape ); return function( elem ) { var node = typeof elem.getAttributeNode !== "undefined" && elem.getAttributeNode("id"); return node && node.value === attrId; }; }; } // Tag Expr.find["TAG"] = support.getElementsByTagName ? function( tag, context ) { if ( typeof context.getElementsByTagName !== "undefined" ) { return context.getElementsByTagName( tag ); // DocumentFragment nodes don't have gEBTN } else if ( support.qsa ) { return context.querySelectorAll( tag ); } } : function( tag, context ) { var elem, tmp = [], i = 0, // By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too results = context.getElementsByTagName( tag ); // Filter out possible comments if ( tag === "*" ) { while ( (elem = results[i++]) ) { if ( elem.nodeType === 1 ) { tmp.push( elem ); } } return tmp; } return results; }; // Class Expr.find["CLASS"] = support.getElementsByClassName && function( className, context ) { if ( typeof context.getElementsByClassName !== "undefined" && documentIsHTML ) { return context.getElementsByClassName( className ); } }; /* QSA/matchesSelector ---------------------------------------------------------------------- */ // QSA and matchesSelector support // matchesSelector(:active) reports false when true (IE9/Opera 11.5) rbuggyMatches = []; // qSa(:focus) reports false when true (Chrome 21) // We allow this because of a bug in IE8/9 that throws an error // whenever `document.activeElement` is accessed on an iframe // So, we allow :focus to pass through QSA all the time to avoid the IE error // See http://bugs.jquery.com/ticket/13378 rbuggyQSA = []; if ( (support.qsa = rnative.test( document.querySelectorAll )) ) { // Build QSA regex // Regex strategy adopted from Diego Perini assert(function( div ) { // Select is set to empty string on purpose // This is to test IE's treatment of not explicitly // setting a boolean content attribute, // since its presence should be enough // http://bugs.jquery.com/ticket/12359 docElem.appendChild( div ).innerHTML = "" + ""; // Support: IE8, Opera 11-12.16 // Nothing should be selected when empty strings follow ^= or $= or *= // The test attribute must be unknown in Opera but "safe" for WinRT // http://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section if ( div.querySelectorAll("[msallowcapture^='']").length ) { rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:''|\"\")" ); } // Support: IE8 // Boolean attributes and "value" are not treated correctly if ( !div.querySelectorAll("[selected]").length ) { rbuggyQSA.push( "\\[" + whitespace + "*(?:value|" + booleans + ")" ); } // Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+ if ( !div.querySelectorAll( "[id~=" + expando + "-]" ).length ) { rbuggyQSA.push("~="); } // Webkit/Opera - :checked should return selected option elements // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked // IE8 throws error here and will not see later tests if ( !div.querySelectorAll(":checked").length ) { rbuggyQSA.push(":checked"); } // Support: Safari 8+, iOS 8+ // https://bugs.webkit.org/show_bug.cgi?id=136851 // In-page `selector#id sibing-combinator selector` fails if ( !div.querySelectorAll( "a#" + expando + "+*" ).length ) { rbuggyQSA.push(".#.+[+~]"); } }); assert(function( div ) { // Support: Windows 8 Native Apps // The type and name attributes are restricted during .innerHTML assignment var input = document.createElement("input"); input.setAttribute( "type", "hidden" ); div.appendChild( input ).setAttribute( "name", "D" ); // Support: IE8 // Enforce case-sensitivity of name attribute if ( div.querySelectorAll("[name=d]").length ) { rbuggyQSA.push( "name" + whitespace + "*[*^$|!~]?=" ); } // FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled) // IE8 throws error here and will not see later tests if ( !div.querySelectorAll(":enabled").length ) { rbuggyQSA.push( ":enabled", ":disabled" ); } // Opera 10-11 does not throw on post-comma invalid pseudos div.querySelectorAll("*,:x"); rbuggyQSA.push(",.*:"); }); } if ( (support.matchesSelector = rnative.test( (matches = docElem.matches || docElem.webkitMatchesSelector || docElem.mozMatchesSelector || docElem.oMatchesSelector || docElem.msMatchesSelector) )) ) { assert(function( div ) { // Check to see if it's possible to do matchesSelector // on a disconnected node (IE 9) support.disconnectedMatch = matches.call( div, "div" ); // This should fail with an exception // Gecko does not error, returns false instead matches.call( div, "[s!='']:x" ); rbuggyMatches.push( "!=", pseudos ); }); } rbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join("|") ); rbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join("|") ); /* Contains ---------------------------------------------------------------------- */ hasCompare = rnative.test( docElem.compareDocumentPosition ); // Element contains another // Purposefully self-exclusive // As in, an element does not contain itself contains = hasCompare || rnative.test( docElem.contains ) ? function( a, b ) { var adown = a.nodeType === 9 ? a.documentElement : a, bup = b && b.parentNode; return a === bup || !!( bup && bup.nodeType === 1 && ( adown.contains ? adown.contains( bup ) : a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16 )); } : function( a, b ) { if ( b ) { while ( (b = b.parentNode) ) { if ( b === a ) { return true; } } } return false; }; /* Sorting ---------------------------------------------------------------------- */ // Document order sorting sortOrder = hasCompare ? function( a, b ) { // Flag for duplicate removal if ( a === b ) { hasDuplicate = true; return 0; } // Sort on method existence if only one input has compareDocumentPosition var compare = !a.compareDocumentPosition - !b.compareDocumentPosition; if ( compare ) { return compare; } // Calculate position if both inputs belong to the same document compare = ( a.ownerDocument || a ) === ( b.ownerDocument || b ) ? a.compareDocumentPosition( b ) : // Otherwise we know they are disconnected 1; // Disconnected nodes if ( compare & 1 || (!support.sortDetached && b.compareDocumentPosition( a ) === compare) ) { // Choose the first element that is related to our preferred document if ( a === document || a.ownerDocument === preferredDoc && contains(preferredDoc, a) ) { return -1; } if ( b === document || b.ownerDocument === preferredDoc && contains(preferredDoc, b) ) { return 1; } // Maintain original order return sortInput ? ( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) : 0; } return compare & 4 ? -1 : 1; } : function( a, b ) { // Exit early if the nodes are identical if ( a === b ) { hasDuplicate = true; return 0; } var cur, i = 0, aup = a.parentNode, bup = b.parentNode, ap = [ a ], bp = [ b ]; // Parentless nodes are either documents or disconnected if ( !aup || !bup ) { return a === document ? -1 : b === document ? 1 : aup ? -1 : bup ? 1 : sortInput ? ( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) : 0; // If the nodes are siblings, we can do a quick check } else if ( aup === bup ) { return siblingCheck( a, b ); } // Otherwise we need full lists of their ancestors for comparison cur = a; while ( (cur = cur.parentNode) ) { ap.unshift( cur ); } cur = b; while ( (cur = cur.parentNode) ) { bp.unshift( cur ); } // Walk down the tree looking for a discrepancy while ( ap[i] === bp[i] ) { i++; } return i ? // Do a sibling check if the nodes have a common ancestor siblingCheck( ap[i], bp[i] ) : // Otherwise nodes in our document sort first ap[i] === preferredDoc ? -1 : bp[i] === preferredDoc ? 1 : 0; }; return document; }; Sizzle.matches = function( expr, elements ) { return Sizzle( expr, null, null, elements ); }; Sizzle.matchesSelector = function( elem, expr ) { // Set document vars if needed if ( ( elem.ownerDocument || elem ) !== document ) { setDocument( elem ); } // Make sure that attribute selectors are quoted expr = expr.replace( rattributeQuotes, "='$1']" ); if ( support.matchesSelector && documentIsHTML && !compilerCache[ expr + " " ] && ( !rbuggyMatches || !rbuggyMatches.test( expr ) ) && ( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) { try { var ret = matches.call( elem, expr ); // IE 9's matchesSelector returns false on disconnected nodes if ( ret || support.disconnectedMatch || // As well, disconnected nodes are said to be in a document // fragment in IE 9 elem.document && elem.document.nodeType !== 11 ) { return ret; } } catch (e) {} } return Sizzle( expr, document, null, [ elem ] ).length > 0; }; Sizzle.contains = function( context, elem ) { // Set document vars if needed if ( ( context.ownerDocument || context ) !== document ) { setDocument( context ); } return contains( context, elem ); }; Sizzle.attr = function( elem, name ) { // Set document vars if needed if ( ( elem.ownerDocument || elem ) !== document ) { setDocument( elem ); } var fn = Expr.attrHandle[ name.toLowerCase() ], // Don't get fooled by Object.prototype properties (jQuery #13807) val = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ? fn( elem, name, !documentIsHTML ) : undefined; return val !== undefined ? val : support.attributes || !documentIsHTML ? elem.getAttribute( name ) : (val = elem.getAttributeNode(name)) && val.specified ? val.value : null; }; Sizzle.error = function( msg ) { throw new Error( "Syntax error, unrecognized expression: " + msg ); }; /** * Document sorting and removing duplicates * @param {ArrayLike} results */ Sizzle.uniqueSort = function( results ) { var elem, duplicates = [], j = 0, i = 0; // Unless we *know* we can detect duplicates, assume their presence hasDuplicate = !support.detectDuplicates; sortInput = !support.sortStable && results.slice( 0 ); results.sort( sortOrder ); if ( hasDuplicate ) { while ( (elem = results[i++]) ) { if ( elem === results[ i ] ) { j = duplicates.push( i ); } } while ( j-- ) { results.splice( duplicates[ j ], 1 ); } } // Clear input after sorting to release objects // See https://github.com/jquery/sizzle/pull/225 sortInput = null; return results; }; /** * Utility function for retrieving the text value of an array of DOM nodes * @param {Array|Element} elem */ getText = Sizzle.getText = function( elem ) { var node, ret = "", i = 0, nodeType = elem.nodeType; if ( !nodeType ) { // If no nodeType, this is expected to be an array while ( (node = elem[i++]) ) { // Do not traverse comment nodes ret += getText( node ); } } else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) { // Use textContent for elements // innerText usage removed for consistency of new lines (jQuery #11153) if ( typeof elem.textContent === "string" ) { return elem.textContent; } else { // Traverse its children for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { ret += getText( elem ); } } } else if ( nodeType === 3 || nodeType === 4 ) { return elem.nodeValue; } // Do not include comment or processing instruction nodes return ret; }; Expr = Sizzle.selectors = { // Can be adjusted by the user cacheLength: 50, createPseudo: markFunction, match: matchExpr, attrHandle: {}, find: {}, relative: { ">": { dir: "parentNode", first: true }, " ": { dir: "parentNode" }, "+": { dir: "previousSibling", first: true }, "~": { dir: "previousSibling" } }, preFilter: { "ATTR": function( match ) { match[1] = match[1].replace( runescape, funescape ); // Move the given value to match[3] whether quoted or unquoted match[3] = ( match[3] || match[4] || match[5] || "" ).replace( runescape, funescape ); if ( match[2] === "~=" ) { match[3] = " " + match[3] + " "; } return match.slice( 0, 4 ); }, "CHILD": function( match ) { /* matches from matchExpr["CHILD"] 1 type (only|nth|...) 2 what (child|of-type) 3 argument (even|odd|\d*|\d*n([+-]\d+)?|...) 4 xn-component of xn+y argument ([+-]?\d*n|) 5 sign of xn-component 6 x of xn-component 7 sign of y-component 8 y of y-component */ match[1] = match[1].toLowerCase(); if ( match[1].slice( 0, 3 ) === "nth" ) { // nth-* requires argument if ( !match[3] ) { Sizzle.error( match[0] ); } // numeric x and y parameters for Expr.filter.CHILD // remember that false/true cast respectively to 0/1 match[4] = +( match[4] ? match[5] + (match[6] || 1) : 2 * ( match[3] === "even" || match[3] === "odd" ) ); match[5] = +( ( match[7] + match[8] ) || match[3] === "odd" ); // other types prohibit arguments } else if ( match[3] ) { Sizzle.error( match[0] ); } return match; }, "PSEUDO": function( match ) { var excess, unquoted = !match[6] && match[2]; if ( matchExpr["CHILD"].test( match[0] ) ) { return null; } // Accept quoted arguments as-is if ( match[3] ) { match[2] = match[4] || match[5] || ""; // Strip excess characters from unquoted arguments } else if ( unquoted && rpseudo.test( unquoted ) && // Get excess from tokenize (recursively) (excess = tokenize( unquoted, true )) && // advance to the next closing parenthesis (excess = unquoted.indexOf( ")", unquoted.length - excess ) - unquoted.length) ) { // excess is a negative index match[0] = match[0].slice( 0, excess ); match[2] = unquoted.slice( 0, excess ); } // Return only captures needed by the pseudo filter method (type and argument) return match.slice( 0, 3 ); } }, filter: { "TAG": function( nodeNameSelector ) { var nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase(); return nodeNameSelector === "*" ? function() { return true; } : function( elem ) { return elem.nodeName && elem.nodeName.toLowerCase() === nodeName; }; }, "CLASS": function( className ) { var pattern = classCache[ className + " " ]; return pattern || (pattern = new RegExp( "(^|" + whitespace + ")" + className + "(" + whitespace + "|$)" )) && classCache( className, function( elem ) { return pattern.test( typeof elem.className === "string" && elem.className || typeof elem.getAttribute !== "undefined" && elem.getAttribute("class") || "" ); }); }, "ATTR": function( name, operator, check ) { return function( elem ) { var result = Sizzle.attr( elem, name ); if ( result == null ) { return operator === "!="; } if ( !operator ) { return true; } result += ""; return operator === "=" ? result === check : operator === "!=" ? result !== check : operator === "^=" ? check && result.indexOf( check ) === 0 : operator === "*=" ? check && result.indexOf( check ) > -1 : operator === "$=" ? check && result.slice( -check.length ) === check : operator === "~=" ? ( " " + result.replace( rwhitespace, " " ) + " " ).indexOf( check ) > -1 : operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" : false; }; }, "CHILD": function( type, what, argument, first, last ) { var simple = type.slice( 0, 3 ) !== "nth", forward = type.slice( -4 ) !== "last", ofType = what === "of-type"; return first === 1 && last === 0 ? // Shortcut for :nth-*(n) function( elem ) { return !!elem.parentNode; } : function( elem, context, xml ) { var cache, uniqueCache, outerCache, node, nodeIndex, start, dir = simple !== forward ? "nextSibling" : "previousSibling", parent = elem.parentNode, name = ofType && elem.nodeName.toLowerCase(), useCache = !xml && !ofType, diff = false; if ( parent ) { // :(first|last|only)-(child|of-type) if ( simple ) { while ( dir ) { node = elem; while ( (node = node[ dir ]) ) { if ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) { return false; } } // Reverse direction for :only-* (if we haven't yet done so) start = dir = type === "only" && !start && "nextSibling"; } return true; } start = [ forward ? parent.firstChild : parent.lastChild ]; // non-xml :nth-child(...) stores cache data on `parent` if ( forward && useCache ) { // Seek `elem` from a previously-cached index // ...in a gzip-friendly way node = parent; outerCache = node[ expando ] || (node[ expando ] = {}); // Support: IE <9 only // Defend against cloned attroperties (jQuery gh-1709) uniqueCache = outerCache[ node.uniqueID ] || (outerCache[ node.uniqueID ] = {}); cache = uniqueCache[ type ] || []; nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ]; diff = nodeIndex && cache[ 2 ]; node = nodeIndex && parent.childNodes[ nodeIndex ]; while ( (node = ++nodeIndex && node && node[ dir ] || // Fallback to seeking `elem` from the start (diff = nodeIndex = 0) || start.pop()) ) { // When found, cache indexes on `parent` and break if ( node.nodeType === 1 && ++diff && node === elem ) { uniqueCache[ type ] = [ dirruns, nodeIndex, diff ]; break; } } } else { // Use previously-cached element index if available if ( useCache ) { // ...in a gzip-friendly way node = elem; outerCache = node[ expando ] || (node[ expando ] = {}); // Support: IE <9 only // Defend against cloned attroperties (jQuery gh-1709) uniqueCache = outerCache[ node.uniqueID ] || (outerCache[ node.uniqueID ] = {}); cache = uniqueCache[ type ] || []; nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ]; diff = nodeIndex; } // xml :nth-child(...) // or :nth-last-child(...) or :nth(-last)?-of-type(...) if ( diff === false ) { // Use the same loop as above to seek `elem` from the start while ( (node = ++nodeIndex && node && node[ dir ] || (diff = nodeIndex = 0) || start.pop()) ) { if ( ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) && ++diff ) { // Cache the index of each encountered element if ( useCache ) { outerCache = node[ expando ] || (node[ expando ] = {}); // Support: IE <9 only // Defend against cloned attroperties (jQuery gh-1709) uniqueCache = outerCache[ node.uniqueID ] || (outerCache[ node.uniqueID ] = {}); uniqueCache[ type ] = [ dirruns, diff ]; } if ( node === elem ) { break; } } } } } // Incorporate the offset, then check against cycle size diff -= last; return diff === first || ( diff % first === 0 && diff / first >= 0 ); } }; }, "PSEUDO": function( pseudo, argument ) { // pseudo-class names are case-insensitive // http://www.w3.org/TR/selectors/#pseudo-classes // Prioritize by case sensitivity in case custom pseudos are added with uppercase letters // Remember that setFilters inherits from pseudos var args, fn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] || Sizzle.error( "unsupported pseudo: " + pseudo ); // The user may use createPseudo to indicate that // arguments are needed to create the filter function // just as Sizzle does if ( fn[ expando ] ) { return fn( argument ); } // But maintain support for old signatures if ( fn.length > 1 ) { args = [ pseudo, pseudo, "", argument ]; return Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ? markFunction(function( seed, matches ) { var idx, matched = fn( seed, argument ), i = matched.length; while ( i-- ) { idx = indexOf( seed, matched[i] ); seed[ idx ] = !( matches[ idx ] = matched[i] ); } }) : function( elem ) { return fn( elem, 0, args ); }; } return fn; } }, pseudos: { // Potentially complex pseudos "not": markFunction(function( selector ) { // Trim the selector passed to compile // to avoid treating leading and trailing // spaces as combinators var input = [], results = [], matcher = compile( selector.replace( rtrim, "$1" ) ); return matcher[ expando ] ? markFunction(function( seed, matches, context, xml ) { var elem, unmatched = matcher( seed, null, xml, [] ), i = seed.length; // Match elements unmatched by `matcher` while ( i-- ) { if ( (elem = unmatched[i]) ) { seed[i] = !(matches[i] = elem); } } }) : function( elem, context, xml ) { input[0] = elem; matcher( input, null, xml, results ); // Don't keep the element (issue #299) input[0] = null; return !results.pop(); }; }), "has": markFunction(function( selector ) { return function( elem ) { return Sizzle( selector, elem ).length > 0; }; }), "contains": markFunction(function( text ) { text = text.replace( runescape, funescape ); return function( elem ) { return ( elem.textContent || elem.innerText || getText( elem ) ).indexOf( text ) > -1; }; }), // "Whether an element is represented by a :lang() selector // is based solely on the element's language value // being equal to the identifier C, // or beginning with the identifier C immediately followed by "-". // The matching of C against the element's language value is performed case-insensitively. // The identifier C does not have to be a valid language name." // http://www.w3.org/TR/selectors/#lang-pseudo "lang": markFunction( function( lang ) { // lang value must be a valid identifier if ( !ridentifier.test(lang || "") ) { Sizzle.error( "unsupported lang: " + lang ); } lang = lang.replace( runescape, funescape ).toLowerCase(); return function( elem ) { var elemLang; do { if ( (elemLang = documentIsHTML ? elem.lang : elem.getAttribute("xml:lang") || elem.getAttribute("lang")) ) { elemLang = elemLang.toLowerCase(); return elemLang === lang || elemLang.indexOf( lang + "-" ) === 0; } } while ( (elem = elem.parentNode) && elem.nodeType === 1 ); return false; }; }), // Miscellaneous "target": function( elem ) { var hash = window.location && window.location.hash; return hash && hash.slice( 1 ) === elem.id; }, "root": function( elem ) { return elem === docElem; }, "focus": function( elem ) { return elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex); }, // Boolean properties "enabled": function( elem ) { return elem.disabled === false; }, "disabled": function( elem ) { return elem.disabled === true; }, "checked": function( elem ) { // In CSS3, :checked should return both checked and selected elements // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked var nodeName = elem.nodeName.toLowerCase(); return (nodeName === "input" && !!elem.checked) || (nodeName === "option" && !!elem.selected); }, "selected": function( elem ) { // Accessing this property makes selected-by-default // options in Safari work properly if ( elem.parentNode ) { elem.parentNode.selectedIndex; } return elem.selected === true; }, // Contents "empty": function( elem ) { // http://www.w3.org/TR/selectors/#empty-pseudo // :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5), // but not by others (comment: 8; processing instruction: 7; etc.) // nodeType < 6 works because attributes (2) do not appear as children for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { if ( elem.nodeType < 6 ) { return false; } } return true; }, "parent": function( elem ) { return !Expr.pseudos["empty"]( elem ); }, // Element/input types "header": function( elem ) { return rheader.test( elem.nodeName ); }, "input": function( elem ) { return rinputs.test( elem.nodeName ); }, "button": function( elem ) { var name = elem.nodeName.toLowerCase(); return name === "input" && elem.type === "button" || name === "button"; }, "text": function( elem ) { var attr; return elem.nodeName.toLowerCase() === "input" && elem.type === "text" && // Support: IE<8 // New HTML5 attribute values (e.g., "search") appear with elem.type === "text" ( (attr = elem.getAttribute("type")) == null || attr.toLowerCase() === "text" ); }, // Position-in-collection "first": createPositionalPseudo(function() { return [ 0 ]; }), "last": createPositionalPseudo(function( matchIndexes, length ) { return [ length - 1 ]; }), "eq": createPositionalPseudo(function( matchIndexes, length, argument ) { return [ argument < 0 ? argument + length : argument ]; }), "even": createPositionalPseudo(function( matchIndexes, length ) { var i = 0; for ( ; i < length; i += 2 ) { matchIndexes.push( i ); } return matchIndexes; }), "odd": createPositionalPseudo(function( matchIndexes, length ) { var i = 1; for ( ; i < length; i += 2 ) { matchIndexes.push( i ); } return matchIndexes; }), "lt": createPositionalPseudo(function( matchIndexes, length, argument ) { var i = argument < 0 ? argument + length : argument; for ( ; --i >= 0; ) { matchIndexes.push( i ); } return matchIndexes; }), "gt": createPositionalPseudo(function( matchIndexes, length, argument ) { var i = argument < 0 ? argument + length : argument; for ( ; ++i < length; ) { matchIndexes.push( i ); } return matchIndexes; }) } }; Expr.pseudos["nth"] = Expr.pseudos["eq"]; // Add button/input type pseudos for ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) { Expr.pseudos[ i ] = createInputPseudo( i ); } for ( i in { submit: true, reset: true } ) { Expr.pseudos[ i ] = createButtonPseudo( i ); } // Easy API for creating new setFilters function setFilters() {} setFilters.prototype = Expr.filters = Expr.pseudos; Expr.setFilters = new setFilters(); tokenize = Sizzle.tokenize = function( selector, parseOnly ) { var matched, match, tokens, type, soFar, groups, preFilters, cached = tokenCache[ selector + " " ]; if ( cached ) { return parseOnly ? 0 : cached.slice( 0 ); } soFar = selector; groups = []; preFilters = Expr.preFilter; while ( soFar ) { // Comma and first run if ( !matched || (match = rcomma.exec( soFar )) ) { if ( match ) { // Don't consume trailing commas as valid soFar = soFar.slice( match[0].length ) || soFar; } groups.push( (tokens = []) ); } matched = false; // Combinators if ( (match = rcombinators.exec( soFar )) ) { matched = match.shift(); tokens.push({ value: matched, // Cast descendant combinators to space type: match[0].replace( rtrim, " " ) }); soFar = soFar.slice( matched.length ); } // Filters for ( type in Expr.filter ) { if ( (match = matchExpr[ type ].exec( soFar )) && (!preFilters[ type ] || (match = preFilters[ type ]( match ))) ) { matched = match.shift(); tokens.push({ value: matched, type: type, matches: match }); soFar = soFar.slice( matched.length ); } } if ( !matched ) { break; } } // Return the length of the invalid excess // if we're just parsing // Otherwise, throw an error or return tokens return parseOnly ? soFar.length : soFar ? Sizzle.error( selector ) : // Cache the tokens tokenCache( selector, groups ).slice( 0 ); }; function toSelector( tokens ) { var i = 0, len = tokens.length, selector = ""; for ( ; i < len; i++ ) { selector += tokens[i].value; } return selector; } function addCombinator( matcher, combinator, base ) { var dir = combinator.dir, checkNonElements = base && dir === "parentNode", doneName = done++; return combinator.first ? // Check against closest ancestor/preceding element function( elem, context, xml ) { while ( (elem = elem[ dir ]) ) { if ( elem.nodeType === 1 || checkNonElements ) { return matcher( elem, context, xml ); } } } : // Check against all ancestor/preceding elements function( elem, context, xml ) { var oldCache, uniqueCache, outerCache, newCache = [ dirruns, doneName ]; // We can't set arbitrary data on XML nodes, so they don't benefit from combinator caching if ( xml ) { while ( (elem = elem[ dir ]) ) { if ( elem.nodeType === 1 || checkNonElements ) { if ( matcher( elem, context, xml ) ) { return true; } } } } else { while ( (elem = elem[ dir ]) ) { if ( elem.nodeType === 1 || checkNonElements ) { outerCache = elem[ expando ] || (elem[ expando ] = {}); // Support: IE <9 only // Defend against cloned attroperties (jQuery gh-1709) uniqueCache = outerCache[ elem.uniqueID ] || (outerCache[ elem.uniqueID ] = {}); if ( (oldCache = uniqueCache[ dir ]) && oldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) { // Assign to newCache so results back-propagate to previous elements return (newCache[ 2 ] = oldCache[ 2 ]); } else { // Reuse newcache so results back-propagate to previous elements uniqueCache[ dir ] = newCache; // A match means we're done; a fail means we have to keep checking if ( (newCache[ 2 ] = matcher( elem, context, xml )) ) { return true; } } } } } }; } function elementMatcher( matchers ) { return matchers.length > 1 ? function( elem, context, xml ) { var i = matchers.length; while ( i-- ) { if ( !matchers[i]( elem, context, xml ) ) { return false; } } return true; } : matchers[0]; } function multipleContexts( selector, contexts, results ) { var i = 0, len = contexts.length; for ( ; i < len; i++ ) { Sizzle( selector, contexts[i], results ); } return results; } function condense( unmatched, map, filter, context, xml ) { var elem, newUnmatched = [], i = 0, len = unmatched.length, mapped = map != null; for ( ; i < len; i++ ) { if ( (elem = unmatched[i]) ) { if ( !filter || filter( elem, context, xml ) ) { newUnmatched.push( elem ); if ( mapped ) { map.push( i ); } } } } return newUnmatched; } function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) { if ( postFilter && !postFilter[ expando ] ) { postFilter = setMatcher( postFilter ); } if ( postFinder && !postFinder[ expando ] ) { postFinder = setMatcher( postFinder, postSelector ); } return markFunction(function( seed, results, context, xml ) { var temp, i, elem, preMap = [], postMap = [], preexisting = results.length, // Get initial elements from seed or context elems = seed || multipleContexts( selector || "*", context.nodeType ? [ context ] : context, [] ), // Prefilter to get matcher input, preserving a map for seed-results synchronization matcherIn = preFilter && ( seed || !selector ) ? condense( elems, preMap, preFilter, context, xml ) : elems, matcherOut = matcher ? // If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results, postFinder || ( seed ? preFilter : preexisting || postFilter ) ? // ...intermediate processing is necessary [] : // ...otherwise use results directly results : matcherIn; // Find primary matches if ( matcher ) { matcher( matcherIn, matcherOut, context, xml ); } // Apply postFilter if ( postFilter ) { temp = condense( matcherOut, postMap ); postFilter( temp, [], context, xml ); // Un-match failing elements by moving them back to matcherIn i = temp.length; while ( i-- ) { if ( (elem = temp[i]) ) { matcherOut[ postMap[i] ] = !(matcherIn[ postMap[i] ] = elem); } } } if ( seed ) { if ( postFinder || preFilter ) { if ( postFinder ) { // Get the final matcherOut by condensing this intermediate into postFinder contexts temp = []; i = matcherOut.length; while ( i-- ) { if ( (elem = matcherOut[i]) ) { // Restore matcherIn since elem is not yet a final match temp.push( (matcherIn[i] = elem) ); } } postFinder( null, (matcherOut = []), temp, xml ); } // Move matched elements from seed to results to keep them synchronized i = matcherOut.length; while ( i-- ) { if ( (elem = matcherOut[i]) && (temp = postFinder ? indexOf( seed, elem ) : preMap[i]) > -1 ) { seed[temp] = !(results[temp] = elem); } } } // Add elements to results, through postFinder if defined } else { matcherOut = condense( matcherOut === results ? matcherOut.splice( preexisting, matcherOut.length ) : matcherOut ); if ( postFinder ) { postFinder( null, results, matcherOut, xml ); } else { push.apply( results, matcherOut ); } } }); } function matcherFromTokens( tokens ) { var checkContext, matcher, j, len = tokens.length, leadingRelative = Expr.relative[ tokens[0].type ], implicitRelative = leadingRelative || Expr.relative[" "], i = leadingRelative ? 1 : 0, // The foundational matcher ensures that elements are reachable from top-level context(s) matchContext = addCombinator( function( elem ) { return elem === checkContext; }, implicitRelative, true ), matchAnyContext = addCombinator( function( elem ) { return indexOf( checkContext, elem ) > -1; }, implicitRelative, true ), matchers = [ function( elem, context, xml ) { var ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || ( (checkContext = context).nodeType ? matchContext( elem, context, xml ) : matchAnyContext( elem, context, xml ) ); // Avoid hanging onto element (issue #299) checkContext = null; return ret; } ]; for ( ; i < len; i++ ) { if ( (matcher = Expr.relative[ tokens[i].type ]) ) { matchers = [ addCombinator(elementMatcher( matchers ), matcher) ]; } else { matcher = Expr.filter[ tokens[i].type ].apply( null, tokens[i].matches ); // Return special upon seeing a positional matcher if ( matcher[ expando ] ) { // Find the next relative operator (if any) for proper handling j = ++i; for ( ; j < len; j++ ) { if ( Expr.relative[ tokens[j].type ] ) { break; } } return setMatcher( i > 1 && elementMatcher( matchers ), i > 1 && toSelector( // If the preceding token was a descendant combinator, insert an implicit any-element `*` tokens.slice( 0, i - 1 ).concat({ value: tokens[ i - 2 ].type === " " ? "*" : "" }) ).replace( rtrim, "$1" ), matcher, i < j && matcherFromTokens( tokens.slice( i, j ) ), j < len && matcherFromTokens( (tokens = tokens.slice( j )) ), j < len && toSelector( tokens ) ); } matchers.push( matcher ); } } return elementMatcher( matchers ); } function matcherFromGroupMatchers( elementMatchers, setMatchers ) { var bySet = setMatchers.length > 0, byElement = elementMatchers.length > 0, superMatcher = function( seed, context, xml, results, outermost ) { var elem, j, matcher, matchedCount = 0, i = "0", unmatched = seed && [], setMatched = [], contextBackup = outermostContext, // We must always have either seed elements or outermost context elems = seed || byElement && Expr.find["TAG"]( "*", outermost ), // Use integer dirruns iff this is the outermost matcher dirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1), len = elems.length; if ( outermost ) { outermostContext = context === document || context || outermost; } // Add elements passing elementMatchers directly to results // Support: IE<9, Safari // Tolerate NodeList properties (IE: "length"; Safari: ) matching elements by id for ( ; i !== len && (elem = elems[i]) != null; i++ ) { if ( byElement && elem ) { j = 0; if ( !context && elem.ownerDocument !== document ) { setDocument( elem ); xml = !documentIsHTML; } while ( (matcher = elementMatchers[j++]) ) { if ( matcher( elem, context || document, xml) ) { results.push( elem ); break; } } if ( outermost ) { dirruns = dirrunsUnique; } } // Track unmatched elements for set filters if ( bySet ) { // They will have gone through all possible matchers if ( (elem = !matcher && elem) ) { matchedCount--; } // Lengthen the array for every element, matched or not if ( seed ) { unmatched.push( elem ); } } } // `i` is now the count of elements visited above, and adding it to `matchedCount` // makes the latter nonnegative. matchedCount += i; // Apply set filters to unmatched elements // NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount` // equals `i`), unless we didn't visit _any_ elements in the above loop because we have // no element matchers and no seed. // Incrementing an initially-string "0" `i` allows `i` to remain a string only in that // case, which will result in a "00" `matchedCount` that differs from `i` but is also // numerically zero. if ( bySet && i !== matchedCount ) { j = 0; while ( (matcher = setMatchers[j++]) ) { matcher( unmatched, setMatched, context, xml ); } if ( seed ) { // Reintegrate element matches to eliminate the need for sorting if ( matchedCount > 0 ) { while ( i-- ) { if ( !(unmatched[i] || setMatched[i]) ) { setMatched[i] = pop.call( results ); } } } // Discard index placeholder values to get only actual matches setMatched = condense( setMatched ); } // Add matches to results push.apply( results, setMatched ); // Seedless set matches succeeding multiple successful matchers stipulate sorting if ( outermost && !seed && setMatched.length > 0 && ( matchedCount + setMatchers.length ) > 1 ) { Sizzle.uniqueSort( results ); } } // Override manipulation of globals by nested matchers if ( outermost ) { dirruns = dirrunsUnique; outermostContext = contextBackup; } return unmatched; }; return bySet ? markFunction( superMatcher ) : superMatcher; } compile = Sizzle.compile = function( selector, match /* Internal Use Only */ ) { var i, setMatchers = [], elementMatchers = [], cached = compilerCache[ selector + " " ]; if ( !cached ) { // Generate a function of recursive functions that can be used to check each element if ( !match ) { match = tokenize( selector ); } i = match.length; while ( i-- ) { cached = matcherFromTokens( match[i] ); if ( cached[ expando ] ) { setMatchers.push( cached ); } else { elementMatchers.push( cached ); } } // Cache the compiled function cached = compilerCache( selector, matcherFromGroupMatchers( elementMatchers, setMatchers ) ); // Save selector and tokenization cached.selector = selector; } return cached; }; /** * A low-level selection function that works with Sizzle's compiled * selector functions * @param {String|Function} selector A selector or a pre-compiled * selector function built with Sizzle.compile * @param {Element} context * @param {Array} [results] * @param {Array} [seed] A set of elements to match against */ select = Sizzle.select = function( selector, context, results, seed ) { var i, tokens, token, type, find, compiled = typeof selector === "function" && selector, match = !seed && tokenize( (selector = compiled.selector || selector) ); results = results || []; // Try to minimize operations if there is only one selector in the list and no seed // (the latter of which guarantees us context) if ( match.length === 1 ) { // Reduce context if the leading compound selector is an ID tokens = match[0] = match[0].slice( 0 ); if ( tokens.length > 2 && (token = tokens[0]).type === "ID" && support.getById && context.nodeType === 9 && documentIsHTML && Expr.relative[ tokens[1].type ] ) { context = ( Expr.find["ID"]( token.matches[0].replace(runescape, funescape), context ) || [] )[0]; if ( !context ) { return results; // Precompiled matchers will still verify ancestry, so step up a level } else if ( compiled ) { context = context.parentNode; } selector = selector.slice( tokens.shift().value.length ); } // Fetch a seed set for right-to-left matching i = matchExpr["needsContext"].test( selector ) ? 0 : tokens.length; while ( i-- ) { token = tokens[i]; // Abort if we hit a combinator if ( Expr.relative[ (type = token.type) ] ) { break; } if ( (find = Expr.find[ type ]) ) { // Search, expanding context for leading sibling combinators if ( (seed = find( token.matches[0].replace( runescape, funescape ), rsibling.test( tokens[0].type ) && testContext( context.parentNode ) || context )) ) { // If seed is empty or no tokens remain, we can return early tokens.splice( i, 1 ); selector = seed.length && toSelector( tokens ); if ( !selector ) { push.apply( results, seed ); return results; } break; } } } } // Compile and execute a filtering function if one is not provided // Provide `match` to avoid retokenization if we modified the selector above ( compiled || compile( selector, match ) )( seed, context, !documentIsHTML, results, !context || rsibling.test( selector ) && testContext( context.parentNode ) || context ); return results; }; // One-time assignments // Sort stability support.sortStable = expando.split("").sort( sortOrder ).join("") === expando; // Support: Chrome 14-35+ // Always assume duplicates if they aren't passed to the comparison function support.detectDuplicates = !!hasDuplicate; // Initialize against the default document setDocument(); // Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27) // Detached nodes confoundingly follow *each other* support.sortDetached = assert(function( div1 ) { // Should return 1, but returns 4 (following) return div1.compareDocumentPosition( document.createElement("div") ) & 1; }); // Support: IE<8 // Prevent attribute/property "interpolation" // http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx if ( !assert(function( div ) { div.innerHTML = ""; return div.firstChild.getAttribute("href") === "#" ; }) ) { addHandle( "type|href|height|width", function( elem, name, isXML ) { if ( !isXML ) { return elem.getAttribute( name, name.toLowerCase() === "type" ? 1 : 2 ); } }); } // Support: IE<9 // Use defaultValue in place of getAttribute("value") if ( !support.attributes || !assert(function( div ) { div.innerHTML = ""; div.firstChild.setAttribute( "value", "" ); return div.firstChild.getAttribute( "value" ) === ""; }) ) { addHandle( "value", function( elem, name, isXML ) { if ( !isXML && elem.nodeName.toLowerCase() === "input" ) { return elem.defaultValue; } }); } // Support: IE<9 // Use getAttributeNode to fetch booleans when getAttribute lies if ( !assert(function( div ) { return div.getAttribute("disabled") == null; }) ) { addHandle( booleans, function( elem, name, isXML ) { var val; if ( !isXML ) { return elem[ name ] === true ? name.toLowerCase() : (val = elem.getAttributeNode( name )) && val.specified ? val.value : null; } }); } return Sizzle; })( window ); jQuery.find = Sizzle; jQuery.expr = Sizzle.selectors; jQuery.expr[ ":" ] = jQuery.expr.pseudos; jQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort; jQuery.text = Sizzle.getText; jQuery.isXMLDoc = Sizzle.isXML; jQuery.contains = Sizzle.contains; var dir = function( elem, dir, until ) { var matched = [], truncate = until !== undefined; while ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) { if ( elem.nodeType === 1 ) { if ( truncate && jQuery( elem ).is( until ) ) { break; } matched.push( elem ); } } return matched; }; var siblings = function( n, elem ) { var matched = []; for ( ; n; n = n.nextSibling ) { if ( n.nodeType === 1 && n !== elem ) { matched.push( n ); } } return matched; }; var rneedsContext = jQuery.expr.match.needsContext; var rsingleTag = ( /^<([\w-]+)\s*\/?>(?:<\/\1>|)$/ ); var risSimple = /^.[^:#\[\.,]*$/; // Implement the identical functionality for filter and not function winnow( elements, qualifier, not ) { if ( jQuery.isFunction( qualifier ) ) { return jQuery.grep( elements, function( elem, i ) { /* jshint -W018 */ return !!qualifier.call( elem, i, elem ) !== not; } ); } if ( qualifier.nodeType ) { return jQuery.grep( elements, function( elem ) { return ( elem === qualifier ) !== not; } ); } if ( typeof qualifier === "string" ) { if ( risSimple.test( qualifier ) ) { return jQuery.filter( qualifier, elements, not ); } qualifier = jQuery.filter( qualifier, elements ); } return jQuery.grep( elements, function( elem ) { return ( jQuery.inArray( elem, qualifier ) > -1 ) !== not; } ); } jQuery.filter = function( expr, elems, not ) { var elem = elems[ 0 ]; if ( not ) { expr = ":not(" + expr + ")"; } return elems.length === 1 && elem.nodeType === 1 ? jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [] : jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) { return elem.nodeType === 1; } ) ); }; jQuery.fn.extend( { find: function( selector ) { var i, ret = [], self = this, len = self.length; if ( typeof selector !== "string" ) { return this.pushStack( jQuery( selector ).filter( function() { for ( i = 0; i < len; i++ ) { if ( jQuery.contains( self[ i ], this ) ) { return true; } } } ) ); } for ( i = 0; i < len; i++ ) { jQuery.find( selector, self[ i ], ret ); } // Needed because $( selector, context ) becomes $( context ).find( selector ) ret = this.pushStack( len > 1 ? jQuery.unique( ret ) : ret ); ret.selector = this.selector ? this.selector + " " + selector : selector; return ret; }, filter: function( selector ) { return this.pushStack( winnow( this, selector || [], false ) ); }, not: function( selector ) { return this.pushStack( winnow( this, selector || [], true ) ); }, is: function( selector ) { return !!winnow( this, // If this is a positional/relative selector, check membership in the returned set // so $("p:first").is("p:last") won't return true for a doc with two "p". typeof selector === "string" && rneedsContext.test( selector ) ? jQuery( selector ) : selector || [], false ).length; } } ); // Initialize a jQuery object // A central reference to the root jQuery(document) var rootjQuery, // A simple way to check for HTML strings // Prioritize #id over to avoid XSS via location.hash (#9521) // Strict HTML recognition (#11290: must start with <) rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/, init = jQuery.fn.init = function( selector, context, root ) { var match, elem; // HANDLE: $(""), $(null), $(undefined), $(false) if ( !selector ) { return this; } // init accepts an alternate rootjQuery // so migrate can support jQuery.sub (gh-2101) root = root || rootjQuery; // Handle HTML strings if ( typeof selector === "string" ) { if ( selector.charAt( 0 ) === "<" && selector.charAt( selector.length - 1 ) === ">" && selector.length >= 3 ) { // Assume that strings that start and end with <> are HTML and skip the regex check match = [ null, selector, null ]; } else { match = rquickExpr.exec( selector ); } // Match html or make sure no context is specified for #id if ( match && ( match[ 1 ] || !context ) ) { // HANDLE: $(html) -> $(array) if ( match[ 1 ] ) { context = context instanceof jQuery ? context[ 0 ] : context; // scripts is true for back-compat // Intentionally let the error be thrown if parseHTML is not present jQuery.merge( this, jQuery.parseHTML( match[ 1 ], context && context.nodeType ? context.ownerDocument || context : document, true ) ); // HANDLE: $(html, props) if ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) { for ( match in context ) { // Properties of context are called as methods if possible if ( jQuery.isFunction( this[ match ] ) ) { this[ match ]( context[ match ] ); // ...and otherwise set as attributes } else { this.attr( match, context[ match ] ); } } } return this; // HANDLE: $(#id) } else { elem = document.getElementById( match[ 2 ] ); // Check parentNode to catch when Blackberry 4.6 returns // nodes that are no longer in the document #6963 if ( elem && elem.parentNode ) { // Handle the case where IE and Opera return items // by name instead of ID if ( elem.id !== match[ 2 ] ) { return rootjQuery.find( selector ); } // Otherwise, we inject the element directly into the jQuery object this.length = 1; this[ 0 ] = elem; } this.context = document; this.selector = selector; return this; } // HANDLE: $(expr, $(...)) } else if ( !context || context.jquery ) { return ( context || root ).find( selector ); // HANDLE: $(expr, context) // (which is just equivalent to: $(context).find(expr) } else { return this.constructor( context ).find( selector ); } // HANDLE: $(DOMElement) } else if ( selector.nodeType ) { this.context = this[ 0 ] = selector; this.length = 1; return this; // HANDLE: $(function) // Shortcut for document ready } else if ( jQuery.isFunction( selector ) ) { return typeof root.ready !== "undefined" ? root.ready( selector ) : // Execute immediately if ready is not present selector( jQuery ); } if ( selector.selector !== undefined ) { this.selector = selector.selector; this.context = selector.context; } return jQuery.makeArray( selector, this ); }; // Give the init function the jQuery prototype for later instantiation init.prototype = jQuery.fn; // Initialize central reference rootjQuery = jQuery( document ); var rparentsprev = /^(?:parents|prev(?:Until|All))/, // methods guaranteed to produce a unique set when starting from a unique set guaranteedUnique = { children: true, contents: true, next: true, prev: true }; jQuery.fn.extend( { has: function( target ) { var i, targets = jQuery( target, this ), len = targets.length; return this.filter( function() { for ( i = 0; i < len; i++ ) { if ( jQuery.contains( this, targets[ i ] ) ) { return true; } } } ); }, closest: function( selectors, context ) { var cur, i = 0, l = this.length, matched = [], pos = rneedsContext.test( selectors ) || typeof selectors !== "string" ? jQuery( selectors, context || this.context ) : 0; for ( ; i < l; i++ ) { for ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) { // Always skip document fragments if ( cur.nodeType < 11 && ( pos ? pos.index( cur ) > -1 : // Don't pass non-elements to Sizzle cur.nodeType === 1 && jQuery.find.matchesSelector( cur, selectors ) ) ) { matched.push( cur ); break; } } } return this.pushStack( matched.length > 1 ? jQuery.uniqueSort( matched ) : matched ); }, // Determine the position of an element within // the matched set of elements index: function( elem ) { // No argument, return index in parent if ( !elem ) { return ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1; } // index in selector if ( typeof elem === "string" ) { return jQuery.inArray( this[ 0 ], jQuery( elem ) ); } // Locate the position of the desired element return jQuery.inArray( // If it receives a jQuery object, the first element is used elem.jquery ? elem[ 0 ] : elem, this ); }, add: function( selector, context ) { return this.pushStack( jQuery.uniqueSort( jQuery.merge( this.get(), jQuery( selector, context ) ) ) ); }, addBack: function( selector ) { return this.add( selector == null ? this.prevObject : this.prevObject.filter( selector ) ); } } ); function sibling( cur, dir ) { do { cur = cur[ dir ]; } while ( cur && cur.nodeType !== 1 ); return cur; } jQuery.each( { parent: function( elem ) { var parent = elem.parentNode; return parent && parent.nodeType !== 11 ? parent : null; }, parents: function( elem ) { return dir( elem, "parentNode" ); }, parentsUntil: function( elem, i, until ) { return dir( elem, "parentNode", until ); }, next: function( elem ) { return sibling( elem, "nextSibling" ); }, prev: function( elem ) { return sibling( elem, "previousSibling" ); }, nextAll: function( elem ) { return dir( elem, "nextSibling" ); }, prevAll: function( elem ) { return dir( elem, "previousSibling" ); }, nextUntil: function( elem, i, until ) { return dir( elem, "nextSibling", until ); }, prevUntil: function( elem, i, until ) { return dir( elem, "previousSibling", until ); }, siblings: function( elem ) { return siblings( ( elem.parentNode || {} ).firstChild, elem ); }, children: function( elem ) { return siblings( elem.firstChild ); }, contents: function( elem ) { return jQuery.nodeName( elem, "iframe" ) ? elem.contentDocument || elem.contentWindow.document : jQuery.merge( [], elem.childNodes ); } }, function( name, fn ) { jQuery.fn[ name ] = function( until, selector ) { var ret = jQuery.map( this, fn, until ); if ( name.slice( -5 ) !== "Until" ) { selector = until; } if ( selector && typeof selector === "string" ) { ret = jQuery.filter( selector, ret ); } if ( this.length > 1 ) { // Remove duplicates if ( !guaranteedUnique[ name ] ) { ret = jQuery.uniqueSort( ret ); } // Reverse order for parents* and prev-derivatives if ( rparentsprev.test( name ) ) { ret = ret.reverse(); } } return this.pushStack( ret ); }; } ); var rnotwhite = ( /\S+/g ); // Convert String-formatted options into Object-formatted ones function createOptions( options ) { var object = {}; jQuery.each( options.match( rnotwhite ) || [], function( _, flag ) { object[ flag ] = true; } ); return object; } /* * Create a callback list using the following parameters: * * options: an optional list of space-separated options that will change how * the callback list behaves or a more traditional option object * * By default a callback list will act like an event callback list and can be * "fired" multiple times. * * Possible options: * * once: will ensure the callback list can only be fired once (like a Deferred) * * memory: will keep track of previous values and will call any callback added * after the list has been fired right away with the latest "memorized" * values (like a Deferred) * * unique: will ensure a callback can only be added once (no duplicate in the list) * * stopOnFalse: interrupt callings when a callback returns false * */ jQuery.Callbacks = function( options ) { // Convert options from String-formatted to Object-formatted if needed // (we check in cache first) options = typeof options === "string" ? createOptions( options ) : jQuery.extend( {}, options ); var // Flag to know if list is currently firing firing, // Last fire value for non-forgettable lists memory, // Flag to know if list was already fired fired, // Flag to prevent firing locked, // Actual callback list list = [], // Queue of execution data for repeatable lists queue = [], // Index of currently firing callback (modified by add/remove as needed) firingIndex = -1, // Fire callbacks fire = function() { // Enforce single-firing locked = options.once; // Execute callbacks for all pending executions, // respecting firingIndex overrides and runtime changes fired = firing = true; for ( ; queue.length; firingIndex = -1 ) { memory = queue.shift(); while ( ++firingIndex < list.length ) { // Run callback and check for early termination if ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false && options.stopOnFalse ) { // Jump to end and forget the data so .add doesn't re-fire firingIndex = list.length; memory = false; } } } // Forget the data if we're done with it if ( !options.memory ) { memory = false; } firing = false; // Clean up if we're done firing for good if ( locked ) { // Keep an empty list if we have data for future add calls if ( memory ) { list = []; // Otherwise, this object is spent } else { list = ""; } } }, // Actual Callbacks object self = { // Add a callback or a collection of callbacks to the list add: function() { if ( list ) { // If we have memory from a past run, we should fire after adding if ( memory && !firing ) { firingIndex = list.length - 1; queue.push( memory ); } ( function add( args ) { jQuery.each( args, function( _, arg ) { if ( jQuery.isFunction( arg ) ) { if ( !options.unique || !self.has( arg ) ) { list.push( arg ); } } else if ( arg && arg.length && jQuery.type( arg ) !== "string" ) { // Inspect recursively add( arg ); } } ); } )( arguments ); if ( memory && !firing ) { fire(); } } return this; }, // Remove a callback from the list remove: function() { jQuery.each( arguments, function( _, arg ) { var index; while ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { list.splice( index, 1 ); // Handle firing indexes if ( index <= firingIndex ) { firingIndex--; } } } ); return this; }, // Check if a given callback is in the list. // If no argument is given, return whether or not list has callbacks attached. has: function( fn ) { return fn ? jQuery.inArray( fn, list ) > -1 : list.length > 0; }, // Remove all callbacks from the list empty: function() { if ( list ) { list = []; } return this; }, // Disable .fire and .add // Abort any current/pending executions // Clear all callbacks and values disable: function() { locked = queue = []; list = memory = ""; return this; }, disabled: function() { return !list; }, // Disable .fire // Also disable .add unless we have memory (since it would have no effect) // Abort any pending executions lock: function() { locked = true; if ( !memory ) { self.disable(); } return this; }, locked: function() { return !!locked; }, // Call all callbacks with the given context and arguments fireWith: function( context, args ) { if ( !locked ) { args = args || []; args = [ context, args.slice ? args.slice() : args ]; queue.push( args ); if ( !firing ) { fire(); } } return this; }, // Call all the callbacks with the given arguments fire: function() { self.fireWith( this, arguments ); return this; }, // To know if the callbacks have already been called at least once fired: function() { return !!fired; } }; return self; }; jQuery.extend( { Deferred: function( func ) { var tuples = [ // action, add listener, listener list, final state [ "resolve", "done", jQuery.Callbacks( "once memory" ), "resolved" ], [ "reject", "fail", jQuery.Callbacks( "once memory" ), "rejected" ], [ "notify", "progress", jQuery.Callbacks( "memory" ) ] ], state = "pending", promise = { state: function() { return state; }, always: function() { deferred.done( arguments ).fail( arguments ); return this; }, then: function( /* fnDone, fnFail, fnProgress */ ) { var fns = arguments; return jQuery.Deferred( function( newDefer ) { jQuery.each( tuples, function( i, tuple ) { var fn = jQuery.isFunction( fns[ i ] ) && fns[ i ]; // deferred[ done | fail | progress ] for forwarding actions to newDefer deferred[ tuple[ 1 ] ]( function() { var returned = fn && fn.apply( this, arguments ); if ( returned && jQuery.isFunction( returned.promise ) ) { returned.promise() .progress( newDefer.notify ) .done( newDefer.resolve ) .fail( newDefer.reject ); } else { newDefer[ tuple[ 0 ] + "With" ]( this === promise ? newDefer.promise() : this, fn ? [ returned ] : arguments ); } } ); } ); fns = null; } ).promise(); }, // Get a promise for this deferred // If obj is provided, the promise aspect is added to the object promise: function( obj ) { return obj != null ? jQuery.extend( obj, promise ) : promise; } }, deferred = {}; // Keep pipe for back-compat promise.pipe = promise.then; // Add list-specific methods jQuery.each( tuples, function( i, tuple ) { var list = tuple[ 2 ], stateString = tuple[ 3 ]; // promise[ done | fail | progress ] = list.add promise[ tuple[ 1 ] ] = list.add; // Handle state if ( stateString ) { list.add( function() { // state = [ resolved | rejected ] state = stateString; // [ reject_list | resolve_list ].disable; progress_list.lock }, tuples[ i ^ 1 ][ 2 ].disable, tuples[ 2 ][ 2 ].lock ); } // deferred[ resolve | reject | notify ] deferred[ tuple[ 0 ] ] = function() { deferred[ tuple[ 0 ] + "With" ]( this === deferred ? promise : this, arguments ); return this; }; deferred[ tuple[ 0 ] + "With" ] = list.fireWith; } ); // Make the deferred a promise promise.promise( deferred ); // Call given func if any if ( func ) { func.call( deferred, deferred ); } // All done! return deferred; }, // Deferred helper when: function( subordinate /* , ..., subordinateN */ ) { var i = 0, resolveValues = slice.call( arguments ), length = resolveValues.length, // the count of uncompleted subordinates remaining = length !== 1 || ( subordinate && jQuery.isFunction( subordinate.promise ) ) ? length : 0, // the master Deferred. // If resolveValues consist of only a single Deferred, just use that. deferred = remaining === 1 ? subordinate : jQuery.Deferred(), // Update function for both resolve and progress values updateFunc = function( i, contexts, values ) { return function( value ) { contexts[ i ] = this; values[ i ] = arguments.length > 1 ? slice.call( arguments ) : value; if ( values === progressValues ) { deferred.notifyWith( contexts, values ); } else if ( !( --remaining ) ) { deferred.resolveWith( contexts, values ); } }; }, progressValues, progressContexts, resolveContexts; // add listeners to Deferred subordinates; treat others as resolved if ( length > 1 ) { progressValues = new Array( length ); progressContexts = new Array( length ); resolveContexts = new Array( length ); for ( ; i < length; i++ ) { if ( resolveValues[ i ] && jQuery.isFunction( resolveValues[ i ].promise ) ) { resolveValues[ i ].promise() .progress( updateFunc( i, progressContexts, progressValues ) ) .done( updateFunc( i, resolveContexts, resolveValues ) ) .fail( deferred.reject ); } else { --remaining; } } } // if we're not waiting on anything, resolve the master if ( !remaining ) { deferred.resolveWith( resolveContexts, resolveValues ); } return deferred.promise(); } } ); // The deferred used on DOM ready var readyList; jQuery.fn.ready = function( fn ) { // Add the callback jQuery.ready.promise().done( fn ); return this; }; jQuery.extend( { // Is the DOM ready to be used? Set to true once it occurs. isReady: false, // A counter to track how many items to wait for before // the ready event fires. See #6781 readyWait: 1, // Hold (or release) the ready event holdReady: function( hold ) { if ( hold ) { jQuery.readyWait++; } else { jQuery.ready( true ); } }, // Handle when the DOM is ready ready: function( wait ) { // Abort if there are pending holds or we're already ready if ( wait === true ? --jQuery.readyWait : jQuery.isReady ) { return; } // Remember that the DOM is ready jQuery.isReady = true; // If a normal DOM Ready event fired, decrement, and wait if need be if ( wait !== true && --jQuery.readyWait > 0 ) { return; } // If there are functions bound, to execute readyList.resolveWith( document, [ jQuery ] ); // Trigger any bound ready events if ( jQuery.fn.triggerHandler ) { jQuery( document ).triggerHandler( "ready" ); jQuery( document ).off( "ready" ); } } } ); /** * Clean-up method for dom ready events */ function detach() { if ( document.addEventListener ) { document.removeEventListener( "DOMContentLoaded", completed ); window.removeEventListener( "load", completed ); } else { document.detachEvent( "onreadystatechange", completed ); window.detachEvent( "onload", completed ); } } /** * The ready event handler and self cleanup method */ function completed() { // readyState === "complete" is good enough for us to call the dom ready in oldIE if ( document.addEventListener || window.event.type === "load" || document.readyState === "complete" ) { detach(); jQuery.ready(); } } jQuery.ready.promise = function( obj ) { if ( !readyList ) { readyList = jQuery.Deferred(); // Catch cases where $(document).ready() is called // after the browser event has already occurred. // Support: IE6-10 // Older IE sometimes signals "interactive" too soon if ( document.readyState === "complete" || ( document.readyState !== "loading" && !document.documentElement.doScroll ) ) { // Handle it asynchronously to allow scripts the opportunity to delay ready window.setTimeout( jQuery.ready ); // Standards-based browsers support DOMContentLoaded } else if ( document.addEventListener ) { // Use the handy event callback document.addEventListener( "DOMContentLoaded", completed ); // A fallback to window.onload, that will always work window.addEventListener( "load", completed ); // If IE event model is used } else { // Ensure firing before onload, maybe late but safe also for iframes document.attachEvent( "onreadystatechange", completed ); // A fallback to window.onload, that will always work window.attachEvent( "onload", completed ); // If IE and not a frame // continually check to see if the document is ready var top = false; try { top = window.frameElement == null && document.documentElement; } catch ( e ) {} if ( top && top.doScroll ) { ( function doScrollCheck() { if ( !jQuery.isReady ) { try { // Use the trick by Diego Perini // http://javascript.nwbox.com/IEContentLoaded/ top.doScroll( "left" ); } catch ( e ) { return window.setTimeout( doScrollCheck, 50 ); } // detach all dom ready events detach(); // and execute any waiting functions jQuery.ready(); } } )(); } } } return readyList.promise( obj ); }; // Kick off the DOM ready check even if the user does not jQuery.ready.promise(); // Support: IE<9 // Iteration over object's inherited properties before its own var i; for ( i in jQuery( support ) ) { break; } support.ownFirst = i === "0"; // Note: most support tests are defined in their respective modules. // false until the test is run support.inlineBlockNeedsLayout = false; // Execute ASAP in case we need to set body.style.zoom jQuery( function() { // Minified: var a,b,c,d var val, div, body, container; body = document.getElementsByTagName( "body" )[ 0 ]; if ( !body || !body.style ) { // Return for frameset docs that don't have a body return; } // Setup div = document.createElement( "div" ); container = document.createElement( "div" ); container.style.cssText = "position:absolute;border:0;width:0;height:0;top:0;left:-9999px"; body.appendChild( container ).appendChild( div ); if ( typeof div.style.zoom !== "undefined" ) { // Support: IE<8 // Check if natively block-level elements act like inline-block // elements when setting their display to 'inline' and giving // them layout div.style.cssText = "display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1"; support.inlineBlockNeedsLayout = val = div.offsetWidth === 3; if ( val ) { // Prevent IE 6 from affecting layout for positioned elements #11048 // Prevent IE from shrinking the body in IE 7 mode #12869 // Support: IE<8 body.style.zoom = 1; } } body.removeChild( container ); } ); ( function() { var div = document.createElement( "div" ); // Support: IE<9 support.deleteExpando = true; try { delete div.test; } catch ( e ) { support.deleteExpando = false; } // Null elements to avoid leaks in IE. div = null; } )(); var acceptData = function( elem ) { var noData = jQuery.noData[ ( elem.nodeName + " " ).toLowerCase() ], nodeType = +elem.nodeType || 1; // Do not set data on non-element DOM nodes because it will not be cleared (#8335). return nodeType !== 1 && nodeType !== 9 ? false : // Nodes accept data unless otherwise specified; rejection can be conditional !noData || noData !== true && elem.getAttribute( "classid" ) === noData; }; var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, rmultiDash = /([A-Z])/g; function dataAttr( elem, key, data ) { // If nothing was found internally, try to fetch any // data from the HTML5 data-* attribute if ( data === undefined && elem.nodeType === 1 ) { var name = "data-" + key.replace( rmultiDash, "-$1" ).toLowerCase(); data = elem.getAttribute( name ); if ( typeof data === "string" ) { try { data = data === "true" ? true : data === "false" ? false : data === "null" ? null : // Only convert to a number if it doesn't change the string +data + "" === data ? +data : rbrace.test( data ) ? jQuery.parseJSON( data ) : data; } catch ( e ) {} // Make sure we set the data so it isn't changed later jQuery.data( elem, key, data ); } else { data = undefined; } } return data; } // checks a cache object for emptiness function isEmptyDataObject( obj ) { var name; for ( name in obj ) { // if the public data object is empty, the private is still empty if ( name === "data" && jQuery.isEmptyObject( obj[ name ] ) ) { continue; } if ( name !== "toJSON" ) { return false; } } return true; } function internalData( elem, name, data, pvt /* Internal Use Only */ ) { if ( !acceptData( elem ) ) { return; } var ret, thisCache, internalKey = jQuery.expando, // We have to handle DOM nodes and JS objects differently because IE6-7 // can't GC object references properly across the DOM-JS boundary isNode = elem.nodeType, // Only DOM nodes need the global jQuery cache; JS object data is // attached directly to the object so GC can occur automatically cache = isNode ? jQuery.cache : elem, // Only defining an ID for JS objects if its cache already exists allows // the code to shortcut on the same path as a DOM node with no cache id = isNode ? elem[ internalKey ] : elem[ internalKey ] && internalKey; // Avoid doing any more work than we need to when trying to get data on an // object that has no data at all if ( ( !id || !cache[ id ] || ( !pvt && !cache[ id ].data ) ) && data === undefined && typeof name === "string" ) { return; } if ( !id ) { // Only DOM nodes need a new unique ID for each element since their data // ends up in the global cache if ( isNode ) { id = elem[ internalKey ] = deletedIds.pop() || jQuery.guid++; } else { id = internalKey; } } if ( !cache[ id ] ) { // Avoid exposing jQuery metadata on plain JS objects when the object // is serialized using JSON.stringify cache[ id ] = isNode ? {} : { toJSON: jQuery.noop }; } // An object can be passed to jQuery.data instead of a key/value pair; this gets // shallow copied over onto the existing cache if ( typeof name === "object" || typeof name === "function" ) { if ( pvt ) { cache[ id ] = jQuery.extend( cache[ id ], name ); } else { cache[ id ].data = jQuery.extend( cache[ id ].data, name ); } } thisCache = cache[ id ]; // jQuery data() is stored in a separate object inside the object's internal data // cache in order to avoid key collisions between internal data and user-defined // data. if ( !pvt ) { if ( !thisCache.data ) { thisCache.data = {}; } thisCache = thisCache.data; } if ( data !== undefined ) { thisCache[ jQuery.camelCase( name ) ] = data; } // Check for both converted-to-camel and non-converted data property names // If a data property was specified if ( typeof name === "string" ) { // First Try to find as-is property data ret = thisCache[ name ]; // Test for null|undefined property data if ( ret == null ) { // Try to find the camelCased property ret = thisCache[ jQuery.camelCase( name ) ]; } } else { ret = thisCache; } return ret; } function internalRemoveData( elem, name, pvt ) { if ( !acceptData( elem ) ) { return; } var thisCache, i, isNode = elem.nodeType, // See jQuery.data for more information cache = isNode ? jQuery.cache : elem, id = isNode ? elem[ jQuery.expando ] : jQuery.expando; // If there is already no cache entry for this object, there is no // purpose in continuing if ( !cache[ id ] ) { return; } if ( name ) { thisCache = pvt ? cache[ id ] : cache[ id ].data; if ( thisCache ) { // Support array or space separated string names for data keys if ( !jQuery.isArray( name ) ) { // try the string as a key before any manipulation if ( name in thisCache ) { name = [ name ]; } else { // split the camel cased version by spaces unless a key with the spaces exists name = jQuery.camelCase( name ); if ( name in thisCache ) { name = [ name ]; } else { name = name.split( " " ); } } } else { // If "name" is an array of keys... // When data is initially created, via ("key", "val") signature, // keys will be converted to camelCase. // Since there is no way to tell _how_ a key was added, remove // both plain key and camelCase key. #12786 // This will only penalize the array argument path. name = name.concat( jQuery.map( name, jQuery.camelCase ) ); } i = name.length; while ( i-- ) { delete thisCache[ name[ i ] ]; } // If there is no data left in the cache, we want to continue // and let the cache object itself get destroyed if ( pvt ? !isEmptyDataObject( thisCache ) : !jQuery.isEmptyObject( thisCache ) ) { return; } } } // See jQuery.data for more information if ( !pvt ) { delete cache[ id ].data; // Don't destroy the parent cache unless the internal data object // had been the only thing left in it if ( !isEmptyDataObject( cache[ id ] ) ) { return; } } // Destroy the cache if ( isNode ) { jQuery.cleanData( [ elem ], true ); // Use delete when supported for expandos or `cache` is not a window per isWindow (#10080) /* jshint eqeqeq: false */ } else if ( support.deleteExpando || cache != cache.window ) { /* jshint eqeqeq: true */ delete cache[ id ]; // When all else fails, undefined } else { cache[ id ] = undefined; } } jQuery.extend( { cache: {}, // The following elements (space-suffixed to avoid Object.prototype collisions) // throw uncatchable exceptions if you attempt to set expando properties noData: { "applet ": true, "embed ": true, // ...but Flash objects (which have this classid) *can* handle expandos "object ": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" }, hasData: function( elem ) { elem = elem.nodeType ? jQuery.cache[ elem[ jQuery.expando ] ] : elem[ jQuery.expando ]; return !!elem && !isEmptyDataObject( elem ); }, data: function( elem, name, data ) { return internalData( elem, name, data ); }, removeData: function( elem, name ) { return internalRemoveData( elem, name ); }, // For internal use only. _data: function( elem, name, data ) { return internalData( elem, name, data, true ); }, _removeData: function( elem, name ) { return internalRemoveData( elem, name, true ); } } ); jQuery.fn.extend( { data: function( key, value ) { var i, name, data, elem = this[ 0 ], attrs = elem && elem.attributes; // Special expections of .data basically thwart jQuery.access, // so implement the relevant behavior ourselves // Gets all values if ( key === undefined ) { if ( this.length ) { data = jQuery.data( elem ); if ( elem.nodeType === 1 && !jQuery._data( elem, "parsedAttrs" ) ) { i = attrs.length; while ( i-- ) { // Support: IE11+ // The attrs elements can be null (#14894) if ( attrs[ i ] ) { name = attrs[ i ].name; if ( name.indexOf( "data-" ) === 0 ) { name = jQuery.camelCase( name.slice( 5 ) ); dataAttr( elem, name, data[ name ] ); } } } jQuery._data( elem, "parsedAttrs", true ); } } return data; } // Sets multiple values if ( typeof key === "object" ) { return this.each( function() { jQuery.data( this, key ); } ); } return arguments.length > 1 ? // Sets one value this.each( function() { jQuery.data( this, key, value ); } ) : // Gets one value // Try to fetch any internally stored data first elem ? dataAttr( elem, key, jQuery.data( elem, key ) ) : undefined; }, removeData: function( key ) { return this.each( function() { jQuery.removeData( this, key ); } ); } } ); jQuery.extend( { queue: function( elem, type, data ) { var queue; if ( elem ) { type = ( type || "fx" ) + "queue"; queue = jQuery._data( elem, type ); // Speed up dequeue by getting out quickly if this is just a lookup if ( data ) { if ( !queue || jQuery.isArray( data ) ) { queue = jQuery._data( elem, type, jQuery.makeArray( data ) ); } else { queue.push( data ); } } return queue || []; } }, dequeue: function( elem, type ) { type = type || "fx"; var queue = jQuery.queue( elem, type ), startLength = queue.length, fn = queue.shift(), hooks = jQuery._queueHooks( elem, type ), next = function() { jQuery.dequeue( elem, type ); }; // If the fx queue is dequeued, always remove the progress sentinel if ( fn === "inprogress" ) { fn = queue.shift(); startLength--; } if ( fn ) { // Add a progress sentinel to prevent the fx queue from being // automatically dequeued if ( type === "fx" ) { queue.unshift( "inprogress" ); } // clear up the last queue stop function delete hooks.stop; fn.call( elem, next, hooks ); } if ( !startLength && hooks ) { hooks.empty.fire(); } }, // not intended for public consumption - generates a queueHooks object, // or returns the current one _queueHooks: function( elem, type ) { var key = type + "queueHooks"; return jQuery._data( elem, key ) || jQuery._data( elem, key, { empty: jQuery.Callbacks( "once memory" ).add( function() { jQuery._removeData( elem, type + "queue" ); jQuery._removeData( elem, key ); } ) } ); } } ); jQuery.fn.extend( { queue: function( type, data ) { var setter = 2; if ( typeof type !== "string" ) { data = type; type = "fx"; setter--; } if ( arguments.length < setter ) { return jQuery.queue( this[ 0 ], type ); } return data === undefined ? this : this.each( function() { var queue = jQuery.queue( this, type, data ); // ensure a hooks for this queue jQuery._queueHooks( this, type ); if ( type === "fx" && queue[ 0 ] !== "inprogress" ) { jQuery.dequeue( this, type ); } } ); }, dequeue: function( type ) { return this.each( function() { jQuery.dequeue( this, type ); } ); }, clearQueue: function( type ) { return this.queue( type || "fx", [] ); }, // Get a promise resolved when queues of a certain type // are emptied (fx is the type by default) promise: function( type, obj ) { var tmp, count = 1, defer = jQuery.Deferred(), elements = this, i = this.length, resolve = function() { if ( !( --count ) ) { defer.resolveWith( elements, [ elements ] ); } }; if ( typeof type !== "string" ) { obj = type; type = undefined; } type = type || "fx"; while ( i-- ) { tmp = jQuery._data( elements[ i ], type + "queueHooks" ); if ( tmp && tmp.empty ) { count++; tmp.empty.add( resolve ); } } resolve(); return defer.promise( obj ); } } ); ( function() { var shrinkWrapBlocksVal; support.shrinkWrapBlocks = function() { if ( shrinkWrapBlocksVal != null ) { return shrinkWrapBlocksVal; } // Will be changed later if needed. shrinkWrapBlocksVal = false; // Minified: var b,c,d var div, body, container; body = document.getElementsByTagName( "body" )[ 0 ]; if ( !body || !body.style ) { // Test fired too early or in an unsupported environment, exit. return; } // Setup div = document.createElement( "div" ); container = document.createElement( "div" ); container.style.cssText = "position:absolute;border:0;width:0;height:0;top:0;left:-9999px"; body.appendChild( container ).appendChild( div ); // Support: IE6 // Check if elements with layout shrink-wrap their children if ( typeof div.style.zoom !== "undefined" ) { // Reset CSS: box-sizing; display; margin; border div.style.cssText = // Support: Firefox<29, Android 2.3 // Vendor-prefix box-sizing "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;" + "box-sizing:content-box;display:block;margin:0;border:0;" + "padding:1px;width:1px;zoom:1"; div.appendChild( document.createElement( "div" ) ).style.width = "5px"; shrinkWrapBlocksVal = div.offsetWidth !== 3; } body.removeChild( container ); return shrinkWrapBlocksVal; }; } )(); var pnum = ( /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/ ).source; var rcssNum = new RegExp( "^(?:([+-])=|)(" + pnum + ")([a-z%]*)$", "i" ); var cssExpand = [ "Top", "Right", "Bottom", "Left" ]; var isHidden = function( elem, el ) { // isHidden might be called from jQuery#filter function; // in that case, element will be second argument elem = el || elem; return jQuery.css( elem, "display" ) === "none" || !jQuery.contains( elem.ownerDocument, elem ); }; function adjustCSS( elem, prop, valueParts, tween ) { var adjusted, scale = 1, maxIterations = 20, currentValue = tween ? function() { return tween.cur(); } : function() { return jQuery.css( elem, prop, "" ); }, initial = currentValue(), unit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ), // Starting value computation is required for potential unit mismatches initialInUnit = ( jQuery.cssNumber[ prop ] || unit !== "px" && +initial ) && rcssNum.exec( jQuery.css( elem, prop ) ); if ( initialInUnit && initialInUnit[ 3 ] !== unit ) { // Trust units reported by jQuery.css unit = unit || initialInUnit[ 3 ]; // Make sure we update the tween properties later on valueParts = valueParts || []; // Iteratively approximate from a nonzero starting point initialInUnit = +initial || 1; do { // If previous iteration zeroed out, double until we get *something*. // Use string for doubling so we don't accidentally see scale as unchanged below scale = scale || ".5"; // Adjust and apply initialInUnit = initialInUnit / scale; jQuery.style( elem, prop, initialInUnit + unit ); // Update scale, tolerating zero or NaN from tween.cur() // Break the loop if scale is unchanged or perfect, or if we've just had enough. } while ( scale !== ( scale = currentValue() / initial ) && scale !== 1 && --maxIterations ); } if ( valueParts ) { initialInUnit = +initialInUnit || +initial || 0; // Apply relative offset (+=/-=) if specified adjusted = valueParts[ 1 ] ? initialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] : +valueParts[ 2 ]; if ( tween ) { tween.unit = unit; tween.start = initialInUnit; tween.end = adjusted; } } return adjusted; } // Multifunctional method to get and set values of a collection // The value/s can optionally be executed if it's a function var access = function( elems, fn, key, value, chainable, emptyGet, raw ) { var i = 0, length = elems.length, bulk = key == null; // Sets many values if ( jQuery.type( key ) === "object" ) { chainable = true; for ( i in key ) { access( elems, fn, i, key[ i ], true, emptyGet, raw ); } // Sets one value } else if ( value !== undefined ) { chainable = true; if ( !jQuery.isFunction( value ) ) { raw = true; } if ( bulk ) { // Bulk operations run against the entire set if ( raw ) { fn.call( elems, value ); fn = null; // ...except when executing function values } else { bulk = fn; fn = function( elem, key, value ) { return bulk.call( jQuery( elem ), value ); }; } } if ( fn ) { for ( ; i < length; i++ ) { fn( elems[ i ], key, raw ? value : value.call( elems[ i ], i, fn( elems[ i ], key ) ) ); } } } return chainable ? elems : // Gets bulk ? fn.call( elems ) : length ? fn( elems[ 0 ], key ) : emptyGet; }; var rcheckableType = ( /^(?:checkbox|radio)$/i ); var rtagName = ( /<([\w:-]+)/ ); var rscriptType = ( /^$|\/(?:java|ecma)script/i ); var rleadingWhitespace = ( /^\s+/ ); var nodeNames = "abbr|article|aside|audio|bdi|canvas|data|datalist|" + "details|dialog|figcaption|figure|footer|header|hgroup|main|" + "mark|meter|nav|output|picture|progress|section|summary|template|time|video"; function createSafeFragment( document ) { var list = nodeNames.split( "|" ), safeFrag = document.createDocumentFragment(); if ( safeFrag.createElement ) { while ( list.length ) { safeFrag.createElement( list.pop() ); } } return safeFrag; } ( function() { var div = document.createElement( "div" ), fragment = document.createDocumentFragment(), input = document.createElement( "input" ); // Setup div.innerHTML = "
a"; // IE strips leading whitespace when .innerHTML is used support.leadingWhitespace = div.firstChild.nodeType === 3; // Make sure that tbody elements aren't automatically inserted // IE will insert them into empty tables support.tbody = !div.getElementsByTagName( "tbody" ).length; // Make sure that link elements get serialized correctly by innerHTML // This requires a wrapper element in IE support.htmlSerialize = !!div.getElementsByTagName( "link" ).length; // Makes sure cloning an html5 element does not cause problems // Where outerHTML is undefined, this still works support.html5Clone = document.createElement( "nav" ).cloneNode( true ).outerHTML !== "<:nav>"; // Check if a disconnected checkbox will retain its checked // value of true after appended to the DOM (IE6/7) input.type = "checkbox"; input.checked = true; fragment.appendChild( input ); support.appendChecked = input.checked; // Make sure textarea (and checkbox) defaultValue is properly cloned // Support: IE6-IE11+ div.innerHTML = ""; support.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue; // #11217 - WebKit loses check when the name is after the checked attribute fragment.appendChild( div ); // Support: Windows Web Apps (WWA) // `name` and `type` must use .setAttribute for WWA (#14901) input = document.createElement( "input" ); input.setAttribute( "type", "radio" ); input.setAttribute( "checked", "checked" ); input.setAttribute( "name", "t" ); div.appendChild( input ); // Support: Safari 5.1, iOS 5.1, Android 4.x, Android 2.3 // old WebKit doesn't clone checked state correctly in fragments support.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked; // Support: IE<9 // Cloned elements keep attachEvent handlers, we use addEventListener on IE9+ support.noCloneEvent = !!div.addEventListener; // Support: IE<9 // Since attributes and properties are the same in IE, // cleanData must set properties to undefined rather than use removeAttribute div[ jQuery.expando ] = 1; support.attributes = !div.getAttribute( jQuery.expando ); } )(); // We have to close these tags to support XHTML (#13200) var wrapMap = { option: [ 1, "" ], legend: [ 1, "
", "
" ], area: [ 1, "", "" ], // Support: IE8 param: [ 1, "", "" ], thead: [ 1, "", "
" ], tr: [ 2, "", "
" ], col: [ 2, "", "
" ], td: [ 3, "", "
" ], // IE6-8 can't serialize link, script, style, or any html5 (NoScope) tags, // unless wrapped in a div with non-breaking characters in front of it. _default: support.htmlSerialize ? [ 0, "", "" ] : [ 1, "X
", "
" ] }; // Support: IE8-IE9 wrapMap.optgroup = wrapMap.option; wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; wrapMap.th = wrapMap.td; function getAll( context, tag ) { var elems, elem, i = 0, found = typeof context.getElementsByTagName !== "undefined" ? context.getElementsByTagName( tag || "*" ) : typeof context.querySelectorAll !== "undefined" ? context.querySelectorAll( tag || "*" ) : undefined; if ( !found ) { for ( found = [], elems = context.childNodes || context; ( elem = elems[ i ] ) != null; i++ ) { if ( !tag || jQuery.nodeName( elem, tag ) ) { found.push( elem ); } else { jQuery.merge( found, getAll( elem, tag ) ); } } } return tag === undefined || tag && jQuery.nodeName( context, tag ) ? jQuery.merge( [ context ], found ) : found; } // Mark scripts as having already been evaluated function setGlobalEval( elems, refElements ) { var elem, i = 0; for ( ; ( elem = elems[ i ] ) != null; i++ ) { jQuery._data( elem, "globalEval", !refElements || jQuery._data( refElements[ i ], "globalEval" ) ); } } var rhtml = /<|&#?\w+;/, rtbody = / from table fragments if ( !support.tbody ) { // String was a , *may* have spurious elem = tag === "table" && !rtbody.test( elem ) ? tmp.firstChild : // String was a bare or wrap[ 1 ] === "
" && !rtbody.test( elem ) ? tmp : 0; j = elem && elem.childNodes.length; while ( j-- ) { if ( jQuery.nodeName( ( tbody = elem.childNodes[ j ] ), "tbody" ) && !tbody.childNodes.length ) { elem.removeChild( tbody ); } } } jQuery.merge( nodes, tmp.childNodes ); // Fix #12392 for WebKit and IE > 9 tmp.textContent = ""; // Fix #12392 for oldIE while ( tmp.firstChild ) { tmp.removeChild( tmp.firstChild ); } // Remember the top-level container for proper cleanup tmp = safe.lastChild; } } } // Fix #11356: Clear elements from fragment if ( tmp ) { safe.removeChild( tmp ); } // Reset defaultChecked for any radios and checkboxes // about to be appended to the DOM in IE 6/7 (#8060) if ( !support.appendChecked ) { jQuery.grep( getAll( nodes, "input" ), fixDefaultChecked ); } i = 0; while ( ( elem = nodes[ i++ ] ) ) { // Skip elements already in the context collection (trac-4087) if ( selection && jQuery.inArray( elem, selection ) > -1 ) { if ( ignored ) { ignored.push( elem ); } continue; } contains = jQuery.contains( elem.ownerDocument, elem ); // Append to fragment tmp = getAll( safe.appendChild( elem ), "script" ); // Preserve script evaluation history if ( contains ) { setGlobalEval( tmp ); } // Capture executables if ( scripts ) { j = 0; while ( ( elem = tmp[ j++ ] ) ) { if ( rscriptType.test( elem.type || "" ) ) { scripts.push( elem ); } } } } tmp = null; return safe; } ( function() { var i, eventName, div = document.createElement( "div" ); // Support: IE<9 (lack submit/change bubble), Firefox (lack focus(in | out) events) for ( i in { submit: true, change: true, focusin: true } ) { eventName = "on" + i; if ( !( support[ i ] = eventName in window ) ) { // Beware of CSP restrictions (https://developer.mozilla.org/en/Security/CSP) div.setAttribute( eventName, "t" ); support[ i ] = div.attributes[ eventName ].expando === false; } } // Null elements to avoid leaks in IE. div = null; } )(); var rformElems = /^(?:input|select|textarea)$/i, rkeyEvent = /^key/, rmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, rtypenamespace = /^([^.]*)(?:\.(.+)|)/; function returnTrue() { return true; } function returnFalse() { return false; } // Support: IE9 // See #13393 for more info function safeActiveElement() { try { return document.activeElement; } catch ( err ) { } } function on( elem, types, selector, data, fn, one ) { var origFn, type; // Types can be a map of types/handlers if ( typeof types === "object" ) { // ( types-Object, selector, data ) if ( typeof selector !== "string" ) { // ( types-Object, data ) data = data || selector; selector = undefined; } for ( type in types ) { on( elem, type, selector, data, types[ type ], one ); } return elem; } if ( data == null && fn == null ) { // ( types, fn ) fn = selector; data = selector = undefined; } else if ( fn == null ) { if ( typeof selector === "string" ) { // ( types, selector, fn ) fn = data; data = undefined; } else { // ( types, data, fn ) fn = data; data = selector; selector = undefined; } } if ( fn === false ) { fn = returnFalse; } else if ( !fn ) { return elem; } if ( one === 1 ) { origFn = fn; fn = function( event ) { // Can use an empty set, since event contains the info jQuery().off( event ); return origFn.apply( this, arguments ); }; // Use same guid so caller can remove using origFn fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); } return elem.each( function() { jQuery.event.add( this, types, fn, data, selector ); } ); } /* * Helper functions for managing events -- not part of the public interface. * Props to Dean Edwards' addEvent library for many of the ideas. */ jQuery.event = { global: {}, add: function( elem, types, handler, data, selector ) { var tmp, events, t, handleObjIn, special, eventHandle, handleObj, handlers, type, namespaces, origType, elemData = jQuery._data( elem ); // Don't attach events to noData or text/comment nodes (but allow plain objects) if ( !elemData ) { return; } // Caller can pass in an object of custom data in lieu of the handler if ( handler.handler ) { handleObjIn = handler; handler = handleObjIn.handler; selector = handleObjIn.selector; } // Make sure that the handler has a unique ID, used to find/remove it later if ( !handler.guid ) { handler.guid = jQuery.guid++; } // Init the element's event structure and main handler, if this is the first if ( !( events = elemData.events ) ) { events = elemData.events = {}; } if ( !( eventHandle = elemData.handle ) ) { eventHandle = elemData.handle = function( e ) { // Discard the second event of a jQuery.event.trigger() and // when an event is called after a page has unloaded return typeof jQuery !== "undefined" && ( !e || jQuery.event.triggered !== e.type ) ? jQuery.event.dispatch.apply( eventHandle.elem, arguments ) : undefined; }; // Add elem as a property of the handle fn to prevent a memory leak // with IE non-native events eventHandle.elem = elem; } // Handle multiple events separated by a space types = ( types || "" ).match( rnotwhite ) || [ "" ]; t = types.length; while ( t-- ) { tmp = rtypenamespace.exec( types[ t ] ) || []; type = origType = tmp[ 1 ]; namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort(); // There *must* be a type, no attaching namespace-only handlers if ( !type ) { continue; } // If event changes its type, use the special event handlers for the changed type special = jQuery.event.special[ type ] || {}; // If selector defined, determine special event api type, otherwise given type type = ( selector ? special.delegateType : special.bindType ) || type; // Update special based on newly reset type special = jQuery.event.special[ type ] || {}; // handleObj is passed to all event handlers handleObj = jQuery.extend( { type: type, origType: origType, data: data, handler: handler, guid: handler.guid, selector: selector, needsContext: selector && jQuery.expr.match.needsContext.test( selector ), namespace: namespaces.join( "." ) }, handleObjIn ); // Init the event handler queue if we're the first if ( !( handlers = events[ type ] ) ) { handlers = events[ type ] = []; handlers.delegateCount = 0; // Only use addEventListener/attachEvent if the special events handler returns false if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) { // Bind the global event handler to the element if ( elem.addEventListener ) { elem.addEventListener( type, eventHandle, false ); } else if ( elem.attachEvent ) { elem.attachEvent( "on" + type, eventHandle ); } } } if ( special.add ) { special.add.call( elem, handleObj ); if ( !handleObj.handler.guid ) { handleObj.handler.guid = handler.guid; } } // Add to the element's handler list, delegates in front if ( selector ) { handlers.splice( handlers.delegateCount++, 0, handleObj ); } else { handlers.push( handleObj ); } // Keep track of which events have ever been used, for event optimization jQuery.event.global[ type ] = true; } // Nullify elem to prevent memory leaks in IE elem = null; }, // Detach an event or set of events from an element remove: function( elem, types, handler, selector, mappedTypes ) { var j, handleObj, tmp, origCount, t, events, special, handlers, type, namespaces, origType, elemData = jQuery.hasData( elem ) && jQuery._data( elem ); if ( !elemData || !( events = elemData.events ) ) { return; } // Once for each type.namespace in types; type may be omitted types = ( types || "" ).match( rnotwhite ) || [ "" ]; t = types.length; while ( t-- ) { tmp = rtypenamespace.exec( types[ t ] ) || []; type = origType = tmp[ 1 ]; namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort(); // Unbind all events (on this namespace, if provided) for the element if ( !type ) { for ( type in events ) { jQuery.event.remove( elem, type + types[ t ], handler, selector, true ); } continue; } special = jQuery.event.special[ type ] || {}; type = ( selector ? special.delegateType : special.bindType ) || type; handlers = events[ type ] || []; tmp = tmp[ 2 ] && new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" ); // Remove matching events origCount = j = handlers.length; while ( j-- ) { handleObj = handlers[ j ]; if ( ( mappedTypes || origType === handleObj.origType ) && ( !handler || handler.guid === handleObj.guid ) && ( !tmp || tmp.test( handleObj.namespace ) ) && ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) { handlers.splice( j, 1 ); if ( handleObj.selector ) { handlers.delegateCount--; } if ( special.remove ) { special.remove.call( elem, handleObj ); } } } // Remove generic event handler if we removed something and no more handlers exist // (avoids potential for endless recursion during removal of special event handlers) if ( origCount && !handlers.length ) { if ( !special.teardown || special.teardown.call( elem, namespaces, elemData.handle ) === false ) { jQuery.removeEvent( elem, type, elemData.handle ); } delete events[ type ]; } } // Remove the expando if it's no longer used if ( jQuery.isEmptyObject( events ) ) { delete elemData.handle; // removeData also checks for emptiness and clears the expando if empty // so use it instead of delete jQuery._removeData( elem, "events" ); } }, trigger: function( event, data, elem, onlyHandlers ) { var handle, ontype, cur, bubbleType, special, tmp, i, eventPath = [ elem || document ], type = hasOwn.call( event, "type" ) ? event.type : event, namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split( "." ) : []; cur = tmp = elem = elem || document; // Don't do events on text and comment nodes if ( elem.nodeType === 3 || elem.nodeType === 8 ) { return; } // focus/blur morphs to focusin/out; ensure we're not firing them right now if ( rfocusMorph.test( type + jQuery.event.triggered ) ) { return; } if ( type.indexOf( "." ) > -1 ) { // Namespaced trigger; create a regexp to match event type in handle() namespaces = type.split( "." ); type = namespaces.shift(); namespaces.sort(); } ontype = type.indexOf( ":" ) < 0 && "on" + type; // Caller can pass in a jQuery.Event object, Object, or just an event type string event = event[ jQuery.expando ] ? event : new jQuery.Event( type, typeof event === "object" && event ); // Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true) event.isTrigger = onlyHandlers ? 2 : 3; event.namespace = namespaces.join( "." ); event.rnamespace = event.namespace ? new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" ) : null; // Clean up the event in case it is being reused event.result = undefined; if ( !event.target ) { event.target = elem; } // Clone any incoming data and prepend the event, creating the handler arg list data = data == null ? [ event ] : jQuery.makeArray( data, [ event ] ); // Allow special events to draw outside the lines special = jQuery.event.special[ type ] || {}; if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) { return; } // Determine event propagation path in advance, per W3C events spec (#9951) // Bubble up to document, then to window; watch for a global ownerDocument var (#9724) if ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) { bubbleType = special.delegateType || type; if ( !rfocusMorph.test( bubbleType + type ) ) { cur = cur.parentNode; } for ( ; cur; cur = cur.parentNode ) { eventPath.push( cur ); tmp = cur; } // Only add window if we got to document (e.g., not plain obj or detached DOM) if ( tmp === ( elem.ownerDocument || document ) ) { eventPath.push( tmp.defaultView || tmp.parentWindow || window ); } } // Fire handlers on the event path i = 0; while ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) { event.type = i > 1 ? bubbleType : special.bindType || type; // jQuery handler handle = ( jQuery._data( cur, "events" ) || {} )[ event.type ] && jQuery._data( cur, "handle" ); if ( handle ) { handle.apply( cur, data ); } // Native handler handle = ontype && cur[ ontype ]; if ( handle && handle.apply && acceptData( cur ) ) { event.result = handle.apply( cur, data ); if ( event.result === false ) { event.preventDefault(); } } } event.type = type; // If nobody prevented the default action, do it now if ( !onlyHandlers && !event.isDefaultPrevented() ) { if ( ( !special._default || special._default.apply( eventPath.pop(), data ) === false ) && acceptData( elem ) ) { // Call a native DOM method on the target with the same name name as the event. // Can't use an .isFunction() check here because IE6/7 fails that test. // Don't do default actions on window, that's where global variables be (#6170) if ( ontype && elem[ type ] && !jQuery.isWindow( elem ) ) { // Don't re-trigger an onFOO event when we call its FOO() method tmp = elem[ ontype ]; if ( tmp ) { elem[ ontype ] = null; } // Prevent re-triggering of the same event, since we already bubbled it above jQuery.event.triggered = type; try { elem[ type ](); } catch ( e ) { // IE<9 dies on focus/blur to hidden element (#1486,#12518) // only reproducible on winXP IE8 native, not IE9 in IE8 mode } jQuery.event.triggered = undefined; if ( tmp ) { elem[ ontype ] = tmp; } } } } return event.result; }, dispatch: function( event ) { // Make a writable jQuery.Event from the native event object event = jQuery.event.fix( event ); var i, j, ret, matched, handleObj, handlerQueue = [], args = slice.call( arguments ), handlers = ( jQuery._data( this, "events" ) || {} )[ event.type ] || [], special = jQuery.event.special[ event.type ] || {}; // Use the fix-ed jQuery.Event rather than the (read-only) native event args[ 0 ] = event; event.delegateTarget = this; // Call the preDispatch hook for the mapped type, and let it bail if desired if ( special.preDispatch && special.preDispatch.call( this, event ) === false ) { return; } // Determine handlers handlerQueue = jQuery.event.handlers.call( this, event, handlers ); // Run delegates first; they may want to stop propagation beneath us i = 0; while ( ( matched = handlerQueue[ i++ ] ) && !event.isPropagationStopped() ) { event.currentTarget = matched.elem; j = 0; while ( ( handleObj = matched.handlers[ j++ ] ) && !event.isImmediatePropagationStopped() ) { // Triggered event must either 1) have no namespace, or 2) have namespace(s) // a subset or equal to those in the bound event (both can have no namespace). if ( !event.rnamespace || event.rnamespace.test( handleObj.namespace ) ) { event.handleObj = handleObj; event.data = handleObj.data; ret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle || handleObj.handler ).apply( matched.elem, args ); if ( ret !== undefined ) { if ( ( event.result = ret ) === false ) { event.preventDefault(); event.stopPropagation(); } } } } } // Call the postDispatch hook for the mapped type if ( special.postDispatch ) { special.postDispatch.call( this, event ); } return event.result; }, handlers: function( event, handlers ) { var i, matches, sel, handleObj, handlerQueue = [], delegateCount = handlers.delegateCount, cur = event.target; // Support (at least): Chrome, IE9 // Find delegate handlers // Black-hole SVG instance trees (#13180) // // Support: Firefox<=42+ // Avoid non-left-click in FF but don't block IE radio events (#3861, gh-2343) if ( delegateCount && cur.nodeType && ( event.type !== "click" || isNaN( event.button ) || event.button < 1 ) ) { /* jshint eqeqeq: false */ for ( ; cur != this; cur = cur.parentNode || this ) { /* jshint eqeqeq: true */ // Don't check non-elements (#13208) // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) if ( cur.nodeType === 1 && ( cur.disabled !== true || event.type !== "click" ) ) { matches = []; for ( i = 0; i < delegateCount; i++ ) { handleObj = handlers[ i ]; // Don't conflict with Object.prototype properties (#13203) sel = handleObj.selector + " "; if ( matches[ sel ] === undefined ) { matches[ sel ] = handleObj.needsContext ? jQuery( sel, this ).index( cur ) > -1 : jQuery.find( sel, this, null, [ cur ] ).length; } if ( matches[ sel ] ) { matches.push( handleObj ); } } if ( matches.length ) { handlerQueue.push( { elem: cur, handlers: matches } ); } } } } // Add the remaining (directly-bound) handlers if ( delegateCount < handlers.length ) { handlerQueue.push( { elem: this, handlers: handlers.slice( delegateCount ) } ); } return handlerQueue; }, fix: function( event ) { if ( event[ jQuery.expando ] ) { return event; } // Create a writable copy of the event object and normalize some properties var i, prop, copy, type = event.type, originalEvent = event, fixHook = this.fixHooks[ type ]; if ( !fixHook ) { this.fixHooks[ type ] = fixHook = rmouseEvent.test( type ) ? this.mouseHooks : rkeyEvent.test( type ) ? this.keyHooks : {}; } copy = fixHook.props ? this.props.concat( fixHook.props ) : this.props; event = new jQuery.Event( originalEvent ); i = copy.length; while ( i-- ) { prop = copy[ i ]; event[ prop ] = originalEvent[ prop ]; } // Support: IE<9 // Fix target property (#1925) if ( !event.target ) { event.target = originalEvent.srcElement || document; } // Support: Safari 6-8+ // Target should not be a text node (#504, #13143) if ( event.target.nodeType === 3 ) { event.target = event.target.parentNode; } // Support: IE<9 // For mouse/key events, metaKey==false if it's undefined (#3368, #11328) event.metaKey = !!event.metaKey; return fixHook.filter ? fixHook.filter( event, originalEvent ) : event; }, // Includes some event props shared by KeyEvent and MouseEvent props: ( "altKey bubbles cancelable ctrlKey currentTarget detail eventPhase " + "metaKey relatedTarget shiftKey target timeStamp view which" ).split( " " ), fixHooks: {}, keyHooks: { props: "char charCode key keyCode".split( " " ), filter: function( event, original ) { // Add which for key events if ( event.which == null ) { event.which = original.charCode != null ? original.charCode : original.keyCode; } return event; } }, mouseHooks: { props: ( "button buttons clientX clientY fromElement offsetX offsetY " + "pageX pageY screenX screenY toElement" ).split( " " ), filter: function( event, original ) { var body, eventDoc, doc, button = original.button, fromElement = original.fromElement; // Calculate pageX/Y if missing and clientX/Y available if ( event.pageX == null && original.clientX != null ) { eventDoc = event.target.ownerDocument || document; doc = eventDoc.documentElement; body = eventDoc.body; event.pageX = original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) - ( doc && doc.clientLeft || body && body.clientLeft || 0 ); event.pageY = original.clientY + ( doc && doc.scrollTop || body && body.scrollTop || 0 ) - ( doc && doc.clientTop || body && body.clientTop || 0 ); } // Add relatedTarget, if necessary if ( !event.relatedTarget && fromElement ) { event.relatedTarget = fromElement === event.target ? original.toElement : fromElement; } // Add which for click: 1 === left; 2 === middle; 3 === right // Note: button is not normalized, so don't use it if ( !event.which && button !== undefined ) { event.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) ); } return event; } }, special: { load: { // Prevent triggered image.load events from bubbling to window.load noBubble: true }, focus: { // Fire native event if possible so blur/focus sequence is correct trigger: function() { if ( this !== safeActiveElement() && this.focus ) { try { this.focus(); return false; } catch ( e ) { // Support: IE<9 // If we error on focus to hidden element (#1486, #12518), // let .trigger() run the handlers } } }, delegateType: "focusin" }, blur: { trigger: function() { if ( this === safeActiveElement() && this.blur ) { this.blur(); return false; } }, delegateType: "focusout" }, click: { // For checkbox, fire native event so checked state will be right trigger: function() { if ( jQuery.nodeName( this, "input" ) && this.type === "checkbox" && this.click ) { this.click(); return false; } }, // For cross-browser consistency, don't fire native .click() on links _default: function( event ) { return jQuery.nodeName( event.target, "a" ); } }, beforeunload: { postDispatch: function( event ) { // Support: Firefox 20+ // Firefox doesn't alert if the returnValue field is not set. if ( event.result !== undefined && event.originalEvent ) { event.originalEvent.returnValue = event.result; } } } }, // Piggyback on a donor event to simulate a different one simulate: function( type, elem, event ) { var e = jQuery.extend( new jQuery.Event(), event, { type: type, isSimulated: true // Previously, `originalEvent: {}` was set here, so stopPropagation call // would not be triggered on donor event, since in our own // jQuery.event.stopPropagation function we had a check for existence of // originalEvent.stopPropagation method, so, consequently it would be a noop. // // Guard for simulated events was moved to jQuery.event.stopPropagation function // since `originalEvent` should point to the original event for the // constancy with other events and for more focused logic } ); jQuery.event.trigger( e, null, elem ); if ( e.isDefaultPrevented() ) { event.preventDefault(); } } }; jQuery.removeEvent = document.removeEventListener ? function( elem, type, handle ) { // This "if" is needed for plain objects if ( elem.removeEventListener ) { elem.removeEventListener( type, handle ); } } : function( elem, type, handle ) { var name = "on" + type; if ( elem.detachEvent ) { // #8545, #7054, preventing memory leaks for custom events in IE6-8 // detachEvent needed property on element, by name of that event, // to properly expose it to GC if ( typeof elem[ name ] === "undefined" ) { elem[ name ] = null; } elem.detachEvent( name, handle ); } }; jQuery.Event = function( src, props ) { // Allow instantiation without the 'new' keyword if ( !( this instanceof jQuery.Event ) ) { return new jQuery.Event( src, props ); } // Event object if ( src && src.type ) { this.originalEvent = src; this.type = src.type; // Events bubbling up the document may have been marked as prevented // by a handler lower down the tree; reflect the correct value. this.isDefaultPrevented = src.defaultPrevented || src.defaultPrevented === undefined && // Support: IE < 9, Android < 4.0 src.returnValue === false ? returnTrue : returnFalse; // Event type } else { this.type = src; } // Put explicitly provided properties onto the event object if ( props ) { jQuery.extend( this, props ); } // Create a timestamp if incoming event doesn't have one this.timeStamp = src && src.timeStamp || jQuery.now(); // Mark it as fixed this[ jQuery.expando ] = true; }; // jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding // http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html jQuery.Event.prototype = { constructor: jQuery.Event, isDefaultPrevented: returnFalse, isPropagationStopped: returnFalse, isImmediatePropagationStopped: returnFalse, preventDefault: function() { var e = this.originalEvent; this.isDefaultPrevented = returnTrue; if ( !e ) { return; } // If preventDefault exists, run it on the original event if ( e.preventDefault ) { e.preventDefault(); // Support: IE // Otherwise set the returnValue property of the original event to false } else { e.returnValue = false; } }, stopPropagation: function() { var e = this.originalEvent; this.isPropagationStopped = returnTrue; if ( !e || this.isSimulated ) { return; } // If stopPropagation exists, run it on the original event if ( e.stopPropagation ) { e.stopPropagation(); } // Support: IE // Set the cancelBubble property of the original event to true e.cancelBubble = true; }, stopImmediatePropagation: function() { var e = this.originalEvent; this.isImmediatePropagationStopped = returnTrue; if ( e && e.stopImmediatePropagation ) { e.stopImmediatePropagation(); } this.stopPropagation(); } }; // Create mouseenter/leave events using mouseover/out and event-time checks // so that event delegation works in jQuery. // Do the same for pointerenter/pointerleave and pointerover/pointerout // // Support: Safari 7 only // Safari sends mouseenter too often; see: // https://code.google.com/p/chromium/issues/detail?id=470258 // for the description of the bug (it existed in older Chrome versions as well). jQuery.each( { mouseenter: "mouseover", mouseleave: "mouseout", pointerenter: "pointerover", pointerleave: "pointerout" }, function( orig, fix ) { jQuery.event.special[ orig ] = { delegateType: fix, bindType: fix, handle: function( event ) { var ret, target = this, related = event.relatedTarget, handleObj = event.handleObj; // For mouseenter/leave call the handler if related is outside the target. // NB: No relatedTarget if the mouse left/entered the browser window if ( !related || ( related !== target && !jQuery.contains( target, related ) ) ) { event.type = handleObj.origType; ret = handleObj.handler.apply( this, arguments ); event.type = fix; } return ret; } }; } ); // IE submit delegation if ( !support.submit ) { jQuery.event.special.submit = { setup: function() { // Only need this for delegated form submit events if ( jQuery.nodeName( this, "form" ) ) { return false; } // Lazy-add a submit handler when a descendant form may potentially be submitted jQuery.event.add( this, "click._submit keypress._submit", function( e ) { // Node name check avoids a VML-related crash in IE (#9807) var elem = e.target, form = jQuery.nodeName( elem, "input" ) || jQuery.nodeName( elem, "button" ) ? // Support: IE <=8 // We use jQuery.prop instead of elem.form // to allow fixing the IE8 delegated submit issue (gh-2332) // by 3rd party polyfills/workarounds. jQuery.prop( elem, "form" ) : undefined; if ( form && !jQuery._data( form, "submit" ) ) { jQuery.event.add( form, "submit._submit", function( event ) { event._submitBubble = true; } ); jQuery._data( form, "submit", true ); } } ); // return undefined since we don't need an event listener }, postDispatch: function( event ) { // If form was submitted by the user, bubble the event up the tree if ( event._submitBubble ) { delete event._submitBubble; if ( this.parentNode && !event.isTrigger ) { jQuery.event.simulate( "submit", this.parentNode, event ); } } }, teardown: function() { // Only need this for delegated form submit events if ( jQuery.nodeName( this, "form" ) ) { return false; } // Remove delegated handlers; cleanData eventually reaps submit handlers attached above jQuery.event.remove( this, "._submit" ); } }; } // IE change delegation and checkbox/radio fix if ( !support.change ) { jQuery.event.special.change = { setup: function() { if ( rformElems.test( this.nodeName ) ) { // IE doesn't fire change on a check/radio until blur; trigger it on click // after a propertychange. Eat the blur-change in special.change.handle. // This still fires onchange a second time for check/radio after blur. if ( this.type === "checkbox" || this.type === "radio" ) { jQuery.event.add( this, "propertychange._change", function( event ) { if ( event.originalEvent.propertyName === "checked" ) { this._justChanged = true; } } ); jQuery.event.add( this, "click._change", function( event ) { if ( this._justChanged && !event.isTrigger ) { this._justChanged = false; } // Allow triggered, simulated change events (#11500) jQuery.event.simulate( "change", this, event ); } ); } return false; } // Delegated event; lazy-add a change handler on descendant inputs jQuery.event.add( this, "beforeactivate._change", function( e ) { var elem = e.target; if ( rformElems.test( elem.nodeName ) && !jQuery._data( elem, "change" ) ) { jQuery.event.add( elem, "change._change", function( event ) { if ( this.parentNode && !event.isSimulated && !event.isTrigger ) { jQuery.event.simulate( "change", this.parentNode, event ); } } ); jQuery._data( elem, "change", true ); } } ); }, handle: function( event ) { var elem = event.target; // Swallow native change events from checkbox/radio, we already triggered them above if ( this !== elem || event.isSimulated || event.isTrigger || ( elem.type !== "radio" && elem.type !== "checkbox" ) ) { return event.handleObj.handler.apply( this, arguments ); } }, teardown: function() { jQuery.event.remove( this, "._change" ); return !rformElems.test( this.nodeName ); } }; } // Support: Firefox // Firefox doesn't have focus(in | out) events // Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787 // // Support: Chrome, Safari // focus(in | out) events fire after focus & blur events, // which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order // Related ticket - https://code.google.com/p/chromium/issues/detail?id=449857 if ( !support.focusin ) { jQuery.each( { focus: "focusin", blur: "focusout" }, function( orig, fix ) { // Attach a single capturing handler on the document while someone wants focusin/focusout var handler = function( event ) { jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ) ); }; jQuery.event.special[ fix ] = { setup: function() { var doc = this.ownerDocument || this, attaches = jQuery._data( doc, fix ); if ( !attaches ) { doc.addEventListener( orig, handler, true ); } jQuery._data( doc, fix, ( attaches || 0 ) + 1 ); }, teardown: function() { var doc = this.ownerDocument || this, attaches = jQuery._data( doc, fix ) - 1; if ( !attaches ) { doc.removeEventListener( orig, handler, true ); jQuery._removeData( doc, fix ); } else { jQuery._data( doc, fix, attaches ); } } }; } ); } jQuery.fn.extend( { on: function( types, selector, data, fn ) { return on( this, types, selector, data, fn ); }, one: function( types, selector, data, fn ) { return on( this, types, selector, data, fn, 1 ); }, off: function( types, selector, fn ) { var handleObj, type; if ( types && types.preventDefault && types.handleObj ) { // ( event ) dispatched jQuery.Event handleObj = types.handleObj; jQuery( types.delegateTarget ).off( handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, handleObj.selector, handleObj.handler ); return this; } if ( typeof types === "object" ) { // ( types-object [, selector] ) for ( type in types ) { this.off( type, selector, types[ type ] ); } return this; } if ( selector === false || typeof selector === "function" ) { // ( types [, fn] ) fn = selector; selector = undefined; } if ( fn === false ) { fn = returnFalse; } return this.each( function() { jQuery.event.remove( this, types, fn, selector ); } ); }, trigger: function( type, data ) { return this.each( function() { jQuery.event.trigger( type, data, this ); } ); }, triggerHandler: function( type, data ) { var elem = this[ 0 ]; if ( elem ) { return jQuery.event.trigger( type, data, elem, true ); } } } ); var rinlinejQuery = / jQuery\d+="(?:null|\d+)"/g, rnoshimcache = new RegExp( "<(?:" + nodeNames + ")[\\s/>]", "i" ), rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:-]+)[^>]*)\/>/gi, // Support: IE 10-11, Edge 10240+ // In IE/Edge using regex groups here causes severe slowdowns. // See https://connect.microsoft.com/IE/feedback/details/1736512/ rnoInnerhtml = /\s*$/g, safeFragment = createSafeFragment( document ), fragmentDiv = safeFragment.appendChild( document.createElement( "div" ) ); // Support: IE<8 // Manipulating tables requires a tbody function manipulationTarget( elem, content ) { return jQuery.nodeName( elem, "table" ) && jQuery.nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ? elem.getElementsByTagName( "tbody" )[ 0 ] || elem.appendChild( elem.ownerDocument.createElement( "tbody" ) ) : elem; } // Replace/restore the type attribute of script elements for safe DOM manipulation function disableScript( elem ) { elem.type = ( jQuery.find.attr( elem, "type" ) !== null ) + "/" + elem.type; return elem; } function restoreScript( elem ) { var match = rscriptTypeMasked.exec( elem.type ); if ( match ) { elem.type = match[ 1 ]; } else { elem.removeAttribute( "type" ); } return elem; } function cloneCopyEvent( src, dest ) { if ( dest.nodeType !== 1 || !jQuery.hasData( src ) ) { return; } var type, i, l, oldData = jQuery._data( src ), curData = jQuery._data( dest, oldData ), events = oldData.events; if ( events ) { delete curData.handle; curData.events = {}; for ( type in events ) { for ( i = 0, l = events[ type ].length; i < l; i++ ) { jQuery.event.add( dest, type, events[ type ][ i ] ); } } } // make the cloned public data object a copy from the original if ( curData.data ) { curData.data = jQuery.extend( {}, curData.data ); } } function fixCloneNodeIssues( src, dest ) { var nodeName, e, data; // We do not need to do anything for non-Elements if ( dest.nodeType !== 1 ) { return; } nodeName = dest.nodeName.toLowerCase(); // IE6-8 copies events bound via attachEvent when using cloneNode. if ( !support.noCloneEvent && dest[ jQuery.expando ] ) { data = jQuery._data( dest ); for ( e in data.events ) { jQuery.removeEvent( dest, e, data.handle ); } // Event data gets referenced instead of copied if the expando gets copied too dest.removeAttribute( jQuery.expando ); } // IE blanks contents when cloning scripts, and tries to evaluate newly-set text if ( nodeName === "script" && dest.text !== src.text ) { disableScript( dest ).text = src.text; restoreScript( dest ); // IE6-10 improperly clones children of object elements using classid. // IE10 throws NoModificationAllowedError if parent is null, #12132. } else if ( nodeName === "object" ) { if ( dest.parentNode ) { dest.outerHTML = src.outerHTML; } // This path appears unavoidable for IE9. When cloning an object // element in IE9, the outerHTML strategy above is not sufficient. // If the src has innerHTML and the destination does not, // copy the src.innerHTML into the dest.innerHTML. #10324 if ( support.html5Clone && ( src.innerHTML && !jQuery.trim( dest.innerHTML ) ) ) { dest.innerHTML = src.innerHTML; } } else if ( nodeName === "input" && rcheckableType.test( src.type ) ) { // IE6-8 fails to persist the checked state of a cloned checkbox // or radio button. Worse, IE6-7 fail to give the cloned element // a checked appearance if the defaultChecked value isn't also set dest.defaultChecked = dest.checked = src.checked; // IE6-7 get confused and end up setting the value of a cloned // checkbox/radio button to an empty string instead of "on" if ( dest.value !== src.value ) { dest.value = src.value; } // IE6-8 fails to return the selected option to the default selected // state when cloning options } else if ( nodeName === "option" ) { dest.defaultSelected = dest.selected = src.defaultSelected; // IE6-8 fails to set the defaultValue to the correct value when // cloning other types of input fields } else if ( nodeName === "input" || nodeName === "textarea" ) { dest.defaultValue = src.defaultValue; } } function domManip( collection, args, callback, ignored ) { // Flatten any nested arrays args = concat.apply( [], args ); var first, node, hasScripts, scripts, doc, fragment, i = 0, l = collection.length, iNoClone = l - 1, value = args[ 0 ], isFunction = jQuery.isFunction( value ); // We can't cloneNode fragments that contain checked, in WebKit if ( isFunction || ( l > 1 && typeof value === "string" && !support.checkClone && rchecked.test( value ) ) ) { return collection.each( function( index ) { var self = collection.eq( index ); if ( isFunction ) { args[ 0 ] = value.call( this, index, self.html() ); } domManip( self, args, callback, ignored ); } ); } if ( l ) { fragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored ); first = fragment.firstChild; if ( fragment.childNodes.length === 1 ) { fragment = first; } // Require either new content or an interest in ignored elements to invoke the callback if ( first || ignored ) { scripts = jQuery.map( getAll( fragment, "script" ), disableScript ); hasScripts = scripts.length; // Use the original fragment for the last item // instead of the first because it can end up // being emptied incorrectly in certain situations (#8070). for ( ; i < l; i++ ) { node = fragment; if ( i !== iNoClone ) { node = jQuery.clone( node, true, true ); // Keep references to cloned scripts for later restoration if ( hasScripts ) { // Support: Android<4.1, PhantomJS<2 // push.apply(_, arraylike) throws on ancient WebKit jQuery.merge( scripts, getAll( node, "script" ) ); } } callback.call( collection[ i ], node, i ); } if ( hasScripts ) { doc = scripts[ scripts.length - 1 ].ownerDocument; // Reenable scripts jQuery.map( scripts, restoreScript ); // Evaluate executable scripts on first document insertion for ( i = 0; i < hasScripts; i++ ) { node = scripts[ i ]; if ( rscriptType.test( node.type || "" ) && !jQuery._data( node, "globalEval" ) && jQuery.contains( doc, node ) ) { if ( node.src ) { // Optional AJAX dependency, but won't run scripts if not present if ( jQuery._evalUrl ) { jQuery._evalUrl( node.src ); } } else { jQuery.globalEval( ( node.text || node.textContent || node.innerHTML || "" ) .replace( rcleanScript, "" ) ); } } } } // Fix #11809: Avoid leaking memory fragment = first = null; } } return collection; } function remove( elem, selector, keepData ) { var node, elems = selector ? jQuery.filter( selector, elem ) : elem, i = 0; for ( ; ( node = elems[ i ] ) != null; i++ ) { if ( !keepData && node.nodeType === 1 ) { jQuery.cleanData( getAll( node ) ); } if ( node.parentNode ) { if ( keepData && jQuery.contains( node.ownerDocument, node ) ) { setGlobalEval( getAll( node, "script" ) ); } node.parentNode.removeChild( node ); } } return elem; } jQuery.extend( { htmlPrefilter: function( html ) { return html.replace( rxhtmlTag, "<$1>" ); }, clone: function( elem, dataAndEvents, deepDataAndEvents ) { var destElements, node, clone, i, srcElements, inPage = jQuery.contains( elem.ownerDocument, elem ); if ( support.html5Clone || jQuery.isXMLDoc( elem ) || !rnoshimcache.test( "<" + elem.nodeName + ">" ) ) { clone = elem.cloneNode( true ); // IE<=8 does not properly clone detached, unknown element nodes } else { fragmentDiv.innerHTML = elem.outerHTML; fragmentDiv.removeChild( clone = fragmentDiv.firstChild ); } if ( ( !support.noCloneEvent || !support.noCloneChecked ) && ( elem.nodeType === 1 || elem.nodeType === 11 ) && !jQuery.isXMLDoc( elem ) ) { // We eschew Sizzle here for performance reasons: http://jsperf.com/getall-vs-sizzle/2 destElements = getAll( clone ); srcElements = getAll( elem ); // Fix all IE cloning issues for ( i = 0; ( node = srcElements[ i ] ) != null; ++i ) { // Ensure that the destination node is not null; Fixes #9587 if ( destElements[ i ] ) { fixCloneNodeIssues( node, destElements[ i ] ); } } } // Copy the events from the original to the clone if ( dataAndEvents ) { if ( deepDataAndEvents ) { srcElements = srcElements || getAll( elem ); destElements = destElements || getAll( clone ); for ( i = 0; ( node = srcElements[ i ] ) != null; i++ ) { cloneCopyEvent( node, destElements[ i ] ); } } else { cloneCopyEvent( elem, clone ); } } // Preserve script evaluation history destElements = getAll( clone, "script" ); if ( destElements.length > 0 ) { setGlobalEval( destElements, !inPage && getAll( elem, "script" ) ); } destElements = srcElements = node = null; // Return the cloned set return clone; }, cleanData: function( elems, /* internal */ forceAcceptData ) { var elem, type, id, data, i = 0, internalKey = jQuery.expando, cache = jQuery.cache, attributes = support.attributes, special = jQuery.event.special; for ( ; ( elem = elems[ i ] ) != null; i++ ) { if ( forceAcceptData || acceptData( elem ) ) { id = elem[ internalKey ]; data = id && cache[ id ]; if ( data ) { if ( data.events ) { for ( type in data.events ) { if ( special[ type ] ) { jQuery.event.remove( elem, type ); // This is a shortcut to avoid jQuery.event.remove's overhead } else { jQuery.removeEvent( elem, type, data.handle ); } } } // Remove cache only if it was not already removed by jQuery.event.remove if ( cache[ id ] ) { delete cache[ id ]; // Support: IE<9 // IE does not allow us to delete expando properties from nodes // IE creates expando attributes along with the property // IE does not have a removeAttribute function on Document nodes if ( !attributes && typeof elem.removeAttribute !== "undefined" ) { elem.removeAttribute( internalKey ); // Webkit & Blink performance suffers when deleting properties // from DOM nodes, so set to undefined instead // https://code.google.com/p/chromium/issues/detail?id=378607 } else { elem[ internalKey ] = undefined; } deletedIds.push( id ); } } } } } } ); jQuery.fn.extend( { // Keep domManip exposed until 3.0 (gh-2225) domManip: domManip, detach: function( selector ) { return remove( this, selector, true ); }, remove: function( selector ) { return remove( this, selector ); }, text: function( value ) { return access( this, function( value ) { return value === undefined ? jQuery.text( this ) : this.empty().append( ( this[ 0 ] && this[ 0 ].ownerDocument || document ).createTextNode( value ) ); }, null, value, arguments.length ); }, append: function() { return domManip( this, arguments, function( elem ) { if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { var target = manipulationTarget( this, elem ); target.appendChild( elem ); } } ); }, prepend: function() { return domManip( this, arguments, function( elem ) { if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { var target = manipulationTarget( this, elem ); target.insertBefore( elem, target.firstChild ); } } ); }, before: function() { return domManip( this, arguments, function( elem ) { if ( this.parentNode ) { this.parentNode.insertBefore( elem, this ); } } ); }, after: function() { return domManip( this, arguments, function( elem ) { if ( this.parentNode ) { this.parentNode.insertBefore( elem, this.nextSibling ); } } ); }, empty: function() { var elem, i = 0; for ( ; ( elem = this[ i ] ) != null; i++ ) { // Remove element nodes and prevent memory leaks if ( elem.nodeType === 1 ) { jQuery.cleanData( getAll( elem, false ) ); } // Remove any remaining nodes while ( elem.firstChild ) { elem.removeChild( elem.firstChild ); } // If this is a select, ensure that it displays empty (#12336) // Support: IE<9 if ( elem.options && jQuery.nodeName( elem, "select" ) ) { elem.options.length = 0; } } return this; }, clone: function( dataAndEvents, deepDataAndEvents ) { dataAndEvents = dataAndEvents == null ? false : dataAndEvents; deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents; return this.map( function() { return jQuery.clone( this, dataAndEvents, deepDataAndEvents ); } ); }, html: function( value ) { return access( this, function( value ) { var elem = this[ 0 ] || {}, i = 0, l = this.length; if ( value === undefined ) { return elem.nodeType === 1 ? elem.innerHTML.replace( rinlinejQuery, "" ) : undefined; } // See if we can take a shortcut and just use innerHTML if ( typeof value === "string" && !rnoInnerhtml.test( value ) && ( support.htmlSerialize || !rnoshimcache.test( value ) ) && ( support.leadingWhitespace || !rleadingWhitespace.test( value ) ) && !wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) { value = jQuery.htmlPrefilter( value ); try { for ( ; i < l; i++ ) { // Remove element nodes and prevent memory leaks elem = this[ i ] || {}; if ( elem.nodeType === 1 ) { jQuery.cleanData( getAll( elem, false ) ); elem.innerHTML = value; } } elem = 0; // If using innerHTML throws an exception, use the fallback method } catch ( e ) {} } if ( elem ) { this.empty().append( value ); } }, null, value, arguments.length ); }, replaceWith: function() { var ignored = []; // Make the changes, replacing each non-ignored context element with the new content return domManip( this, arguments, function( elem ) { var parent = this.parentNode; if ( jQuery.inArray( this, ignored ) < 0 ) { jQuery.cleanData( getAll( this ) ); if ( parent ) { parent.replaceChild( elem, this ); } } // Force callback invocation }, ignored ); } } ); jQuery.each( { appendTo: "append", prependTo: "prepend", insertBefore: "before", insertAfter: "after", replaceAll: "replaceWith" }, function( name, original ) { jQuery.fn[ name ] = function( selector ) { var elems, i = 0, ret = [], insert = jQuery( selector ), last = insert.length - 1; for ( ; i <= last; i++ ) { elems = i === last ? this : this.clone( true ); jQuery( insert[ i ] )[ original ]( elems ); // Modern browsers can apply jQuery collections as arrays, but oldIE needs a .get() push.apply( ret, elems.get() ); } return this.pushStack( ret ); }; } ); var iframe, elemdisplay = { // Support: Firefox // We have to pre-define these values for FF (#10227) HTML: "block", BODY: "block" }; /** * Retrieve the actual display of a element * @param {String} name nodeName of the element * @param {Object} doc Document object */ // Called only from within defaultDisplay function actualDisplay( name, doc ) { var elem = jQuery( doc.createElement( name ) ).appendTo( doc.body ), display = jQuery.css( elem[ 0 ], "display" ); // We don't have any data stored on the element, // so use "detach" method as fast way to get rid of the element elem.detach(); return display; } /** * Try to determine the default display value of an element * @param {String} nodeName */ function defaultDisplay( nodeName ) { var doc = document, display = elemdisplay[ nodeName ]; if ( !display ) { display = actualDisplay( nodeName, doc ); // If the simple way fails, read from inside an iframe if ( display === "none" || !display ) { // Use the already-created iframe if possible iframe = ( iframe || jQuery( ""); w = $(document).width() * 0.9; h = $(document).height() * 0.85; var hattr = elem.attr("data-dunebox-height"); var wattr = elem.attr("data-dunebox-width"); if (typeof wattr !== typeof undefined && wattr !== false) w = elem.attr("data-dunebox-width").replace("px", ''); if (typeof hattr !== typeof undefined && hattr !== false) h = elem.attr("data-dunebox-height").replace("px", ''); duneBoxID += 10; cb(content, h, w, gallery, elem, type); /* TODO : Resize de toutes les autres en dessous */ break; } } thi.close = function (elem) { $(document).off('keyup',single.BindKeyUp); window.top.duneBoxBinded.pop(); if (elem.hasClass("duneBox-backto")) { var backto = elem.attr("data-dunebox-backto"); var cnt = elem.find(".duneBox-inner").contents(); $(".duneBox-placeholder[data-dunebox-selector='" + backto + "']").after(cnt); $(".duneBox-placeholder[data-dunebox-selector='" + backto + "']").remove(); } clearInterval(thi.resizeInt); elem.remove(); single.elems.pop(); } thi.openDBBox = function (type, elem) { var g = elem.attr("gal"); var gc = ($("*[gal=" + g + "]")) ? $("*[gal=" + g + "]").length : null; var gi = (gc > 1) ? elem.index("*[gal=" + g + "]") : 0; if (gi <= 0 && elem.attr("gal-index")) { gi = parseInt(elem.attr("gal-index")); } /* FIX POUR PASSER SUR DUNEBOX V2 PETIT A PETIT - BERTRAND */ if ( typeof g !== "undefined" && (typeof CMSV1 == 'undefined' || !CMSV1)) { $.duneBoxV2.open($(thi).attr('href'), null, $(thi)); return true; } var t = type; var req = thi.createContent(type, elem, function (content, h, w, g, e, ty) { thi.defaultDBOpt.beforeopen(e); if (ty) t = ty; var modal = thi.createBox(content, w, h, t, e, g); modal = thi.loadContent(content, w, h, t, e, g, modal); if (gc > 0) { modal = thi.addGrpEvents(content, w, h, t, e, g, modal); } modal = thi.addEvents(content, w, h, t, e, g, modal); thi.resizeInt = window.setInterval(function () { thi.resize(modal, e, t, w, h); }, 1000); //thi.defaultDBOpt.onopen(e, modal); if (thi.defaultDBOpt.onopen instanceof Function) r = thi.defaultDBOpt.onopen(e, modal); else r = eval('(function(elem) {' + thi.defaultDBOpt.onopen + "}())"); }); window.top.duneBoxBinded.push(single); } $(thi).off("click").on("click", function (e) { bindClick($(this), e, thi); }); return thi; } this.each(function () { bind(this); }); function bindClick(element, e, thi) { var href = (element.attr("href")) ? element.attr("href") : null; var type = 'div'; var shref = href.split("?"); shref = shref[0].split("."); var ext = shref[shref.length - 1]; if (ext.toLowerCase() == 'pdf') { type = "iframe"; } else if ($.inArray(ext.toLowerCase(), imgExts) >= 0) { type = "image"; } else if (href.substr(0, 4) == 'http') { type = "iframe"; } else if ($.inArray(ext.toLowerCase(), ajaxExts) >= 0) { type = "ajax"; } else if (href.substr(0, 1) == '#') { type = "div"; } else { type = "html"; } if (element.attr("data-dunebox-type")) { type = element.attr("data-dunebox-type"); } type = (element.attr("data-dunebox-type")) ? element.attr("data-dunebox-type") : type; if($(window).width()<800 && (typeof IsNotAWebsite == "undefined" || !IsNotAWebsite)){ switch (type) { // case 'image': // element.off("click"); // element.attr("target", "_blank"); // return true; // break; case 'iframe': if (forceOpenIframe){ e.preventDefault(); e.stopPropagation(); thi.openDBBox(type, element); break; } else { element.off("click"); element.attr("target", "_blank"); return true; break; } default: e.preventDefault(); e.stopPropagation(); thi.openDBBox(type, element); break; } } else { e.preventDefault(); e.stopPropagation(); thi.openDBBox(type, element); } } return single; }; (function ($) { $.fn.hasScrollBar = function () { var e = this.get(0); return { vertical: e.scrollHeight > e.clientHeight, horizontal: e.scrollWidth > e.clientWidth }; }; })(jQuery); if (typeof window.top.duneBoxCloseLast !== "function") { window.top.duneBoxCloseLast = function () { if (Object.assign({},window.top.duneBoxBinded).length) { window.top.duneBoxBinded[window.top.duneBoxBinded.length - 1].close(); } else if(window.parent.duneBox && typeof window.parent.duneBox === "object") { window.parent.duneBox.forceCloseAll(); } return true; }; }/* V2.34 - 13.01.2022 16:14 */ /* * === 2.34 === * - Nouvelle fonctionnalité: * * - ajout de l'option defaultSelectAll pour que tout soit sélectionné par défaut * * === 2.33 === * - Nouvelle fonctionnalité: * * - ajout de l'option triggersChangeEventAfterSelectAll pour empêcher le onchange quand on sélectionne tout * * === 2.32 === * - Correction de bug: * * - suppression des undefined dans les options. * * === 2.31 === * - Nouvelle fonctionnalité: * * - nouveau attribut, data-value, pour préselectioner des données * * - FORMAT: * * * - NORMAL: ID||ID||ID||ID * * * - AJAX: ID,LABEL||ID,LABEL||ID,LABEL||ID,LABEL * * === 2.22 === * - Correction de bug: * * - preventDefault sur "enter" sur le champ de recherche. * * === 2.21 === * - Correction de bug: * * - Correction du bug "click outside" quand alwaysOpen est "true" * * === 2.20 === * - Correction de bug: * * - Recherche très lente lorsque duneselect est dans une Iframe * * - Recherche deux fois sur la meme string, aucune recherche effectuée * * === 2.12 === * - Correction de bug: * * - Suppression du change au load * * - Affichage multiple su champ single * * === 2.11 === * - Nouvelle fonctionnalitée: * * - Checkbox > glyphicons * * - selectWidth * * - "search" est maintenant le Threshold (int) * * === 2.10 === * - Nouvelle fonctionnalitée: * * - Selection des groupes possible en select "unique" (non multiple) * * - Ajout du paramètre selectableGroup (0|1)*0 * */ var duneSelect_SETTINGS = { // Defaults. multiple: 'auto', search: false, maxHeight: "250px", closeOnSelect: true, displayLimit: "auto", displayBreak: false, checkbox: true, truncateTextOptions: false, searchThreshold: 3, // chevronWidth: 35, chevronWidth: 18, expanded: false, additionalWidth: 0, maxSelected: 0, selectAllButton: true, ajax: false, alwaysOpen: false, dropdownWidth: 100, selectWidth: false, selectableGroup: false, ajaxUrl: "", selectedText: "sélectionnés", noneText: "Aucun", displayAllSelectedText: true, allSelectedText: "Tous", SelectAllText: "Tout cocher", DeSelectAllText: "Tout décocher", maxSelectedText: "Vous ne pouvez pas sélectionner plus d'options", closeSelector: "html", optGroupOnSelect: "all", triggersChangeEventAfterSelectAll: true, dropdownPositionFixed: false, defaultSelectAll:false, dunePopTitle: '', }; var duneSelect_SETTINGS_fr = { selectedText: "sélectionnés", noneText: "Aucun", allSelectedText: "Tous", SelectAllText: "Tout cocher", DeSelectAllText: "Tout décocher", maxSelectedText: "Vous ne pouvez pas sélectionner plus d'options", }; var duneSelect_SETTINGS_de = { selectedText: "ausgewählt", noneText: "Kein", allSelectedText: "Alle", SelectAllText: "Alles ankreuzen", DeSelectAllText: "Alle Markierungen entfernen", maxSelectedText: "Sie können keine weiteren Optionen wählen", }; var duneSelect_SETTINGS_en = { selectedText: "selected", noneText: "None", allSelectedText: "All", SelectAllText: "Check all", DeSelectAllText: "Uncheck all", maxSelectedText: "You cannot select more options", }; var duneSelect_SETTINGS_es = { selectedText: "seleccionado", noneText: "Ninguno", allSelectedText: "Todos", SelectAllText: "Marcar todo", DeSelectAllText: "Desmarcar todo", maxSelectedText: "No puedes seleccionar más opciones", }; var duneSelect_SETTINGS_po = { selectedText: "selecionado", noneText: "Nenhum", allSelectedText: "Todos", SelectAllText: "Seleccionar todas", DeSelectAllText: "Desmarcar", maxSelectedText: "Você não pode selecionar mais opções", }; var duneSelect_SETTINGS_it = { selectedText: "selezionato", noneText: "Nessuno", allSelectedText: "Tutti i", SelectAllText: "Seleziona tutto", DeSelectAllText: "Deseleziona tutto", maxSelectedText: "Non è possibile selezionare più opzioni", }; (function ($) { var duneSelectInstances = []; var instanceID = 1; $.fn.duneSelect = function (options) { switch (options) { case 'select': if (!arguments[1]) return false; if (!arguments[2]) return false; var element = arguments[1]; var value = arguments[2]; var elemInstance = 0; if (typeof element == 'number') { elemInstance = element; } else { elemInstance = element.attr("data-instance"); } if (duneSelectInstances[elemInstance]) { var currentInstance = duneSelectInstances[elemInstance]; if (currentInstance.settings.ajax) { if (value instanceof Array ) { $.each(value, function (k, v) { if (!v.name && v.value) v.name = v.value; if (!v.value && v.name) v.value = v.name; var r = currentInstance.setAjaxSelection(v, true); if (!r) return; }); } else { if (!value.name && value.value) value.name = value.value; if (!value.value && value.name) value.value = value.name; currentInstance.setAjaxSelection(value, true); } return true; } if (value instanceof Array) { $.each(value, function (k, v) { // console.log($.escapeSelector(v)); var option = currentInstance.contain.find(".duneselect-option[value='" + v.replace(/'/gi,"\\'") + "']"); if (option.length) { var r = currentInstance.setSelection(option, true); if (!r) return; } //else console.log("Option " + v + " introuvable"); }); } else { var option = currentInstance.contain.find(".duneselect-option[value='" + value + "']"); if (option.length) currentInstance.setSelection(option, true); //else console.log("Option " + value + " introuvable"); } } //else console.log("Instance inconnue"); return true; break; case 'selectOnly': if (!arguments[1]) return false; if (!arguments[2]) return false; var element = arguments[1]; var value = arguments[2]; var elemInstance = 0; if (typeof element == 'number') { elemInstance = element; } else elemInstance = element.attr("data-instance"); if (duneSelectInstances[elemInstance]) { var currentInstance = duneSelectInstances[elemInstance]; var oldOptGroupOnSelect = currentInstance.settings.optGroupOnSelect; currentInstance.settings.optGroupOnSelect = 'optgroup'; if (currentInstance.settings.ajax) { if (value instanceof Array) { $.each(value, function (k, v) { if (!v.name && v.value) v.name = v.value; if (!v.value && v.name) v.value = v.name; var r = currentInstance.setAjaxSelection(v, true); if (!r) return; }); } else { if (!value.name && value.value) value.name = value.value; if (!value.value && value.name) value.value = value.name; currentInstance.setAjaxSelection(value, true); } currentInstance.settings.optGroupOnSelect = oldOptGroupOnSelect; return true; } if (value instanceof Array) { $.each(value, function (k, v) { var option = currentInstance.contain.find(".duneselect-option[value='" + v + "']"); if (option.length) { var r = currentInstance.setSelection(option, true); if (!r) return; } //else console.log("Option " + v + " introuvable"); }); } else { var option = currentInstance.contain.find(".duneselect-option[value='" + value + "']"); if (option.length) currentInstance.setSelection(option, true); //else console.log("Option " + value + " introuvable"); } currentInstance.settings.optGroupOnSelect = oldOptGroupOnSelect; } //else console.log("Instance inconnue"); return true; break; case 'unselect': if (!arguments[1]) return false; if (!arguments[2]) return false; var element = arguments[1]; var value = arguments[2]; var elemInstance = 0; if (typeof element == 'number') { elemInstance = element; } else elemInstance = element.attr("data-instance"); if (duneSelectInstances[elemInstance]) { var currentInstance = duneSelectInstances[elemInstance]; if (currentInstance.settings.ajax) { if (value instanceof Array) { $.each(value, function (k, v) { currentInstance.unselectAjax(v); }); } else { currentInstance.unselectAjax(value); } return true; } if (value instanceof Array) { $.each(value, function (k, v) { var option = currentInstance.contain.find(".duneselect-option[value='" + v + "']"); if (option.length) currentInstance.unselect(option); //else console.log("Option " + v + " introuvable"); }); } else { var option = currentInstance.contain.find(".duneselect-option[value='" + value + "']"); if (option.length) currentInstance.unselect(option); //else console.log("Option " + value + " introuvable"); } } //else console.log("Instance inconnue"); return true; break; case 'unselectOnly': if (!arguments[1]) return false; if (!arguments[2]) return false; var element = arguments[1]; var value = arguments[2]; var elemInstance = 0; if (typeof element == 'number') { elemInstance = element; } else elemInstance = element.attr("data-instance"); if (duneSelectInstances[elemInstance]) { var currentInstance = duneSelectInstances[elemInstance]; var oldOptGroupOnSelect = currentInstance.settings.optGroupOnSelect; currentInstance.settings.optGroupOnSelect = 'optgroup'; if (currentInstance.settings.ajax) { if (value instanceof Array) { $.each(value, function (k, v) { currentInstance.unselectAjax(v); }); } else { currentInstance.unselectAjax(value); } currentInstance.settings.optGroupOnSelect = oldOptGroupOnSelect; return true; } if (value instanceof Array) { $.each(value, function (k, v) { var option = currentInstance.contain.find(".duneselect-option[value='" + v + "']"); if (option.length) currentInstance.unselect(option); //else console.log("Option " + v + " introuvable"); }); } else { var option = currentInstance.contain.find(".duneselect-option[value='" + value + "']"); if (option.length) currentInstance.unselect(option); //else console.log("Option " + value + " introuvable"); } currentInstance.settings.optGroupOnSelect = oldOptGroupOnSelect; } //else console.log("Instance inconnue"); return true; break; case 'unselectAll': if (!arguments[1]) return false; var element = arguments[1]; var elemInstance = 0; if (typeof element == 'number') { elemInstance = element; } else elemInstance = element.attr("data-instance"); if (duneSelectInstances[elemInstance]) { var currentInstance = duneSelectInstances[elemInstance]; currentInstance.deSelectAll(true); } //else console.log("Instance inconnue"); return true; break; case 'selectAll': if (!arguments[1]) return false; var element = arguments[1]; var elemInstance = 0; if (typeof element == 'number') { elemInstance = element; } else { elemInstance = element.attr("data-instance"); } if (duneSelectInstances[elemInstance]) { var currentInstance = duneSelectInstances[elemInstance]; currentInstance.selectAll(); } return true; break; default: break; } var objs = []; var settings = {}; $.extend(settings, duneSelect_SETTINGS); var lang = $('html').attr('lang'); if (window["duneSelect_SETTINGS_" + lang]) { $.extend(settings, window["duneSelect_SETTINGS_" + lang]); } else { $.extend(settings, duneSelect_SETTINGS_fr); } $.extend(settings, options); var bind = function (thi) { if ($(thi).attr("data-instance")) { $(".duneselect-contain[data-instance=" + $(thi).attr("data-instance") + "]").remove(); } var orig = $(thi); thi.obj = { selectedDefault: [], optionCount: 0, loaded: false, instance: instanceID, optgroup: false, prevSearch: '', first: true, lastGroupName: '', lastGroupValue: '', original: orig, allowDeselect: false, lastPressKey: 0, selection: [], selectionValue: [], searchTimeOut: 0, expanded:false, ajaxAllDisplayed: true, defaultSelectAll: false, settings: $.extend({}, settings) }; if (thi.obj.settings.multiple == 'auto') { if ($(thi).prop("multiple")) { thi.obj.settings.multiple = $(thi).prop("multiple"); } else { thi.obj.settings.multiple = false; } } if (thi.obj.settings.multiple == true) { thi.obj.settings.closeOnSelect = false; } if ($(thi).attr("data-duneselect-options") && $(thi).attr("data-duneselect-options") !== '') { var optsStr = $(thi).attr("data-duneselect-options"); var opts = optsStr.split(";"); for (var optK in opts) { var opt = opts[optK]; if (opt !== '') { var optS = opt.split(":"); if (optS[0] && optS[1]) $(thi).attr("data-duneselect-" + optS[0], optS[1]); } } } if ($(thi).attr("data-duneselect-allowdeselect") == '1') { thi.obj.allowDeselect = true; } for (var i in thi.obj.settings) { if ($(thi).attr("data-duneselect-" + i)) { if (i == "selectableGroup" && $(thi).attr("data-duneselect-" + i) == '0') { thi.obj.settings[i] = false; } else if (i == "checkbox" && $(thi).attr("data-duneselect-" + i) == '0') { thi.obj.settings[i] = true; } else if (i == "search" && $(thi).attr("data-duneselect-" + i) == '0') { thi.obj.settings[i] = false; } else if (i.toLowerCase() == "additionalwidth") { thi.obj.settings[i] = parseInt($(thi).attr("data-duneselect-" + i)); } else { thi.obj.settings[i] = $(thi).attr("data-duneselect-" + i); } } } if (thi.obj.settings.ajax) { thi.obj.settings.search = 3; } instanceID++; /** ### METHODS ### */ /** === INIT === */ /**INIT THE SELECT BOX */ thi.obj.createBlock = function () { thi.obj.original.hide(); var contain = $("
"); if (thi.obj.original.attr("id")) { contain.attr("id", "duneselect-" + thi.obj.original.attr("id")); } thi.obj.contain = contain; var outer = $("
"); var display = $("
"); if (thi.obj.original.find("[data-group]").length > 0) { thi.obj.optgroup = true; } contain.addClass("duneselect-contain"); contain.attr("tabindex","0"); contain.attr("data-instance", thi.obj.instance); thi.obj.original.attr("data-instance", thi.obj.instance); var w = thi.obj.original.outerWidth(); if (thi.obj.settings.selectWidth) { w = thi.obj.settings.selectWidth; } if (thi.obj.settings.additionalWidth) { w += thi.obj.settings.additionalWidth; } contain.css("width", w); outer.addClass("duneselect-outer"); outer.appendTo(contain); display.addClass("duneselect-display"); display.appendTo(outer); var options; if (thi.obj.settings.ajax === false) { if (thi.obj.settings.alwaysOpen) { contain.addClass("duneselect-alwaysOpen"); thi.obj.settings.chevronWidth = 10; } options = thi.obj.generateOptions(); options.appendTo(contain); thi.obj.bindMainEvents(); thi.obj.contain.insertAfter($(thi)); thi.obj.loaded = true; thi.obj.selectOptions(); thi.obj.displaySelection(); } else { options = thi.obj.generateAjaxOptions(contain); } if (thi.obj.settings.expanded) { display.addClass('duneselect-expanded') } if (thi.obj.first) { thi.obj.first = false; } // thi.obj.original.hide(); }; /**INIT THE SEARCH INPUT */ thi.obj.generateSearch = function () { var search = $("
"); search.addClass("duneselect-search"); var searchInput = $(""); searchInput.appendTo(search); return search; }; /**INIT ALL OPTIONS */ thi.obj.generateAjaxOptions = function (contain) { var dropdown = $("
"); if (thi.obj.settings.dropdownWidth && thi.obj.settings.dropdownWidth > contain.width()) { dropdown.width(thi.obj.settings.dropdownWidth + "px"); } dropdown.addClass("duneselect-dropdown"); var options = $("
"); options.css("max-height", thi.obj.settings.maxHeight); options.addClass("duneselect-options"); if (thi.obj.settings.search || thi.obj.settings.ajax) { var search = thi.obj.generateSearch(); dropdown.append(search); } dropdown.appendTo(contain); thi.obj.contain.insertAfter($(thi)); var paramsAjax = {action: "getAll", selectedVal: thi.obj.original.val()}; if (thi.obj.settings.ajaxUrl.indexOf('selectedVal') !== -1) { paramsAjax = {action: "getAll"}; } $.ajax({ url: thi.obj.settings.ajaxUrl, data: paramsAjax }).done(function (msg) { var json = JSON.parse(msg); var originalOptions = []; if (json && json.options) for (var j in json.options) { var e = thi.obj.generateAjaxOption(json.options[j]); originalOptions.push(e); } if (originalOptions) for (var i in originalOptions) { var o = originalOptions[i]; options.append(thi.obj.generateOption(o)); } options.appendTo(dropdown); thi.obj.bindMainEvents(); thi.obj.loaded = true; thi.obj.displaySelection(); // $(thi).hide(); }); return dropdown; }; /**INIT ALL OPTIONS */ thi.obj.generateOptions = function () { var dropdown = $("
"); if (thi.obj.settings.dropdownWidth && thi.obj.settings.dropdownWidth > thi.obj.contain.width()) { dropdown.width(thi.obj.settings.dropdownWidth + "px"); } dropdown.addClass("duneselect-dropdown"); var options = $("
"); options.css("max-height", thi.obj.settings.maxHeight); options.addClass("duneselect-options"); var originalOptions = thi.obj.original.children("option"); var opts = ''; if (originalOptions) thi.obj.original.children("option").each(function () { var o = $(this); opts += thi.obj.generateOption(o); }); options.append(opts); if (thi.obj.settings.search && thi.obj.optionCount >= thi.obj.settings.search) { var search = thi.obj.generateSearch(); dropdown.prepend(search); } else { thi.obj.settings.search = false; } if (thi.obj.settings.multiple == true && thi.obj.settings.selectAllButton && (thi.obj.settings.maxSelected == 0 || thi.obj.settings.maxSelected >= thi.obj.optionCount)) { var selectAllBtn = $("
"); selectAllBtn.addClass("duneselect-selectAll"); selectAllBtn.attr("data-all", 0); selectAllBtn.html(thi.obj.settings.SelectAllText); // selectAllBtn.prepend(' '); selectAllBtn.prependTo(options); } dropdown.append(options); return dropdown; }; thi.obj.generateAjaxOption = function (opt) { var e = $(""); e.attr("value", opt.value); e.attr("title", opt.name); if (opt.group) e.attr("data-group", opt.group); if (opt.disabled) e.prop("disabled", "disabled"); if(opt.selected) e.prop("selected","selected"); e.html(opt.name); if (opt.group && opt.group !== false) thi.obj.optgroup = true; return e; }; thi.obj.usedValues = []; /** INIT ONE OPTION */ thi.obj.generateOption = function (original) { var rt = arguments[1] || false; if (original.val() == '') { thi.obj.allowDeselect = true; } var increment = 1; var checkbox = ''; var addClass = []; var attrs = []; if (thi.obj.settings.checkbox && thi.obj.settings.multiple == true && !(original.attr("data-group") && (thi.obj.settings.optGroupOnSelect == 'options' || thi.obj.settings.optGroupOnSelect == 'none'))) { checkbox = ""; } else { if (thi.obj.settings.multiple == true && !(original.attr("data-group") && (thi.obj.settings.optGroupOnSelect == 'options' || thi.obj.settings.optGroupOnSelect == 'none'))) { addClass.push("duneselect-nocheckbox"); } } if (original.attr("data-group") && (thi.obj.settings.optGroupOnSelect == 'options' || thi.obj.settings.optGroupOnSelect == 'none')) { increment = 0; } if (thi.obj.settings.ajax) { increment = 0; } if (original.attr("data-group")) { attrs.push('data-group="' + original.attr("data-group") + '"'); thi.obj.lastGroupName = original.text(); thi.obj.lastGroupValue = original.attr("value"); addClass.push("duneselect-group"); } else if (thi.obj.optgroup) { addClass.push("duneselect-child"); attrs.push('data-parent="' + thi.obj.lastGroupValue + '"'); } attrs.push('data-insearch="true"'); var originaldttext = original.attr("data-duneselect-text") ? original.attr("data-duneselect-text") : ""; if (thi.obj.lastGroupName !== '' && !original.attr("data-group")) { attrs.push('data-text="' + original.text() + " " + originaldttext + " " + thi.obj.lastGroupName + '"'); } else { attrs.push('data-text="' + original.text() + " " + originaldttext + '"'); } if (original.prop("disabled")) { addClass.push("duneselect-disabled"); } if (checkbox){ addClass.push("duneselect-optionWithCheckbox"); } /* ADD BERTRAND - LE 07/10/2020 - TITLE SUR L'OPTION POUR POUVOIR VOIR LA VALEUR QUAND LE DUNESELECT EST TROP PETIT */ // attrs.push('title="' + original.text() + " " + originaldttext + '"'); // Virer par fab car ne contient pas les url de sites // attrs.push('title="' + original.text() + '"'); attrs.push('title="' + originaldttext + '"'); var option = '
0 && txt.length > truncateTxt ){ var hooks = txt.match(/(\[[^)]+\])/); txt = txt.replace(/(\[[^)]+\])/g, ''); txt = txt.slice(0, truncateTxt) + "..."; if (hooks && hooks[0]) { txt += hooks[0]; } } option += ' ' + attrs.join(" ") + ' class="DS_' + thi.obj.instance + '-' + classUniq + ' duneselect-option ' + classAttr + ' ' + addClass.join(" ") + '">' + checkbox + htmlPrefix + txt + '
'; var optionDiv = $(option); if (original.prop("selected")) { if (thi.obj.selectedDefault.indexOf(optionDiv.attr("value")) < 0) { thi.obj.selectedDefault.push(optionDiv.attr("value")); thi.obj.setSelection(optionDiv, false, true); } } if (thi.obj.usedValues.indexOf(original.val()) === -1) { thi.obj.optionCount += increment; thi.obj.usedValues.push(original.val()); } if (rt == 'dom') { return $(option); } return option; }; thi.obj.bindDisplayEvents = function () { var display = thi.obj.contain.find(".duneselect-display"); display.find(".duneselect-cross").off("click").click(function (e) { e.preventDefault(); e.stopPropagation(); thi.obj.unselectCross($(this)); }); if (thi.obj.settings.dunePopTitle && typeof $.fn.dunePop !== 'undefined') { display.find('.duneselect-display-text').dunePop(); } }; /**BIND ALL EVENTS */ thi.obj.bindMainEvents = function () { $(thi.obj.settings.closeSelector).on("click", function (e) { //e.stopPropagation(); $(this).find(".duneselect-contain").removeClass("open"); $(this).find(".duneselect-dropdown").removeClass("open"); thi.obj.contain.find(".duneselect-search input").val(''); if (!thi.obj.settings.alwaysOpen) { thi.obj.contain.find(".duneselect-search input").val(''); thi.obj.search(""); thi.obj.prevSearch = ''; } }); $(".duneBox-inner").off("click").on("click", function (e) { $(this).find(".duneselect-contain").removeClass("open"); $(this).find(".duneselect-dropdown").removeClass("open"); if (!thi.obj.settings.alwaysOpen) { $(this).find(".duneselect-search input").val(''); thi.obj.search(""); thi.obj.prevSearch = ''; } }); var options = thi.obj.contain.find(".duneselect-dropdown"); var search = thi.obj.contain.find(".duneselect-search"); thi.obj.contain.off("click").on("click", function (e) { e.preventDefault(); e.stopPropagation(); $(".duneselect-contain").each(function () { if ($(this).attr("data-instance") != thi.obj.contain.attr("data-instance")) { $(this).find(".duneselect-dropdown").removeClass("open"); $(this).removeClass("open"); if (!thi.obj.settings.alwaysOpen) { $(this).find(".duneselect-search input").val(''); thi.obj.search(""); thi.obj.prevSearch = ''; } } }); e.stopPropagation(); options.toggleClass("open"); thi.obj.contain.toggleClass("open"); if (options.hasClass("open")) { if ( $(this).closest('.duneBox-inner').length ) { var duneSelectPosition = $(this).position(); var duneSelectHeight = $(this).height(); var optionsHeight = options.height(); var totalDuneSelect = parseInt(duneSelectPosition.top) + parseInt(duneSelectHeight) + parseInt(optionsHeight); totalDuneBox = parseInt($(this).closest('.duneBox-inner').height()); if ( totalDuneSelect > totalDuneBox ) { $(this).closest('.duneBox-inner').css('height', totalDuneSelect); } } options.find(".duneselect-search input").focus(); if (thi.obj.settings.dropdownPositionFixed) { options.removeAttr("style"); var realPositionDropdown = options.get(0).getBoundingClientRect(); options.attr("style", "top:" + realPositionDropdown.top + "px !important; left:" + realPositionDropdown.left + "px !important; width:" + realPositionDropdown.width + "px !important; position:fixed !important;"); // recalculer la position car sinon il y a un bug de quelques pixels ... var realPositionContain = options.closest(".duneselect-contain").get(0).getBoundingClientRect(); options.attr("style", "top:" + realPositionDropdown.top + "px !important; left:" + realPositionContain.left + "px !important; width:" + realPositionDropdown.width + "px !important; position:fixed !important; margin: 0 0 0 0!important;"); } } else { options.find(".duneselect-search input").val(""); thi.obj.search(""); if (!thi.obj.settings.alwaysOpen) { thi.obj.prevSearch = ''; } if ( $(this).closest('.duneBox-inner').length ) { $(this).closest('.duneBox-inner').css('height', totalDuneBox); } } }); $(".duneselect-dropdown").off("click").on("click", function (e) { e.stopPropagation(); }); $(".duneselect-options").off("click").on("click", function (e) { e.stopPropagation(); }); options.find(".duneselect-option").off("click").on("click", function (e) { e.stopPropagation(); if (!thi.obj.settings.multiple && !thi.obj.settings.selectableGroup && $(this).hasClass("duneselect-group")) return; thi.obj.setSelection($(this)); if (thi.obj.settings.closeOnSelect == 0) thi.obj.settings.closeOnSelect = false; if (thi.obj.settings.closeOnSelect && !$(this).hasClass("duneselect-disabled")) { $(this).parent().parent().removeClass("open"); thi.obj.contain.removeClass("open"); } }); options.find(".duneselect-search").off("click").on("click", function (e) { e.stopPropagation(); }); if (thi.obj.settings.search) { thi.obj.lastPressKey = 0; search.children("input").on("keydown", function (e) { thi.obj.lastPressKey = e.keyCode; if (thi.obj.lastPressKey && thi.obj.lastPressKey == 13) { e.stopPropagation(); e.preventDefault(); return false; } }); search.children("input").on("keyup", function (e) { thi.obj.lastPressKey = e.keyCode; if (thi.obj.lastPressKey && thi.obj.lastPressKey == 13) { e.stopPropagation(); e.preventDefault(); return false; } $(this).trigger("search"); }); search.children("input").on("search", function (e) { if (thi.obj.lastPressKey && thi.obj.lastPressKey == 13) { e.preventDefault(); e.stopPropagation(); return false; } if (thi.obj.searchTimeOut) window.clearTimeout(thi.obj.searchTimeOut); var sVal = $(this).val(); thi.obj.searchTimeOut = setTimeout(function () { thi.obj.search(sVal); //console.log("sVal : "+sVal); }, 250); }); } options.find(".duneselect-selectAll, .duneselect-selectAll input").off("click").click(function (e) { e.preventDefault(); e.stopPropagation(); if ($(this).attr("data-all") == 0) { thi.obj.selectAll(); $(this).attr("data-all", 1); $(this).text(thi.obj.settings.DeSelectAllText); $(this).find(".dscb").removeClass("glyphicons-unchecked"); $(this).find(".dscb").addClass("glyphicons-check"); } else { thi.obj.deSelectAll(); $(this).attr("data-all", 0); $(this).text(thi.obj.settings.SelectAllText); $(this).find(".dscb").removeClass("glyphicons-check"); $(this).find(".dscb").addClass("glyphicons-unchecked"); } $(thi).change(); return false; }); }; /** === BACKGROUND ACTIONS === */ /**USED TO DISPLAY SELECTED OPTION(S) */ thi.obj.displaySelection = function () { var display = thi.obj.contain.find(".duneselect-display"); display.html(""); var htmlDisplay = ''; if (thi.obj.selection.length == 0) { if (!thi.obj.allowDeselect) { htmlDisplay = thi.obj.settings.noneText; } else { htmlDisplay = thi.obj.contain.find(".duneselect-option[value='']").text(); } } else { if (thi.obj.settings.displayLimit >= thi.obj.selection.length || thi.obj.settings.displayLimit == 'auto') { if (thi.obj.settings.displayBreak) { thi.obj.contain.addClass("duneselect-break"); } if (thi.obj.selection) for (var i in thi.obj.selection) { if (thi.obj.settings.multiple == true) { htmlDisplay += ""; var dunePopAttr = ''; if (thi.obj.settings.dunePopTitle) { dunePopAttr = thi.obj.settings.dunePopTitle; dunePopAttr = dunePopAttr.replaceAll('{{id}}', thi.obj.selection[i].attr('value')); dunePopAttr = ' data-dunepop-title="' + dunePopAttr + '" data-dunepop-position="top"'; } htmlDisplay += "" + thi.obj.selection[i].eq(0).text() + ""; htmlDisplay += "×"; htmlDisplay += ""; } else { if (thi.obj.allowDeselect && thi.obj.selection[i].attr("value") !== '') { htmlDisplay += ""; htmlDisplay += "" + thi.obj.selection[i].eq(0).text() + ""; htmlDisplay += "×"; htmlDisplay += ""; } else { htmlDisplay += thi.obj.selection[i].eq(0).text(); if (thi.obj.allowDeselect && thi.obj.selection[i].attr("value") !== '') { htmlDisplay += "×"; } } } } } else { var title = ''; if (thi.obj.selection) for (var i in thi.obj.selection) { if (title && !thi.obj.settings.expanded) { title += ', '; } title += thi.obj.selection[i].eq(0).text(); } if (thi.obj.optionCount) { htmlDisplay = "" + thi.obj.selection.length + '/' + thi.obj.optionCount + " " + thi.obj.settings.selectedText + ""; } else { htmlDisplay = "" + thi.obj.selection.length + " " + thi.obj.settings.selectedText + ""; } } } display.html(htmlDisplay); if (thi.obj.settings.displayLimit == 'auto' && !thi.obj.settings.displayBreak && thi.obj.loaded) { var outOfLimits = false; // if (thi.obj.contain.find(".duneselect-display").width() + thi.obj.settings.chevronWidth >= thi.obj.contain.find(".duneselect-outer").width()) { // outOfLimits = true; // } if (thi.obj.selection.length > 1 && thi.obj.contain.find(".duneselect-display").get(0).scrollWidth - thi.obj.settings.chevronWidth -4 >= thi.obj.contain.find(".duneselect-outer").width() - thi.obj.settings.chevronWidth) { outOfLimits = true; } if (outOfLimits && thi.obj.settings.multiple == true && !thi.obj.settings.expanded) { var title = ''; if (thi.obj.selection) for (var i in thi.obj.selection) { if (title && !thi.obj.settings.expanded) { title += ', '; } title += thi.obj.selection[i].eq(0).text(); } if (thi.obj.optionCount) { htmlDisplay = "" + thi.obj.selection.length + '/' + thi.obj.optionCount + " " + thi.obj.settings.selectedText + " "; } else { htmlDisplay = "" + +thi.obj.selection.length + " " + thi.obj.settings.selectedText + " "; } } } if (thi.obj.settings.displayAllSelectedText && thi.obj.optionCount && thi.obj.optionCount == thi.obj.selection.length) { htmlDisplay = thi.obj.settings.allSelectedText + " (" + thi.obj.selection.length + '/' + thi.obj.optionCount + ")"; thi.obj.contain.find(".duneselect-selectAll").attr("data-all", 1); thi.obj.contain.find(".duneselect-selectAll input").attr("checked", true); thi.obj.contain.find(".duneselect-selectAll").text(thi.obj.settings.DeSelectAllText); } else { thi.obj.contain.find(".duneselect-selectAll").attr("data-all", 0); thi.obj.contain.find(".duneselect-selectAll input").attr("checked", false); thi.obj.contain.find(".duneselect-selectAll").text(thi.obj.settings.SelectAllText); } display.html(htmlDisplay); display.find("input").prop("checked", true); thi.obj.bindDisplayEvents(); }; /** === USER ACTIONS === */ /**USED ON USER SEARCH */ thi.obj.ajaxSearch = function (str) { $.ajax({ url: thi.obj.settings.ajaxUrl, data: { action: 'search', query: str, selectedVal: thi.obj.original.val() } }).done(function (msg) { var options = thi.obj.contain.find(".duneselect-options"); options.html(""); var json = JSON.parse(msg); var originalOptions = []; if (json && json.options) { for (var j in json.options) { var e = thi.obj.generateAjaxOption(json.options[j]); originalOptions.push(e); } } if (originalOptions) for (var i in originalOptions) { var o = originalOptions[i]; options.append(function () { var opt = thi.obj.generateOption(o, 'dom'); if (("," + thi.obj.original.val() + ",").search("," + opt.attr("value") + ",") >= 0) { opt.addClass("duneselect-selected"); // opt.find("input").prop("checked", true); opt.find(".dscb").removeClass("glyphicons-unchecked"); opt.find(".dscb").addClass("glyphicons-check"); } return opt; }); } thi.obj.optionCount = json.count; if (json && json.count) { if (originalOptions.length < json.count) thi.obj.ajaxAllDisplayed = false; else thi.obj.ajaxAllDisplayed = true; } thi.obj.bindMainEvents(); thi.obj.displaySelection(); }); }; /**USED ON USER SEARCH */ thi.obj.search = function (str) { if (thi.obj.prevSearch == str) { return; } thi.obj.contain.find(".duneselect-option").attr("data-insearch", "true"); thi.obj.contain.find(".duneselect-option").css("display", "block"); if((!str || str.length == 0 ) && thi.obj.settings.ajax){ //Reset options if empty search var options = thi.obj.contain.find(".duneselect-options"); options.html(""); thi.obj.prevSearch = ""; return false; } else if (str.length < thi.obj.settings.searchThreshold){ return false; } thi.obj.prevSearch = str; if (thi.obj.settings.ajax) { return thi.obj.ajaxSearch(str); } var searchSplit = str.toLowerCase().replace(/([àáâãäå])|([ç])|([èéêë])|([ìíîï])|([ñ])|([òóôõöø])|([ß])|([ùúûü])|([ÿ])|([æ])/g, function (str, a, c, e, i, n, o, s, u, y, ae) { if (a) return 'a'; else if (c) return 'c'; else if (e) return 'e'; else if (i) return 'i'; else if (n) return 'n'; else if (o) return 'o'; else if (s) return 's'; else if (u) return 'u'; else if (y) return 'y'; else if (ae) return 'ae'; }).split(" "); if (str == '') return true; var groupsToDisplay = []; thi.obj.contain.find(".duneselect-option").each(function () { var words = $(this).attr("data-text").toLowerCase().replace(/([àáâãäå])|([ç])|([èéêë])|([ìíîï])|([ñ])|([òóôõöø])|([ß])|([ùúûü])|([ÿ])|([æ])/g, function (str, a, c, e, i, n, o, s, u, y, ae) { if (a) return 'a'; else if (c) return 'c'; else if (e) return 'e'; else if (i) return 'i'; else if (n) return 'n'; else if (o) return 'o'; else if (s) return 's'; else if (u) return 'u'; else if (y) return 'y'; else if (ae) return 'ae'; }).split(" "); var f = []; if (searchSplit) for (var o in searchSplit) { f[o] = 0; if (words) for (var i in words) { if (f[o] == 0) { if (words[i].search(searchSplit[o]) >= 0) { f[o] = 1; } } } } if (f.indexOf(0) >= 0) { $(this).attr("data-insearch", "false"); $(this).css("display", "none"); } else { if ($(this).attr("data-parent")) groupsToDisplay.push($(this).attr("data-parent")); } }); var groupsToDisplayUnique = []; for (var i = 0; i < groupsToDisplay.length; i++) { if (groupsToDisplayUnique.indexOf(groupsToDisplay[i]) == -1) { groupsToDisplayUnique.push(groupsToDisplay[i]); } } if (groupsToDisplayUnique) for (var gtd in groupsToDisplayUnique) { //console.log("[data-group=\"" + groupsToDisplayUnique[gtd] + "\"]"); thi.obj.contain.find("[data-group=\"" + groupsToDisplayUnique[gtd] + "\"]").show(); thi.obj.contain.find("[data-group=\"" + groupsToDisplayUnique[gtd] + "\"]").attr("data-insearch", "true"); // FIX pour afficher les groupes quand même dans les résultats de la search dans l'edit thi.obj.contain.find("[value=\"" + groupsToDisplayUnique[gtd] + "\"]").show(); thi.obj.contain.find("[value=\"" + groupsToDisplayUnique[gtd] + "\"]").attr("data-insearch", "true"); } }; thi.obj.deSelectAll = function () { if (thi.obj.loaded) { thi.obj.contain.find(".duneselect-group:visible").not(".dontselectall").attr("data-groupselect", 0); var force = arguments[0] || false; var options = thi.obj.contain.find(".duneselect-option:visible"); if (force) options = thi.obj.contain.find(".duneselect-option"); options.removeClass("duneselect-selected"); // thi.obj.contain.find(".duneselect-option input").prop("checked", false); thi.obj.contain.find(".dscb").removeClass("glyphicons-check"); thi.obj.contain.find(".dscb").addClass("glyphicons-unchecked"); thi.obj.original.val(""); thi.obj.selection = []; thi.obj.selectionValue = []; var val = []; if (thi.obj.loaded) { thi.obj.original.val(val); thi.obj.original.change(); thi.obj.displaySelection(); } } }; thi.obj.selectAll = function () { if (thi.obj.loaded) { // var options = thi.obj.contain.find(".duneselect-option:visible"); var options = thi.obj.contain.find(".duneselect-option"); options.removeClass("duneselect-selected"); } // thi.obj.contain.find(".duneselect-group:visible").not(".dontselectall").attr("data-groupselect", 1); // thi.obj.contain.find(".duneselect-option:visible").not(".dontselectall").each(function () { thi.obj.contain.find(".duneselect-group").not(".dontselectall").attr("data-groupselect", 1); thi.obj.contain.find(".duneselect-option").not(".dontselectall").each(function () { var option = $(this); if (option.hasClass("duneselect-disabled")) return; if (thi.obj.loaded) { var options = thi.obj.contain.find(".duneselect-option .dscb"); // options.prop("checked", false); options.removeClass("glyphicons-check"); options.addClass("glyphicons-unchecked"); } var already = -1; if (thi.obj.selectionValue) { already = thi.obj.selectionValue.indexOf(option.attr("value")); } if (already < 0) { switch (thi.obj.settings.optGroupOnSelect) { case "options": case "none": if (!option.attr("data-group")) { thi.obj.selection.push(option); thi.obj.selectionValue.push(option.attr("value")); } break; default: thi.obj.selection.push(option); thi.obj.selectionValue.push(option.attr("value")); break; } } }); var val = []; if (thi.obj.selection) for (var i in thi.obj.selection) { if (val.indexOf(thi.obj.selection[i].attr("value")) < 0) val.push(thi.obj.selection[i].attr("value")); if (thi.obj.settings.checkbox) { // thi.obj.selection[i].find("input").prop("checked", true); thi.obj.selection[i].find(".dscb").removeClass("glyphicons-unchecked"); thi.obj.selection[i].find(".dscb").addClass("glyphicons-check"); } thi.obj.selection[i].addClass("duneselect-selected"); } if (thi.obj.loaded) { thi.obj.original.val(val); if (thi.obj.settings.triggersChangeEventAfterSelectAll){ thi.obj.original.change(); } thi.obj.displaySelection(); } }; /** USED ON USER SELECT */ thi.obj.setSelection = function (option) { if (typeof(option) != 'object') { option = $(option); } var noswitch = arguments[1] || false; var dontChangeOriginal = arguments[2] || false; if (option.hasClass("duneselect-disabled") || (!thi.obj.settings.multiple && !thi.obj.settings.selectableGroup && option.hasClass("duneselect-group"))) { return false; } if (thi.obj.loaded) { var options = thi.obj.contain.find(".duneselect-option"); options.removeClass("duneselect-selected"); } if (thi.obj.settings.multiple == true) { return thi.obj.setSelectionMultiple(option, noswitch, dontChangeOriginal); } thi.obj.selection = [option]; option.addClass("duneselect-selected"); if (thi.obj.loaded) { thi.obj.selectOptions(noswitch, dontChangeOriginal); } }; /** USED ON USER SELECT */ thi.obj.setAjaxSelection = function (params) { if (!thi.obj.loaded) { setTimeout(function () { thi.obj.setAjaxSelection(params); }, 100); return; } var defaults = { name: '', value: '', group: '', parent: '' }; var opt = $.extend(defaults, params); var o = thi.obj.generateAjaxOption(opt); var option = thi.obj.generateOption(o); return thi.obj.setSelection(option, true); }; /** USED ON USER CROSS CLICK */ thi.obj.unselectCross = function (option) { if (thi.obj.loaded) { var options = thi.obj.contain.find(".duneselect-option"); options.removeClass("duneselect-selected"); // options.find("input").prop("checked", false); options.find(".dscb").removeClass("glyphicons-check"); options.find(".dscb").addClass("glyphicons-unchecked"); } var already = -1; if (thi.obj.selectionValue) { already = thi.obj.selectionValue.indexOf(option.attr("data-value")); } if (already >= 0) { thi.obj.selection.splice(already, 1); thi.obj.selectionValue.splice(already, 1); } var val = []; if (thi.obj.selection) for (var i in thi.obj.selection) { if (val.indexOf(thi.obj.selection[i].attr("value")) < 0) val.push(thi.obj.selection[i].attr("value")); if (thi.obj.settings.checkbox) { // thi.obj.selection[i].find("input").prop("checked", true); thi.obj.selection[i].find(".dscb").removeClass("glyphicons-unchecked"); thi.obj.selection[i].find(".dscb").addClass("glyphicons-check"); } thi.obj.selection[i].addClass("duneselect-selected"); } if (option.attr("data-single")) { val = ''; } if (thi.obj.loaded) thi.obj.selectOptions(); }; thi.obj.unselectAjax = function (params) { // var defaults = { // name: '', // value: '', // group: '', // parent: '' // }; // var opt = $.extend(defaults, params); var opt = thi.obj.contain.find(".duneselect-option[value='" + params + "']"); opt = { name: opt.attr('title'), value: opt.attr('value'), }; var o = thi.obj.generateAjaxOption(opt); var option = thi.obj.generateOption(o); thi.obj.unselect($(option)); }; thi.obj.unselect = function (option) { if (thi.obj.loaded) { var options = thi.obj.contain.find(".duneselect-option"); options.removeClass("duneselect-selected"); // options.find("input").prop("checked", false); options.find(".dscb").removeClass("glyphicons-check"); options.find(".dscb").addClass("glyphicons-unchecked"); } var already = -1; if (thi.obj.selectionValue) { already = thi.obj.selectionValue.indexOf(option.attr("value")); } if (already >= 0 || thi.obj.settings.optGroupOnSelect == 'options') { if (already >= 0) { thi.obj.selection.splice(already, 1); thi.obj.selectionValue.splice(already, 1); } if ((thi.obj.settings.optGroupOnSelect == 'options' || thi.obj.settings.optGroupOnSelect == 'all') && thi.obj.settings.multiple && option.attr("value")) { thi.obj.contain.find(".duneselect-option[data-parent=" + option.attr("value") + "][data-insearch=true]").each(function () { var already2 = -1; if (thi.obj.selection) for (var i in thi.obj.selection) { if (thi.obj.selection[i].attr("value") == $(this).attr("value")) { already2 = i; } } if (already2 >= 0) { thi.obj.selection.splice(already2, 1); thi.obj.selectionValue.splice(already2, 1); } }); } } if (thi.obj.loaded) { thi.obj.selectOptions(); } }; /** USED ON USER SELECT MULTIPLE */ thi.obj.setSelectionMultiple = function (option) { var noswitch = arguments[1] || false; var dontChangeOriginal = arguments[2] || false; if (thi.obj.loaded) { var options = thi.obj.contain.find(".duneselect-option .dscb"); // options.prop("checked", false); options.removeClass("glyphicons-check"); options.addClass("glyphicons-unchecked"); } if (option.attr("data-group")) { return thi.obj.setSelectionMultipleGroup(option, noswitch, dontChangeOriginal); } var already = -1; if (thi.obj.selectionValue) { already = thi.obj.selectionValue.indexOf(option.attr("value")); } if (already < 0) { if (thi.obj.settings.maxSelected == 0 || thi.obj.selection.length < thi.obj.settings.maxSelected) thi.obj.selection.push(option); else { alert(thi.obj.settings.maxSelectedText); } } else if (!noswitch) { thi.obj.selection.splice(already, 1); thi.obj.selectionValue.splice(already, 1); } if (thi.obj.loaded) thi.obj.selectOptions(noswitch, dontChangeOriginal); }; thi.obj.selectOptions = function () { var noswitch = arguments[0] || false; var dontChangeOriginal = arguments[1] || false; var val = []; thi.obj.selectionValue = []; if (thi.obj.selection) for (var i in thi.obj.selection) { var sel = thi.obj.selection[i]; var selValue = sel.attr("value"); if (thi.obj.loaded) { //var classUniq = selValue.replace(/ /g,".").replace(/\//g,".").replace(/\.&\./g,".").replace(/'/g,"\\'").replace(/\.{1,}/g,"."); var classUniq = selValue.replace(/[^a-z0-9]/gi, '_').toLowerCase(); var selectorS = ".DS_" + thi.obj.instance + "-" + classUniq; /*selectorS = selectorS.replace(/\.&\./g,"."); selectorS = selectorS.replace(/'/g,"\\'"); selectorS = selectorS.replace(/\//g,".");*/ var f = $(selectorS); if (f.length) { thi.obj.selection[i] = f; sel = thi.obj.selection[i]; selValue = sel.attr("value"); f.addClass("duneselect-selected"); } if (val.indexOf(selValue) < 0) val.push(selValue); } if (thi.obj.settings.checkbox) { sel.find(".dscb").removeClass("glyphicons-unchecked"); sel.find(".dscb").addClass("glyphicons-check"); } sel.addClass("duneselect-selected"); // thi.obj.contain.find(".duneselect-option[value="+selValue+"]").addClass("duneselect-selected"); thi.obj.selectionValue.push(selValue); } if (thi.obj.loaded) { if (val.length < 1) { val = ""; } thi.obj.original.val(val); if (thi.obj.first) { thi.obj.first = false; } else { try { thi.obj.original.change(); } catch(error) { console.log("DuneSelect error : no change original select"); console.log(error); } } } if (thi.obj.loaded) thi.obj.displaySelection(); $(thi).trigger("duneselect:selectOptionsDone"); }; thi.obj.setSelectionMultipleGroup = function (option) { var noswitch = arguments[1] || false; var dontChangeOriginal = arguments[2] || false; var returnNow = false; switch (thi.obj.settings.optGroupOnSelect) { case 'options': var already_g = parseInt(option.attr("data-groupSelect")) || 0; if (already_g) option.attr("data-groupSelect", 0); else option.attr("data-groupSelect", 1); if (already_g == 0 || noswitch) { thi.obj.contain.find(".duneselect-option[data-parent='" + option.attr("value") + "'][data-insearch=true]").each(function () { if ($(this).hasClass("duneselect-disabled")) return; var already = -1; if (thi.obj.selectionValue) { already = thi.obj.selectionValue.indexOf($(this).attr("value")); } if (already < 0) { if (thi.obj.settings.maxSelected == 0 || thi.obj.selection.length < thi.obj.settings.maxSelected) { thi.obj.selection.push($(this)); } else { if (!returnNow) alert(thi.obj.settings.maxSelectedText); returnNow = true; } } }); } else { thi.obj.contain.find(".duneselect-option[data-parent='" + option.attr("value") + "'][data-insearch=true]").each(function () { if ($(this).hasClass("duneselect-disabled")) return; var already = -1; if (thi.obj.selectionValue) { already = thi.obj.selectionValue.indexOf($(this).attr("value")); } if (already >= 0 && !noswitch) { thi.obj.selection.splice(already, 1); thi.obj.selectionValue.splice(already, 1); } }); } break; case 'optgroup': var already_g = -1; if (thi.obj.selectionValue) { already_g = thi.obj.selectionValue.indexOf(option.attr("value")); } if (already_g < 0) { if (thi.obj.settings.maxSelected == 0 || thi.obj.selection.length < thi.obj.settings.maxSelected) thi.obj.selection.push(option); else { alert(thi.obj.settings.maxSelectedText); already_g = 0; } } else if (!noswitch) { thi.obj.selection.splice(already_g, 1); thi.obj.selectionValue.splice(already_g, 1); } break; case 'none': if (option.attr("data-group")) break; var already_g = -1; if (thi.obj.selectionValue) { already_g = thi.obj.selectionValue.indexOf(option.attr("value")); } if (already_g < 0) { if (thi.obj.settings.maxSelected == 0 || thi.obj.selection.length < thi.obj.settings.maxSelected) thi.obj.selection.push(option); else { alert(thi.obj.settings.maxSelectedText); already_g = 0; } } else if (!noswitch) { thi.obj.selection.splice(already_g, 1); thi.obj.selectionValue.splice(already_g, 1); } break; default: var already_g = -1; if (thi.obj.selectionValue) { already_g = thi.obj.selectionValue.indexOf(option.attr("value")); } if (already_g < 0) { if (thi.obj.settings.maxSelected == 0 || thi.obj.selection.length < thi.obj.settings.maxSelected) thi.obj.selection.push(option); else { alert(thi.obj.settings.maxSelectedText); already_g = 0; } } else if (!noswitch) { thi.obj.selection.splice(already_g, 1); thi.obj.selectionValue.splice(already_g, 1); } if (already_g < 0 || noswitch) { thi.obj.contain.find(".duneselect-option[data-parent='" + option.attr("value") + "'][data-insearch=true]").each(function () { if ($(this).hasClass("duneselect-disabled")) return; var already = -1; if (thi.obj.selectionValue) { already = thi.obj.selectionValue.indexOf($(this).attr("value")); } if (already < 0) { if (thi.obj.settings.maxSelected == 0 || thi.obj.selection.length < thi.obj.settings.maxSelected) thi.obj.selection.push($(this)); else { if (!returnNow) alert(thi.obj.settings.maxSelectedText); returnNow = true; } } }); } else { thi.obj.contain.find(".duneselect-option[data-parent='" + option.attr("value") + "'][data-insearch=true]").each(function () { if ($(this).hasClass("duneselect-disabled")) return; var already = -1; if (thi.obj.selectionValue) { already = thi.obj.selectionValue.indexOf($(this).attr("value")); } if (already >= 0 && !noswitch) { thi.obj.selection.splice(already, 1); thi.obj.selectionValue.splice(already, 1); } }); } break; } if (thi.obj.loaded) thi.obj.selectOptions(noswitch, dontChangeOriginal); }; thi.obj.createBlock(); return thi.obj; }; this.each(function () { var ds = bind(this); objs[ds.instance] = ds; duneSelectInstances[ds.instance] = ds; if ($(this).attr("data-value")) { var value = $(this).attr("data-value").split("||"); if (ds.settings.ajax) { var valObj = []; for (var i in value) { if (!value[i]) continue; var exp = value[i].split(",", 2); if (exp.length !== 2) continue; valObj.push({ value: exp[0], name: exp[1] }); } $.duneSelect("select", $(this), valObj); } else { $.duneSelect("select", $(this), value); } } else if (!$(this).attr("data-value") && ds.settings.defaultSelectAll){ ds.selectAll(); } }); return objs; }; $.duneSelect = $.fn.duneSelect; }(jQuery)); var DPClientX = 0; var DPClientY = 0; var dunePopID = 0; var DPQueue = []; $.fn.dunePop = function (options) { var singleton = this; var imgExts = [ "png", "jpg", "gif", "jpeg" ]; var ajaxExts = [ "html", "xml", "php", "php5", "json" ]; this.closeAll = function () { $(".dunePop-container").remove(); $("*[data-dunepop-target]").removeAttr("data-dunepop-target"); }; return this.each(function () { if ($(this).attr("data-dunepop-bind") && $(this).attr("data-dunepop-bind") == "1") { return; } $(this).attr("data-dunepop-bind", "1"); if ($(this).attr("data-dunepop-options") && $(this).attr("data-dunepop-options") != '') { var optsStr = $(this).attr("data-dunepop-options"); var opts = optsStr.split(";"); for (var optK in opts) { var opt = opts[optK]; if (opt != '') { var optS = opt.split(":"); if (optS[0] && optS[1]) $(this).attr("data-dunepop-" + optS[0], optS[1]); } } } this.defaultDPOpt = { maxWidth: $(window).width() * 0.9, maxHeight: $(window).height() * 0.9, zindex: 1000, closeAnimationation: "fade", openTimeOut: 250, closeTimeOut: 200, closeAfter: 0,// secondes cursor: false, offset: 20, direction: "bottom", onclose: function () { // console.log("onclose"); }, onopen: function () { // console.log("onopen"); } }; for (var i in options) { if (i == "cursor" && options[i] == "0") { options[i] = false; } this.defaultDPOpt[i] = options[i]; } this.OTO = 0; this.CTO = 0; this.XHR = null; var obj = this; this.pop = null; this.ref = null; if ($(obj).attr("data-dunepop-openTimeOut")) { obj.defaultDPOpt.openTimeOut = $(obj).attr("data-dunepop-openTimeOut"); } if ($(obj).attr("data-dunepop-closeAfter")) { obj.defaultDPOpt.closeAfter = $(obj).attr("data-dunepop-closeAfter"); } $(this).unbind("mouseover").on("mouseover", function (e) { var $this = $(this); if (obj.CTO) clearTimeout(obj.CTO); if (obj.OTO) clearTimeout(obj.OTO); if (obj.XHR) obj.XHR.abort(); obj.OTO = setTimeout(function () { if (!$this.attr("data-dunepop-target")) { eventLaunch($this, e, obj); } }, obj.defaultDPOpt.openTimeOut); }); $(this).on("remove", function (e) { e.stopPropagation(); if (obj.CTO) clearTimeout(obj.CTO); if (obj.OTO) clearTimeout(obj.OTO); if (obj.XHR) obj.XHR.abort(); var thelem = $(".dunePop-container[data-dunepop-id=" + $(this).attr("data-dunepop-target") + "]"); thelem.remove(); }); $(this).unbind("mouseout").on("mouseout", function (e) { if (obj.CTO) clearTimeout(obj.CTO); var thelem = $(".dunePop-container[data-dunepop-id=" + $(this).attr("data-dunepop-target") + "]"); var thereffer = $(this); obj.CTO = setTimeout(function () { var foT = (obj.defaultDPOpt.closeAnimation == false) ? 0 : 200; thelem.fadeOut(foT, function () { obj.defaultDPOpt.onclose(); if ($(this).hasClass("dunePop-backto")) { var backto = $(this).attr("data-dunepop-backto"); var cnt = $(this).contents(); $(".dunePop-placeholder[data-dunepop-selector='" + backto + "']").after(cnt); $(".dunePop-placeholder[data-dunepop-selector='" + backto + "']").remove(); } thereffer.removeAttr("data-dunepop-target"); $(this).remove(); }); }, obj.defaultDPOpt.closeTimeOut); if (obj.OTO) clearTimeout(obj.OTO); if (obj.XHR) obj.XHR.abort(); }); this.createContent = function (type, elem, cb) { var href = (elem.attr("data-dunepop-title")) ? elem.attr("data-dunepop-title") : null; // console.log(href); var gallery = elem.attr("rel"); var content; var w = "auto"; var h = "auto"; // console.log("3"+type); switch (type) { case 'image': var image = new Image(); image.loaded = 0; image.src = href; if (obj.defaultDPOpt.maxHeight == 0) { obj.defaultDPOpt.maxHeight = $(window).height() * 0.9; } if (obj.defaultDPOpt.maxWidth == 0) { obj.defaultDPOpt.maxWidth = $(window).width() * 0.9; } image.onload = function () { h = this.naturalHeight; w = this.naturalWidth; var r = h / w; while (h > obj.defaultDPOpt.maxHeight || w > obj.defaultDPOpt.maxWidth) { if (h > obj.defaultDPOpt.maxHeight) { h = obj.defaultDPOpt.maxHeight; w = h / r; } if (w > obj.defaultDPOpt.maxWidth) { w = obj.defaultDPOpt.maxWidth; h = w * r; } } if (elem.attr("data-dunepop-width")) w = elem.attr("data-dunepop-width"); if (elem.attr("data-dunepop-height")) h = elem.attr("data-dunepop-height"); this.width = w; this.height = h; content = this; cb(content, w, h, gallery, elem, type); dunePopID += 10; } image.onerror = function () { content = "404 not found (Image)"; cb(content, 0, 0, gallery, elem, 'div'); dunePopID += 10; } break; case 'ajax': obj.XHR = $.ajax({ url: href, async: true }).done(function (msg) { content = msg; w = elem.attr("data-dunepop-width"); h = elem.attr("data-dunepop-height"); if (content == '') { elem.css("cursor", "auto"); return; } cb(content, w, h, gallery, elem); }).fail(function (xhr, msg) { content = xhr.status + ' ' + xhr.statusText; w = elem.attr("data-dunepop-width"); h = elem.attr("data-dunepop-height"); if (xhr.statusText == 'abort') { content = ''; return; } cb(content, w, h, gallery, elem); if (xhr.statusText == 'abort') { elem.mouseout(); } }); dunePopID += 10; break; case 'div': if ($(href).length > 0) { content = $(href); } else { content = "404 not found (DIV)"; } h = 0; w = 0; if (elem.attr("data-dunepop-width")) w = elem.attr("data-dunepop-width"); if (elem.attr("data-dunepop-height")) h = elem.attr("data-dunepop-height"); dunePopID += 10; cb(content, w, h, gallery, elem, type); break; case 'iframe': content = ""; w = 0; h = 0; var hattr = elem.attr("data-dunepop-height"); var wattr = elem.attr("data-dunepop-width"); if (typeof wattr !== typeof undefined && wattr !== false) w = elem.attr("data-dunepop-width"); if (typeof hattr !== typeof undefined && hattr !== false) h = elem.attr("data-dunepop-height"); dunePopID += 10; cb(content, w, h, gallery, elem, type); break; case 'html': if (elem.attr("data-dunepop-width")) w = elem.attr("data-dunepop-width"); if (elem.attr("data-dunepop-height")) h = elem.attr("data-dunepop-height"); dunePopID += 10; content = href; cb(content, w, h, gallery, elem, type); break; } } this.openPopOver = function (content, width, height, group, reffer, type) { // debugger; var class_suffix = reffer.attr("data-dunepop-class-suffix"); if(typeof class_suffix != "undefined" && class_suffix && class_suffix != '' && class_suffix != 'undefined') { class_suffix = "--" + class_suffix; } else { class_suffix = ''; } this.pop = $("
"); this.ref = reffer; if (type == 'div' && typeof content == 'object') { var tp = content.parent(); this.pop.append(content); this.pop.addClass("dunePop-backto"); this.pop.attr("data-dunePop-backto", reffer.attr("data-dunepop-title")); tp.append("
"); } else { this.pop.append(content); } this.pop.appendTo("body"); this.pop.css("visibility", "hidden"); if (type == 'div' || type == 'ajax' || type == 'iframe' || type == 'html') { width = this.pop.width() + 1; height = this.pop.height(); var r = height / width; if (reffer.attr("data-dunepop-width")) width = reffer.attr("data-dunepop-width"); if (reffer.attr("data-dunepop-height")) height = reffer.attr("data-dunepop-height"); while (width > obj.defaultDPOpt.maxWidth) { if (width > obj.defaultDPOpt.maxWidth) { width = obj.defaultDPOpt.maxWidth; this.pop.width(width); this.pop.height("auto"); height = this.pop.height(); } } this.pop.width(width); this.pop.height("auto"); // debugger; height = this.pop.height(); this.pop.height(height); this.pop.find("iframe").width(width); this.pop.find("iframe").height(height); } this.pop.css("visibility", "visible"); this.pop.width(width); this.pop.height(height); reffer.attr("data-dunepop-target", dunePopID); this.pop.attr("data-dunepop-id", dunePopID); DPQueue[dunePopID] = obj; obj.popPosition(this.pop, reffer); obj.createEvents(this.pop, reffer); obj.defaultDPOpt.onopen(); if (reffer.attr("data-dunepop-closeAfter")>0) { console.log('found closeAfter '+reffer.attr("data-dunepop-closeAfter")); setTimeout(function () { reffer.trigger('mouseout'); },reffer.attr("data-dunepop-closeAfter")); } } this.createEvents = function (p, r) { p.unbind("mouseover").on("mouseover", function (e) { $("*[data-dunepop-target]").mouseout(); if (obj.CTO) clearTimeout(obj.CTO); if (obj.OTO) clearTimeout(obj.OTO); if (obj.XHR) obj.XHR.abort(); }); p.unbind("mouseout").on("mouseout", function () { if (obj.CTO) clearTimeout(obj.CTO); var thereffer = $("*[data-dunepop-target=" + $(this).attr("data-dunepop-id") + "]"); var thelem = $(this); obj.CTO = setTimeout(function () { var foT = (obj.defaultDPOpt.closeAnimation == false) ? 0 : 200; thelem.fadeOut(foT, function () { obj.defaultDPOpt.onclose(); if ($(this).hasClass("dunePop-backto")) { var backto = $(this).attr("data-dunepop-backto"); var cnt = $(this).contents(); $(".dunePop-placeholder[data-dunepop-selector=" + backto + "]").after(cnt); $(".dunePop-placeholder[data-dunepop-selector=" + backto + "]").remove(); } thereffer.removeAttr("data-dunepop-target"); $(this).remove(); }); }, obj.defaultDPOpt.closeTimeOut); if (obj.OTO) clearTimeout(obj.OTO); if (obj.XHR) obj.XHR.abort(); }); } this.popPosition = function (p, r) { var cursor = false; if (r.attr("data-dunepop-cursor")) { cursor = r.attr("data-dunepop-cursor"); } else { cursor = obj.defaultDPOpt.cursor; } var pos = 'bottom'; if (r.attr("data-dunepop-direction")) { // OLD VERSION pos = r.attr("data-dunepop-direction"); } else { pos = obj.defaultDPOpt.direction; } if (r.attr("data-dunepop-position")) { // NEW RENAMING pos = r.attr("data-dunepop-position"); } else { pos = obj.defaultDPOpt.direction; } var offset = 0; if (r.attr("data-dunepop-offset")) { offset = r.attr("data-dunepop-offset"); } else { offset = obj.defaultDPOpt.offset; } offset = parseInt(offset); var pw = p.outerWidth(); var ph = p.outerHeight(); var rw = r.outerWidth(); var rh = r.outerHeight(); var rx = r.offset().left; var ry = r.offset().top - $(window).scrollTop(); if (cursor != false) { rw = 0; rh = 0; rx = DPClientX; ry = DPClientY; if (cursor == 'follow') { p.addClass("dunePop-follow"); } } p.addClass("dunePop-position-" + pos); var px, py = 0; switch (pos) { case 'left': px = rx - pw - offset; py = ry + (rh / 2) - (ph / 2); if (px < 0) { px = 0; } if (py < 0) { py = 0; } if (cursor != false) py += 12; if (px + pw > $(window).width()) { px = $(window).width() - pw; } if (py + ph > $(window).height()) { py = $(window).height() - ph; } break; case 'right': px = rx + rw + offset; py = ry + (rh / 2) - (ph / 2); if (px < 0) { px = 0; } if (py < 0) { py = 0; } if (cursor != false) py += 12; if (px + pw > $(window).width()) { px = $(window).width() - pw; } if (py + ph > $(window).height()) { py = $(window).height() - ph; } break; case 'top': px = rx - (pw / 2) + (rw / 2); py = ry - (ph) - offset; if (px < 0) { px = 0; } if (py < 0) { py = 0; } if (px + pw > $(window).width()) { px = $(window).width() - pw; } if (py + ph > $(window).height()) { py = $(window).height() - ph; } break; default: px = rx + (rw / 2) - (pw / 2); py = ry + (rh) + offset; if (px < 0) { px = 0; } if (py < 0) { py = 0; } if (px + pw > $(window).width()) { px = $(window).width() - pw; } if (py + ph > $(window).height()) { py = $(window).height() - ph; } break; } if (px) p.css("left", px); if (py) p.css("top", py); } this.openDPBox = function (type, reffer) { // console.log(reffer); var g = reffer.attr("rel"); var sele = $("*[rel=" + g + "]"); var gc = (sele) ? sele.length : null; var gi = (gc > 1) ? reffer.index("*[rel=" + g + "]") : 0; var t = type; reffer.addClass("dunePop-waiting"); // console.log("2"+t); var req = obj.createContent(t, reffer, function (content, w, h, g, e, ty) { reffer.removeClass("dunePop-waiting"); obj.openPopOver(content, w, h, g, e, ty); }); } }); function eventLaunch(element, e, obj) { e.preventDefault(); e.stopPropagation(); var href = (element.attr("data-dunepop-title")) ? element.attr("data-dunepop-title") : null; var type = 'div'; var shref = href.split("?"); shref = shref[0].split("."); var ext = shref[shref.length - 1]; if ($.inArray(ext.toLowerCase(), imgExts) >= 0) { type = "image"; } else if (href.substr(0, 4) == 'http') { type = "iframe"; } else if ($.inArray(ext.toLowerCase(), ajaxExts) >= 0) { type = "ajax"; } else if (href.substr(0, 1) == '#') { type = "div"; } else { type = "html"; } if (element.attr("data-dunepop-type")) { type = element.attr("data-dunepop-type"); } type = (element.attr("data-dunepop-type")) ? element.attr("data-dunepop-type") : type; // console.log("1"+type); obj.openDPBox(type, element); } }; $(document).ready(function () { $(document).on("mousemove", function (e) { DPClientX = e.clientX; DPClientY = e.clientY; $(".dunePop-follow").each(function () { var id = $(this).attr("data-dunepop-id"); if (id && DPQueue[id]) { DPQueue[id].popPosition(DPQueue[id].pop, DPQueue[id].ref); } }); }); }); var duneBox=0; var mapStyle = []; var ua = navigator.userAgent.toLowerCase(); var check = function(r) { return r.test(ua); }; var DOC = document; var isStrict = DOC.compatMode == "CSS1Compat"; var isOpera = check(/opera/); var isChrome = check(/chrome/); var isWebKit = check(/webkit/); var isSafari = !isChrome && check(/safari/); var isSafari2 = isSafari && check(/applewebkit\/4/); // unique to // Safari 2 var isSafari3 = isSafari && check(/version\/3/); var isSafari4 = isSafari && check(/version\/4/); var isIE = !isOpera && check(/msie/); var isIE7 = isIE && check(/msie 7/); var isIE8 = isIE && check(/msie 8/); var isIE6 = isIE && !isIE7 && !isIE8; var isGecko = !isWebKit && check(/gecko/); var isGecko2 = isGecko && check(/rv:1\.8/); var isGecko3 = isGecko && check(/rv:1\.9/); var isBorderBox = isIE && !isStrict; var isWindows = check(/windows|win32/); var isMac = check(/macintosh|mac os x/); var isAir = check(/adobeair/); var isLinux = check(/linux/); var isSecure = /^https/i.test(window.location.protocol); var isIE7InIE8 = isIE7 && DOC.documentMode == 7; var jsType = '', browserType = '', browserVersion = '', osName = ''; var ua = navigator.userAgent.toLowerCase(); var check = function(r) { return r.test(ua); }; if($(window).width() <= 768) { IsMobile = 1; } if(isWindows){ osName = 'Windows'; if(check(/windows nt/)){ var start = ua.indexOf('windows nt'); var end = ua.indexOf(';', start); osName = ua.substring(start, end); } } else { osName = isMac ? 'Mac' : isLinux ? 'Linux' : 'Other'; } if(isIE){ browserType = 'IE'; jsType = 'IE'; var versionStart = ua.indexOf('msie') + 5; var versionEnd = ua.indexOf(';', versionStart); browserVersion = ua.substring(versionStart, versionEnd); jsType = isIE6 ? 'IE6' : isIE7 ? 'IE7' : isIE8 ? 'IE8' : 'IE'; } else if (isGecko){ var isFF = check(/firefox/); browserType = isFF ? 'Firefox' : 'Others';; jsType = isGecko2 ? 'Gecko2' : isGecko3 ? 'Gecko3' : 'Gecko'; if(isFF){ var versionStart = ua.indexOf('firefox') + 8; var versionEnd = ua.indexOf(' ', versionStart); if(versionEnd == -1){ versionEnd = ua.length; } browserVersion = ua.substring(versionStart, versionEnd); } } else if(isChrome){ browserType = 'Chrome'; jsType = isWebKit ? 'Web Kit' : 'Other'; var versionStart = ua.indexOf('chrome') + 7; var versionEnd = ua.indexOf(' ', versionStart); browserVersion = ua.substring(versionStart, versionEnd); }else{ browserType = isOpera ? 'Opera' : isSafari ? 'Safari' : ''; } function contentMinHFilters() { $("#body .content").css("min-height", $(".ModuleProduitsFilters").outerHeight()); } $(document).ready(function() { $(".dunetrack").duneTrack(); duneBox=$(".duneBox").duneBox(); $(window).keyup(function(e) { if(e.keyCode == 89 && e.ctrlKey) { debugger; } }); $(".vehicules_ordering_title").click(function() { $(this).parent().toggleClass("open"); }); $(".vehicules_ordering").mouseleave(function() { $(this).removeClass("open"); }); $(".vehicules_ordering_list_item, .produits_ordering_list_item").click(function() { // $(this).removeClass("open"); var order = $(this).attr("data-order"); var orderDir = $(this).attr("data-dir"); var s = window.location.search.replace('?', ''); s = s.split('&'); var search = {}; for(var se in s) { se = s[se].split('='); if(se[0] == 'p' || !se[0]) continue; search[se[0]] = se[1]; } search['order'] = order + "|" + orderDir; var string = '?'; for(var e in search) { var val = search[e]; if(typeof val === 'object') { val = val.join(','); } if(val) string += e+'='+val.replace(/(^\s*,)|(,\s*$)/g, '')+'&'; } window.location.search = string; }); $(".ModuleProduitsFilters .ProdSearch>span").click(function(e) { $(this).parent().find(".itms").slideToggle(300, function(){contentMinHFilters()}); $(this).parent().toggleClass("open"); }); $(".ModuleProduitsFilters>h2").click(function(e) { if($(this).parent().hasClass("open")) { $(this).parent().find(".itms").slideUp(300, function(){contentMinHFilters()}); $(this).parent().find(".ProdSearch").removeClass("open"); $(this).parent().removeClass("open"); return; } $(this).parent().find(".itms").slideDown(300, function(){contentMinHFilters()}); $(this).parent().find(".ProdSearch").addClass("open"); $(this).parent().addClass("open"); }); if($(".ModuleProduitsFilters").length) { contentMinHFilters(); } // $(".ModuleProduitsFilters").css({ // top: $(".content").offset().top, // height: $(window).height() - $(".content").offset().top - parseInt($("footer").outerHeight()) - 10 // }); // } $("*[data-toggle]").click(function() { var grp = $(this).attr("data-toggle-group"); var tog = $(this).attr("data-toggle"); if(!grp || !tog) return; $("."+grp).hide(); $("."+tog).show(); $("*[data-toggle-group="+grp+"]").removeClass("active"); $(this).addClass("active"); }); $(".toggleBox").click(function(e) { e.stopPropagation(); $(".selectBox").removeClass("open"); $(".toggleBoxC").removeClass("open"); var toggle = $(this).attr("data-toggle"); if($(toggle) && $(toggle).length > 0) { $(toggle).toggleClass("open"); } // $(this).toggleClass("open"); }); $(".toggleBoxC").click(function(e) { // e.preventDefault(); e.stopPropagation(); }); $(".selectBox").click(function(e) { e.preventDefault(); e.stopPropagation(); $(".selectBox").removeClass("open"); $(".toggleBoxC").removeClass("open"); $(this).toggleClass("open"); }); $(window).click(function() { $(".selectBox").removeClass("open"); $(".toggleBoxC").removeClass("open"); }) $(".selectBox .SB-content").click(function(e) { e.preventDefault(); e.stopPropagation(); }); $(".selectBox").change(function(e) { var min = $(this).find(".SB-min"); var max = $(this).find(".SB-max"); var unity = $(this).attr("data-unity"); var locale = 'fr-CH'; var devise = 'CHF'; var options = {style:'currency',currency:devise,minimumFractionDigits:0,maximumFractionDigits:0}; if(window.Intl) var formatter = new Intl.NumberFormat(locale, options); var labelStr = $(this).find(".SB-label").attr("data-default"); if((min && parseInt(min.val()) >= 0) || (max && parseInt(max.val()) >= 0)) { var minVal = (min && parseInt(min.val()) > 0) ? parseInt(min.val()) : 0; if(window.Intl) var minValStr = formatter.format(minVal).replace(devise, "").trim(); else var minValStr = ""+minVal; if(devise == 'CHF') minValStr = minValStr.replace(/\s/gi, "'"); labelStr = ((max && parseInt(max.val()) >= 0) ? "De " : "A partir de ") + minValStr + ((max && max.val() > 0) ? "" : " "+unity); } if(max && parseInt(max.val()) >= 0) { var maxVal = (min && parseInt(max.val()) > 0) ? parseInt(max.val()) : 0; if(minVal && maxVal < minVal) maxVal = minVal; if(window.Intl) var maxValStr = formatter.format(maxVal).replace(devise, "").trim(); else var maxValStr = ""+maxVal; if(devise == 'CHF') maxValStr = maxValStr.replace(/\s/gi, "'"); labelStr += '
à    ' + maxValStr + " " + unity; } $(this).find(".SB-label").html(labelStr); }); $(".selectBox").change(); $(".SB-content input").keyup(function() { $(this).change(); }); $(".SB-content input").change(function() { $($(this).parentsUntil(".selectBox")[0]).change(); }); if($(".loupe").length == 0 && $("#item-display").length) { var elem = ''; $("body").append(elem); } var mIndex = 1; var TO = null; $(function() { $(".magnifier").mousemove(function(e) { var x = e.clientX; var y = e.clientY; var bx = $(this).offset().left - x; var by = $(this).offset().top - y - $(window).scrollTop(); var ox = bx * $(".loupe img").width() / $(this).width() + $(".loupe").width() / 2; var oy = by * $(".loupe img").height() / $(this).height() + $(".loupe").height() / 2; $(".loupe").css("left", x-$(".loupe").width() / 2); $(".loupe").css("top", y-$(".loupe").height() / 2); $(".loupe img").css({"left": ox+"px", "top": oy+"px"}); $(".loupe img").attr("src", $(this).attr("data-magnifier")); }).mouseenter(function(e) { if(TO) clearTimeout(TO); TO = setTimeout(function() { $(".loupe").fadeIn(50, function() { var x = e.clientX; var y = e.clientY; var bx = $(".magnifier").offset().left - x; var by = $(".magnifier").offset().top - y - $(window).scrollTop(); var ox = bx * $(".loupe img").width() / $(".magnifier").width() + $(".loupe").width() / 2; var oy = by * $(".loupe img").height() / $(".magnifier").height() + $(".loupe").height() / 2; $(".loupe").css("left", x-$(".loupe").width() / 2); $(".loupe").css("top", y-$(".loupe").height() / 2); $(".loupe img").css({"left": ox+"px", "top": oy+"px"}); $(".loupe img").attr("src", $(".magnifier").attr("data-magnifier")); }); }, 100); }).mouseout(function() { if(TO) clearTimeout(TO); $(".loupe").stop().fadeOut(100); }).click(function() { console.log("href: "+$(".service1-item#item-"+mIndex+" img").attr("href")); duneBox.open( $(".service1-item#item-"+mIndex+" img").attr("href"), {}, "product", mIndex); }); $(".service1-item").off("click").click(function(e) { e.preventDefault(); mIndex = $(".service1-item").index($(this)); $("#item-display").attr("src", $(this).children("img").attr("src")); $("#item-display").attr("data-magnifier", $(this).children("img").attr("href")); }); }); resize(); if(browserType == 'Chrome') { $('video').click(function() { if($(this).get(0).paused) $(this).get(0).play() else $(this).get(0).pause() } ); } $("video.hd").after("
HD
"); $("video.hd").prependTo(".hdVideo"); $(".btn_hd").bind("click", function(e) { e.preventDefault(); e.stopPropagation(); var video = $(this).prev("video"); video.get(0).pause(); var mt = video.get(0).currentTime; if(video.parent(".hdVideo").hasClass("isHD")) { videoSwitch(video, "sd"); } else { videoSwitch(video, "hd"); } video.parent(".hdVideo").toggleClass("isHD"); video.get(0).load(); video.get(0).currentTime = mt; video.get(0).play(); }); var hdVidTO = null; $(".hdVideo").hover(function() { if(hdVidTO) clearTimeout(hdVidTO); var elem = $(this); hdVidTO = setTimeout(function() { elem.children(".btn_hd").addClass("invisible"); }, 2000); }, function() { $(this).children(".btn_hd").removeClass("invisible"); if(hdVidTO) clearTimeout(hdVidTO); }); $(".hdVideo").mousemove(function() { $(this).children(".btn_hd").removeClass("invisible"); if(hdVidTO) clearTimeout(hdVidTO); var elem = $(this); hdVidTO = setTimeout(function() { elem.children(".btn_hd").addClass("invisible"); }, 2000); }); $("li.compte").on("mouseenter click", function() { $(this).children("ul").fadeIn(); }); $("li.compte .login_close").on("click", function(e) { e.stopPropagation(); }); $("ul.nav>li").mouseenter(function() { if(!$(this).hasClass("compte"))$("li.compte").children("ul").hide(); }); //if(IsMobile) { // $("li.compte>a").on("click", function(e) { // e.preventDefault(); // }); //} $(".loginAjaxForm").submit(function(e) { e.preventDefault(); e.stopPropagation(); var email = $(this).children("input[name=CliLogin]").val(); var passw = $(this).children("input[name=CliPass]").val(); var elem = $(this); $(this).children(".return").removeClass("error"); if(email.length > 0) { if(passw.length > 0) { $.ajax({ url: '/w3/php/DG/public/ajax/login.php', type: 'post', data: { CliLogin: email, CliPass: passw } }).done(function(msg) { var msg2 = msg.split("|"); var statut = msg2[0]; var text = msg2[1]; elem.children(".return").html(text); if(statut == 'error') { elem.children(".return").addClass("error"); } else { elem.children(".return").html(statut); window.setTimeout(function() { window.location.href = elem.attr("data-url"); }, 1000); } }); } else { $(this).children(".return").html("Merci de rentrer votre mot de passe"); $(this).children(".return").addClass("error"); } } else { $(this).children(".return").html("Merci de rentrer votre Email"); $(this).children(".return").addClass("error"); } }); if($("#pagination-digg").length > 0 && $("#pagination-digg li").length > 12) { console.log("DOPAGIN"); $("#pagination-digg li").hide(); $($("#pagination-digg li")[0]).show(); $($("#pagination-digg li")[1]).show(); $($("#pagination-digg li")[$("#pagination-digg li").length - 1]).show(); $($("#pagination-digg li")[$("#pagination-digg li").length - 2]).show(); $("#pagination-digg li.active").show(); $("#pagination-digg li.active").prev().show(); $("#pagination-digg li.active").prev().prev().show(); $("#pagination-digg li.active").prev().prev().prev().show(); $("#pagination-digg li.active").next().show(); $("#pagination-digg li.active").next().next().show(); $("#pagination-digg li.active").next().next().next().show(); if($("#pagination-digg li.active").index() > 5) { $("
  • ...
  • ").insertAfter($($("#pagination-digg li")[1])); } if($("#pagination-digg li.active").index() < $("#pagination-digg li").length - 6) { $("
  • ...
  • ").insertBefore($($("#pagination-digg li")[$("#pagination-digg li").length - 2])); } if($("#pagination-digg li.active").index() <= 5) { $("#pagination-digg li.first").hide(); $("#pagination-digg li.previous").hide(); $("#pagination-digg li.previous-off").hide(); } if($("#pagination-digg li.active").index() >= $("#pagination-digg li").length - 6) { $("#pagination-digg li.last").hide(); } if($("#pagination-digg li.active").index() == $("#pagination-digg li").length - 4) { $("#pagination-digg li.next-off").hide(); } $("#pagination-digg li:visible").first().addClass("leftRounded"); $("#pagination-digg li:visible").last().addClass("rightRounded"); } $(".blocImmotilesx3").height($(".blocImmotilesx3").width()*0.8); $(".formtofile").submit(function(e) { $(this).find("input[type=submit]").prop("disabled", true); }); var PSTO = 0; $(".mainSearch input[type=search]").on("keyup search", function() { var term = $(".mainSearch input[type=search]").val(); if(!term || term.length < 3) { $(".mainSearchResults").html(""); return; } if(PSTO) window.clearTimeout(PSTO); PSTO = setTimeout(function() { $.ajax({ url: '/w3/web_ajax/produits/quick_search.php', data: { query: term }, type: 'post' }).done(function(s) { var js = JSON.parse(s); if(js) { $(".mainSearchResults").html(""); for(var i in js) { var j = js[i]; var a = $("").addClass("mainSearchResult"); a.attr("href", j.url); a.html(j.nom); if(j.photo) { var photo = new Image(); photo.src = j.photo; a.prepend(photo); } $(".mainSearchResults").append(a); } } }); }, 750); }); $(".mainSearch input[type=search]").keyup(function(e) { if(e.keyCode == 13) { //ENTER doMainSearch(); } }); $(".mainSearch .doMainSearch").click(function() { doMainSearch(); }); function doMainSearch() { var search = $(".mainSearch input[type=search]").val(); var target = $(".mainSearch").attr("data-target"); var url = target + '?p_nom_fr=' + search; window.location.href = url; } }); function videoSwitch(v, s) { sources = v.children('source'); if(sources && sources.attr("data-"+s)) { sources.attr("src", sources.attr("data-"+s)); } } var imgRatio = 822 / 1280; function resize() { var h = $(".service-image-left").width() * imgRatio; if(h < $(".service-image-left img").height()) h = $(".service-image-left img").height(); $(".service-image-left").height(); } ;(function(f){"use strict";"function"===typeof define&&define.amd?define(["jquery"],f):"undefined"!==typeof module&&module.exports?module.exports=f(require("jquery")):f(jQuery)})(function($){"use strict";function n(a){return!a.nodeName||-1!==$.inArray(a.nodeName.toLowerCase(),["iframe","#document","html","body"])}function h(a){return $.isFunction(a)||$.isPlainObject(a)?a:{top:a,left:a}}var p=$.scrollTo=function(a,d,b){return $(window).scrollTo(a,d,b)};p.defaults={axis:"xy",duration:0,limit:!0};$.fn.scrollTo=function(a,d,b){"object"=== typeof d&&(b=d,d=0);"function"===typeof b&&(b={onAfter:b});"max"===a&&(a=9E9);b=$.extend({},p.defaults,b);d=d||b.duration;var u=b.queue&&1=f[g]?0:Math.min(f[g],n));!a&&1div").removeClass("active"); if(pane == 'ls_signup') { $(".ls_slide").addClass("ls_rp"); } else { $(".ls_slide").removeClass("ls_rp"); } $("."+pane).addClass("active"); } }); /*! Copyright (c) 2011 Piotr Rochala (http://rocha.la) * Dual licensed under the MIT (http://www.opensource.org/licenses/mit-license.php) * and GPL (http://www.opensource.org/licenses/gpl-license.php) licenses. * * Version: 1.3.6 * */ (function($) { $.fn.extend({ slimScroll: function(options) { var defaults = { // width in pixels of the visible scroll area width : 'auto', // height in pixels of the visible scroll area height : '250px', // width in pixels of the scrollbar and rail size : '7px', // scrollbar color, accepts any hex/color value color: '#000', // scrollbar position - left/right position : 'right', // distance in pixels between the side edge and the scrollbar distance : '1px', // default scroll position on load - top / bottom / $('selector') start : 'top', // sets scrollbar opacity opacity : .4, // enables always-on mode for the scrollbar alwaysVisible : false, // check if we should hide the scrollbar when user is hovering over disableFadeOut : false, // sets visibility of the rail railVisible : false, // sets rail color railColor : '#333', // sets rail opacity railOpacity : .2, // whether we should use jQuery UI Draggable to enable bar dragging railDraggable : true, // defautlt CSS class of the slimscroll rail railClass : 'slimScrollRail', // defautlt CSS class of the slimscroll bar barClass : 'slimScrollBar', // defautlt CSS class of the slimscroll wrapper wrapperClass : 'slimScrollDiv', // check if mousewheel should scroll the window if we reach top/bottom allowPageScroll : false, // scroll amount applied to each mouse wheel step wheelStep : 20, // scroll amount applied when user is using gestures touchScrollStep : 200, // sets border radius borderRadius: '7px', // sets border radius of the rail railBorderRadius : '7px' }; var o = $.extend(defaults, options); // do it for every element that matches selector this.each(function(){ var isOverPanel, isOverBar, isDragg, queueHide, touchDif, barHeight, percentScroll, lastScroll, divS = '
    ', minBarHeight = 30, releaseScroll = false; // used in event handlers and for better minification var me = $(this); // ensure we are not binding it again if (me.parent().hasClass(o.wrapperClass)) { // start from last bar position var offset = me.scrollTop(); // find bar and rail bar = me.closest('.' + o.barClass); rail = me.closest('.' + o.railClass); getBarHeight(); // check if we should scroll existing instance if ($.isPlainObject(options)) { // Pass height: auto to an existing slimscroll object to force a resize after contents have changed if ( 'height' in options && options.height == 'auto' ) { me.parent().css('height', 'auto'); me.css('height', 'auto'); var height = me.parent().parent().height(); me.parent().css('height', height); me.css('height', height); } if ('scrollTo' in options) { // jump to a static point offset = parseInt(o.scrollTo); } else if ('scrollBy' in options) { // jump by value pixels offset += parseInt(o.scrollBy); } else if ('destroy' in options) { // remove slimscroll elements bar.remove(); rail.remove(); me.unwrap(); return; } // scroll content by the given offset scrollContent(offset, false, true); } return; } else if ($.isPlainObject(options)) { if ('destroy' in options) { return; } } // optionally set height to the parent's height o.height = (o.height == 'auto') ? me.parent().height() : o.height; var rand = Math.round(Math.random()*1000); // wrap content var wrapper = $(divS) .addClass(o.wrapperClass) .css({ position: 'relative', overflow: 'hidden', width: o.width, height: o.height }); // update style for the div me.css({ overflow: 'hidden', width: o.width, height: o.height }); me.attr("data-id", rand); // create scrollbar rail var rail = $(divS) .addClass(o.railClass) .css({ width: o.size, height: '100%', position: 'absolute', top: 0, display: (o.alwaysVisible && o.railVisible) ? 'block' : 'none', 'border-radius': o.railBorderRadius, background: o.railColor, opacity: o.railOpacity, zIndex: 90 }); // create scrollbar var bar = $(divS) .attr("id", 'bar_'+rand) .addClass(o.barClass) .css({ background: o.color, width: o.size, position: 'absolute', top: 0, opacity: o.opacity, display: o.alwaysVisible ? 'block' : 'none', 'border-radius' : o.borderRadius, BorderRadius: o.borderRadius, MozBorderRadius: o.borderRadius, WebkitBorderRadius: o.borderRadius, zIndex: 99 }); // set position var posCss = (o.position == 'right') ? { right: o.distance } : { left: o.distance }; rail.css(posCss); bar.css(posCss); // wrap it me.wrap(wrapper); // append to parent div me.parent().append(bar); me.parent().append(rail); // make it draggable and no longer dependent on the jqueryUI if (o.railDraggable){ bar.bind("mousedown", function(e) { var $doc = $(document); isDragg = true; t = parseFloat(bar.css('top')); pageY = e.pageY; $doc.bind("mousemove.slimscroll", function(e){ currTop = t + e.pageY - pageY; bar.css('top', currTop); scrollContent(0, bar.position().top, false);// scroll content }); $doc.bind("mouseup.slimscroll", function(e) { isDragg = false;hideBar(); $doc.unbind('.slimscroll'); }); return false; }).bind("selectstart.slimscroll", function(e){ e.stopPropagation(); e.preventDefault(); return false; }); } // on rail over rail.hover(function(){ showBar(); }, function(){ hideBar(); }); // on bar over bar.hover(function(){ isOverBar = true; }, function(){ isOverBar = false; }); // show on parent mouseover me.hover(function(){ isOverPanel = true; showBar(); hideBar(); }, function(){ isOverPanel = false; hideBar(); }); // support for mobile me.bind('touchstart', function(e,b){ if (e.originalEvent.touches.length) { // record where touch started touchDif = e.originalEvent.touches[0].pageY; } }); me.bind('touchmove', function(e){ // prevent scrolling the page if necessary if(!releaseScroll) { e.originalEvent.preventDefault(); } if (e.originalEvent.touches.length) { // see how far user swiped var diff = (touchDif - e.originalEvent.touches[0].pageY) / o.touchScrollStep; // scroll content scrollContent(diff, true); touchDif = e.originalEvent.touches[0].pageY; } }); // set up initial height getBarHeight(); // check start position if (o.start === 'bottom') { // scroll content to bottom bar.css({ top: me.outerHeight() - bar.outerHeight() }); scrollContent(0, true); } else if (o.start !== 'top') { // assume jQuery selector scrollContent($(o.start).position().top, null, true); // make sure bar stays hidden if (!o.alwaysVisible) { bar.hide(); } } // attach scroll events attachWheel(this); function _onWheel(e) { // use mouse wheel only when mouse is over if (!isOverPanel) { return; } var e = e || window.event; var delta = 0; if (e.wheelDelta) { delta = -e.wheelDelta/120; } if (e.detail) { delta = e.detail / 3; } var target = e.target || e.srcTarget || e.srcElement; if ($(target).closest('.' + o.wrapperClass).is(me.parent())) { // scroll content scrollContent(delta, true); } // stop window scroll if (e.preventDefault && !releaseScroll) { e.preventDefault(); } if (!releaseScroll) { e.returnValue = false; } } function scrollContent(y, isWheel, isJump) { releaseScroll = false; var delta = y; var maxTop = me.outerHeight() - bar.outerHeight(); if (isWheel) { // move bar with mouse wheel delta = parseInt(bar.css('top')) + y * parseInt(o.wheelStep) / 100 * bar.outerHeight(); // move bar, make sure it doesn't go out delta = Math.min(Math.max(delta, 0), maxTop); // if scrolling down, make sure a fractional change to the // scroll position isn't rounded away when the scrollbar's CSS is set // this flooring of delta would happened automatically when // bar.css is set below, but we floor here for clarity delta = (y > 0) ? Math.ceil(delta) : Math.floor(delta); // scroll the scrollbar bar.css({ top: delta + 'px' }); } // calculate actual scroll amount percentScroll = parseInt(bar.css('top')) / (me.outerHeight() - bar.outerHeight()); delta = percentScroll * (me[0].scrollHeight - me.outerHeight()); if (isJump) { delta = y; var offsetTop = delta / me[0].scrollHeight * me.outerHeight(); offsetTop = Math.min(Math.max(offsetTop, 0), maxTop); var attr = me[0].getAttribute("data-id"); offsetTop = (y > 0) ? Math.ceil(offsetTop) : Math.floor(offsetTop); var $bar = $(document.getElementById("bar_"+attr)); var $me = $(me[0]); if(offsetTop > ($me.outerHeight() - $bar.outerHeight())) { offsetTop = ($me.outerHeight() - $bar.outerHeight()); } $bar.css({top: offsetTop + 'px'}); } // scroll content me.scrollTop(delta); // fire scrolling event me.trigger('slimscrolling', ~~delta); // ensure bar is visible showBar(); // trigger hide when scroll is stopped hideBar(); } function attachWheel(target) { if (window.addEventListener) { target.addEventListener('DOMMouseScroll', _onWheel, false ); target.addEventListener('mousewheel', _onWheel, false ); } else { document.attachEvent("onmousewheel", _onWheel) } } function getBarHeight() { // calculate scrollbar height and make sure it is not too small barHeight = Math.max((me.outerHeight() / me[0].scrollHeight) * me.outerHeight(), minBarHeight); bar.css({ height: barHeight + 'px' }); // hide scrollbar if content is not long enough var display = barHeight == me.outerHeight() ? 'none' : 'block'; bar.css({ display: display }); } function showBar() { // recalculate bar height getBarHeight(); clearTimeout(queueHide); // when bar reached top or bottom if (percentScroll == ~~percentScroll) { //release wheel releaseScroll = o.allowPageScroll; // publish approporiate event if (lastScroll != percentScroll) { var msg = (~~percentScroll == 0) ? 'top' : 'bottom'; me.trigger('slimscroll', msg); } } else { releaseScroll = false; } lastScroll = percentScroll; // show only when required if(barHeight >= me.outerHeight()) { //allow window scroll releaseScroll = true; return; } bar.stop(true,true).fadeIn('fast'); if (o.railVisible) { rail.stop(true,true).fadeIn('fast'); } } function hideBar() { // only hide when options allow it if (!o.alwaysVisible) { queueHide = setTimeout(function(){ if (!(o.disableFadeOut && isOverPanel) && !isOverBar && !isDragg) { bar.fadeOut('slow'); rail.fadeOut('slow'); } }, 1000); } } }); // maintain chainability return this; } }); $.fn.extend({ slimscroll: $.fn.slimScroll }); })(jQuery); mapStyle = [ { "featureType": "all", "elementType": "labels", "stylers": [ { "visibility": "on" } ] }, { "featureType": "all", "elementType": "labels.text.fill", "stylers": [ { "saturation": 36 }, { "color": "#333333" }, { "lightness": 40 } ] }, { "featureType": "all", "elementType": "labels.text.stroke", "stylers": [ { "visibility": "on" }, { "color": "#ffffff" }, { "lightness": 16 } ] }, { "featureType": "all", "elementType": "labels.icon", "stylers": [ { "visibility": "off" } ] }, { "featureType": "administrative", "elementType": "geometry.fill", "stylers": [ { "color": "#fefefe" }, { "lightness": 20 } ] }, { "featureType": "administrative", "elementType": "geometry.stroke", "stylers": [ { "color": "#fefefe" }, { "lightness": 17 }, { "weight": 1.2 } ] }, { "featureType": "landscape", "elementType": "geometry", "stylers": [ { "color": "#f5f5f5" }, { "lightness": 20 } ] }, { "featureType": "landscape", "elementType": "labels", "stylers": [ { "visibility": "off" } ] }, { "featureType": "poi", "elementType": "all", "stylers": [ { "visibility": "on" } ] }, { "featureType": "poi", "elementType": "geometry", "stylers": [ { "color": "#f5f5f5" }, { "lightness": 21 }, { "visibility": "on" } ] }, { "featureType": "poi", "elementType": "labels", "stylers": [ { "visibility": "on" } ] }, { "featureType": "poi.park", "elementType": "geometry", "stylers": [ { "color": "#dedede" }, { "lightness": 21 } ] }, { "featureType": "road", "elementType": "labels", "stylers": [ { "visibility": "off" } ] }, { "featureType": "road.highway", "elementType": "geometry.fill", "stylers": [ { "color": "#ffffff" }, { "lightness": 17 } ] }, { "featureType": "road.highway", "elementType": "geometry.stroke", "stylers": [ { "color": "#ffffff" }, { "lightness": 29 }, { "weight": 0.2 } ] }, { "featureType": "road.arterial", "elementType": "geometry", "stylers": [ { "color": "#ffffff" }, { "lightness": 18 } ] }, { "featureType": "road.local", "elementType": "geometry", "stylers": [ { "color": "#ffffff" }, { "lightness": 16 } ] }, { "featureType": "transit", "elementType": "geometry", "stylers": [ { "color": "#f2f2f2" }, { "lightness": 19 } ] }, { "featureType": "water", "elementType": "geometry", "stylers": [ { "lightness": 17 }, { "color": "#d0dde7" } ] } ]; $(document).ready(function() { if($("#NoMainPic").length == 0) { $(".mainTitle").appendTo("#mainPic"); } $(".tpl_0012-- div.row.gallery .col-md-3").each(function() { if($(this).index() % 4 == 1 || $(this).index() % 4 == 2) { $(this).height($("div.row.gallery .col-md-3").eq(0).height()); $(this).find("img").height("100%"); var elem = $(this); elem.css("width", "100% !important"); $(this).css("border", "1px solid white"); } }); $(".ImmoFicheInformations").insertAfter("#ImmoFicheCall2Action"); $(".immoPic img").each(function() { console.log($(this).attr("src")); $(this).attr("src", $(this).attr("src").replace("/b_", "/1600_")); }); if ($('h1.mainTitle').html() == "Contactez-nous") { $('
    ').appendTo('#mainPic'); } if ($('body').hasClass("WebPage818") == true ) { console.log("Vous êtes sur la page d'acceuil"); $('
    ').appendTo('body'); var subscribeIsOn = false; $('.subscribe').click(function(){ subscribeIsOn = true; showSubscribe(); }); var sessionLocalSubscribe = localStorage.getItem("subscribeLocal"); var sessionSessionSubscribe = sessionStorage.getItem("subscribeSession"); console.log("sessionLocalSubscribe : "+sessionLocalSubscribe); if (sessionLocalSubscribe != "false" ) { if (sessionSessionSubscribe != "false" ) { setTimeout(function(){ if (subscribeIsOn == false) { showSubscribe(); } }, 3000); } } } }); function showSubscribe() { $('.darkPage').toggleClass('darkPage_on'); $('.formSubscribe').toggleClass('formSubscribe_on'); $(".darkPage, .cancel").click(function() { $('.formSubscribe').toggleClass('formSubscribe_on'); $('.darkPage').toggleClass('darkPage_on'); $(".darkPage").off(); $(".cancel").off(); sessionStorage.setItem("subscribeSession","false") }); $("#SubscribeSubmit>input").click(function() { localStorage.setItem("subscribeLocal","false") }); } function mapInit() { var href= $("#CSSColor").attr("href"); if($("#CSSColor").length > 0) href = href.split("/"); if($("#CSSColor").length == 0 || href[href.length - 1] != "white.css") { var mapOptions = { disableDefaultUI: true, styles: mapStyle }; map.setOptions(mapOptions); } } //test