mirror of
https://github.com/acemod/ACE3.git
synced 2024-08-30 18:23:18 +00:00
086ba5da87
* fix various lighthouse issues * remove bom FROM AN AUTOGENERATED FILE
6795 lines
296 KiB
JavaScript
6795 lines
296 KiB
JavaScript
/* Modernizr 2.8.3 (Custom Build) | MIT & BSD
|
|
* Build: http://modernizr.com/download/#-shiv-cssclasses-load
|
|
*/
|
|
;window.Modernizr=function(a,b,c){function u(a){j.cssText=a}function v(a,b){return u(prefixes.join(a+";")+(b||""))}function w(a,b){return typeof a===b}function x(a,b){return!!~(""+a).indexOf(b)}function y(a,b,d){for(var e in a){var f=b[a[e]];if(f!==c)return d===!1?a[e]:w(f,"function")?f.bind(d||b):f}return!1}var d="2.8.3",e={},f=!0,g=b.documentElement,h="modernizr",i=b.createElement(h),j=i.style,k,l={}.toString,m={},n={},o={},p=[],q=p.slice,r,s={}.hasOwnProperty,t;!w(s,"undefined")&&!w(s.call,"undefined")?t=function(a,b){return s.call(a,b)}:t=function(a,b){return b in a&&w(a.constructor.prototype[b],"undefined")},Function.prototype.bind||(Function.prototype.bind=function(b){var c=this;if(typeof c!="function")throw new TypeError;var d=q.call(arguments,1),e=function(){if(this instanceof e){var a=function(){};a.prototype=c.prototype;var f=new a,g=c.apply(f,d.concat(q.call(arguments)));return Object(g)===g?g:f}return c.apply(b,d.concat(q.call(arguments)))};return e});for(var z in m)t(m,z)&&(r=z.toLowerCase(),e[r]=m[z](),p.push((e[r]?"":"no-")+r));return e.addTest=function(a,b){if(typeof a=="object")for(var d in a)t(a,d)&&e.addTest(d,a[d]);else{a=a.toLowerCase();if(e[a]!==c)return e;b=typeof b=="function"?b():b,typeof f!="undefined"&&f&&(g.className+=" "+(b?"":"no-")+a),e[a]=b}return e},u(""),i=k=null,function(a,b){function l(a,b){var c=a.createElement("p"),d=a.getElementsByTagName("head")[0]||a.documentElement;return c.innerHTML="x<style>"+b+"</style>",d.insertBefore(c.lastChild,d.firstChild)}function m(){var a=s.elements;return typeof a=="string"?a.split(" "):a}function n(a){var b=j[a[h]];return b||(b={},i++,a[h]=i,j[i]=b),b}function o(a,c,d){c||(c=b);if(k)return c.createElement(a);d||(d=n(c));var g;return d.cache[a]?g=d.cache[a].cloneNode():f.test(a)?g=(d.cache[a]=d.createElem(a)).cloneNode():g=d.createElem(a),g.canHaveChildren&&!e.test(a)&&!g.tagUrn?d.frag.appendChild(g):g}function p(a,c){a||(a=b);if(k)return a.createDocumentFragment();c=c||n(a);var d=c.frag.cloneNode(),e=0,f=m(),g=f.length;for(;e<g;e++)d.createElement(f[e]);return d}function q(a,b){b.cache||(b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag()),a.createElement=function(c){return s.shivMethods?o(c,a,b):b.createElem(c)},a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+m().join().replace(/[\w\-]+/g,function(a){return b.createElem(a),b.frag.createElement(a),'c("'+a+'")'})+");return n}")(s,b.frag)}function r(a){a||(a=b);var c=n(a);return s.shivCSS&&!g&&!c.hasCSS&&(c.hasCSS=!!l(a,"article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}")),k||q(a,c),a}var c="3.7.0",d=a.html5||{},e=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,f=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,g,h="_html5shiv",i=0,j={},k;(function(){try{var a=b.createElement("a");a.innerHTML="<xyz></xyz>",g="hidden"in a,k=a.childNodes.length==1||function(){b.createElement("a");var a=b.createDocumentFragment();return typeof a.cloneNode=="undefined"||typeof a.createDocumentFragment=="undefined"||typeof a.createElement=="undefined"}()}catch(c){g=!0,k=!0}})();var s={elements:d.elements||"abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output progress section summary template time video",version:c,shivCSS:d.shivCSS!==!1,supportsUnknownElements:k,shivMethods:d.shivMethods!==!1,type:"default",shivDocument:r,createElement:o,createDocumentFragment:p};a.html5=s,r(b)}(this,b),e._version=d,g.className=g.className.replace(/(^|\s)no-js(\s|$)/,"$1$2")+(f?" js "+p.join(" "):""),e}(this,this.document),function(a,b,c){function d(a){return"[object Function]"==o.call(a)}function e(a){return"string"==typeof a}function f(){}function g(a){return!a||"loaded"==a||"complete"==a||"uninitialized"==a}function h(){var a=p.shift();q=1,a?a.t?m(function(){("c"==a.t?B.injectCss:B.injectJs)(a.s,0,a.a,a.x,a.e,1)},0):(a(),h()):q=0}function i(a,c,d,e,f,i,j){function k(b){if(!o&&g(l.readyState)&&(u.r=o=1,!q&&h(),l.onload=l.onreadystatechange=null,b)){"img"!=a&&m(function(){t.removeChild(l)},50);for(var d in y[c])y[c].hasOwnProperty(d)&&y[c][d].onload()}}var j=j||B.errorTimeout,l=b.createElement(a),o=0,r=0,u={t:d,s:c,e:f,a:i,x:j};1===y[c]&&(r=1,y[c]=[]),"object"==a?l.data=c:(l.src=c,l.type=a),l.width=l.height="0",l.onerror=l.onload=l.onreadystatechange=function(){k.call(this,r)},p.splice(e,0,u),"img"!=a&&(r||2===y[c]?(t.insertBefore(l,s?null:n),m(k,j)):y[c].push(l))}function j(a,b,c,d,f){return q=0,b=b||"j",e(a)?i("c"==b?v:u,a,b,this.i++,c,d,f):(p.splice(this.i++,0,a),1==p.length&&h()),this}function k(){var a=B;return a.loader={load:j,i:0},a}var l=b.documentElement,m=a.setTimeout,n=b.getElementsByTagName("script")[0],o={}.toString,p=[],q=0,r="MozAppearance"in l.style,s=r&&!!b.createRange().compareNode,t=s?l:n.parentNode,l=a.opera&&"[object Opera]"==o.call(a.opera),l=!!b.attachEvent&&!l,u=r?"object":l?"script":"img",v=l?"script":u,w=Array.isArray||function(a){return"[object Array]"==o.call(a)},x=[],y={},z={timeout:function(a,b){return b.length&&(a.timeout=b[0]),a}},A,B;B=function(a){function b(a){var a=a.split("!"),b=x.length,c=a.pop(),d=a.length,c={url:c,origUrl:c,prefixes:a},e,f,g;for(f=0;f<d;f++)g=a[f].split("="),(e=z[g.shift()])&&(c=e(c,g));for(f=0;f<b;f++)c=x[f](c);return c}function g(a,e,f,g,h){var i=b(a),j=i.autoCallback;i.url.split(".").pop().split("?").shift(),i.bypass||(e&&(e=d(e)?e:e[a]||e[g]||e[a.split("/").pop().split("?")[0]]),i.instead?i.instead(a,e,f,g,h):(y[i.url]?i.noexec=!0:y[i.url]=1,f.load(i.url,i.forceCSS||!i.forceJS&&"css"==i.url.split(".").pop().split("?").shift()?"c":c,i.noexec,i.attrs,i.timeout),(d(e)||d(j))&&f.load(function(){k(),e&&e(i.origUrl,h,g),j&&j(i.origUrl,h,g),y[i.url]=2})))}function h(a,b){function c(a,c){if(a){if(e(a))c||(j=function(){var a=[].slice.call(arguments);k.apply(this,a),l()}),g(a,j,b,0,h);else if(Object(a)===a)for(n in m=function(){var b=0,c;for(c in a)a.hasOwnProperty(c)&&b++;return b}(),a)a.hasOwnProperty(n)&&(!c&&!--m&&(d(j)?j=function(){var a=[].slice.call(arguments);k.apply(this,a),l()}:j[n]=function(a){return function(){var b=[].slice.call(arguments);a&&a.apply(this,b),l()}}(k[n])),g(a[n],j,b,n,h))}else!c&&l()}var h=!!a.test,i=a.load||a.both,j=a.callback||f,k=j,l=a.complete||f,m,n;c(h?a.yep:a.nope,!!i),i&&c(i)}var i,j,l=this.yepnope.loader;if(e(a))g(a,0,l,0);else if(w(a))for(i=0;i<a.length;i++)j=a[i],e(j)?g(j,0,l,0):w(j)?B(j):Object(j)===j&&h(j,l);else Object(a)===a&&h(a,l)},B.addPrefix=function(a,b){z[a]=b},B.addFilter=function(a){x.push(a)},B.errorTimeout=1e4,null==b.readyState&&b.addEventListener&&(b.readyState="loading",b.addEventListener("DOMContentLoaded",A=function(){b.removeEventListener("DOMContentLoaded",A,0),b.readyState="complete"},0)),a.yepnope=k(),a.yepnope.executeStack=h,a.yepnope.injectJs=function(a,c,d,e,i,j){var k=b.createElement("script"),l,o,e=e||B.errorTimeout;k.src=a;for(o in d)k.setAttribute(o,d[o]);c=j?h:c||f,k.onreadystatechange=k.onload=function(){!l&&g(k.readyState)&&(l=1,c(),k.onload=k.onreadystatechange=null)},m(function(){l||(l=1,c(1))},e),i?k.onload():n.parentNode.insertBefore(k,n)},a.yepnope.injectCss=function(a,c,d,e,g,i){var e=b.createElement("link"),j,c=i?h:c||f;e.href=a,e.rel="stylesheet",e.type="text/css";for(j in d)e.setAttribute(j,d[j]);g||(n.parentNode.insertBefore(e,n),m(c,0))}}(this,document),Modernizr.load=function(){yepnope.apply(window,[].slice.call(arguments,0))};
|
|
/*! picturefill - v3.0.2 - 2016-02-12
|
|
* https://scottjehl.github.io/picturefill/
|
|
* Copyright (c) 2016 https://github.com/scottjehl/picturefill/blob/master/Authors.txt; Licensed MIT
|
|
*/
|
|
/*! Gecko-Picture - v1.0
|
|
* https://github.com/scottjehl/picturefill/tree/3.0/src/plugins/gecko-picture
|
|
* Firefox's early picture implementation (prior to FF41) is static and does
|
|
* not react to viewport changes. This tiny module fixes this.
|
|
*/
|
|
(function (window) {
|
|
/*jshint eqnull:true */
|
|
var ua = navigator.userAgent;
|
|
|
|
if (window.HTMLPictureElement && ((/ecko/).test(ua) && ua.match(/rv\:(\d+)/) && RegExp.$1 < 45)) {
|
|
addEventListener("resize", (function () {
|
|
var timer;
|
|
|
|
var dummySrc = document.createElement("source");
|
|
|
|
var fixRespimg = function (img) {
|
|
var source, sizes;
|
|
var picture = img.parentNode;
|
|
|
|
if (picture.nodeName.toUpperCase() === "PICTURE") {
|
|
source = dummySrc.cloneNode();
|
|
|
|
picture.insertBefore(source, picture.firstElementChild);
|
|
setTimeout(function () {
|
|
picture.removeChild(source);
|
|
});
|
|
} else if (!img._pfLastSize || img.offsetWidth > img._pfLastSize) {
|
|
img._pfLastSize = img.offsetWidth;
|
|
sizes = img.sizes;
|
|
img.sizes += ",100vw";
|
|
setTimeout(function () {
|
|
img.sizes = sizes;
|
|
});
|
|
}
|
|
};
|
|
|
|
var findPictureImgs = function () {
|
|
var i;
|
|
var imgs = document.querySelectorAll("picture > img, img[srcset][sizes]");
|
|
for (i = 0; i < imgs.length; i++) {
|
|
fixRespimg(imgs[i]);
|
|
}
|
|
};
|
|
var onResize = function () {
|
|
clearTimeout(timer);
|
|
timer = setTimeout(findPictureImgs, 99);
|
|
};
|
|
var mq = window.matchMedia && matchMedia("(orientation: landscape)");
|
|
var init = function () {
|
|
onResize();
|
|
|
|
if (mq && mq.addListener) {
|
|
mq.addListener(onResize);
|
|
}
|
|
};
|
|
|
|
dummySrc.srcset = "data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==";
|
|
|
|
if (/^[c|i]|d$/.test(document.readyState || "")) {
|
|
init();
|
|
} else {
|
|
document.addEventListener("DOMContentLoaded", init);
|
|
}
|
|
|
|
return onResize;
|
|
})());
|
|
}
|
|
})(window);
|
|
|
|
/*! Picturefill - v3.0.2
|
|
* http://scottjehl.github.io/picturefill
|
|
* Copyright (c) 2015 https://github.com/scottjehl/picturefill/blob/master/Authors.txt;
|
|
* License: MIT
|
|
*/
|
|
|
|
(function (window, document, undefined) {
|
|
// Enable strict mode
|
|
"use strict";
|
|
|
|
// HTML shim|v it for old IE (IE9 will still need the HTML video tag workaround)
|
|
document.createElement("picture");
|
|
|
|
var warn, eminpx, alwaysCheckWDescriptor, evalId;
|
|
// local object for method references and testing exposure
|
|
var pf = {};
|
|
var isSupportTestReady = false;
|
|
var noop = function () {
|
|
};
|
|
var image = document.createElement("img");
|
|
var getImgAttr = image.getAttribute;
|
|
var setImgAttr = image.setAttribute;
|
|
var removeImgAttr = image.removeAttribute;
|
|
var docElem = document.documentElement;
|
|
var types = {};
|
|
var cfg = {
|
|
//resource selection:
|
|
algorithm: ""
|
|
};
|
|
var srcAttr = "data-pfsrc";
|
|
var srcsetAttr = srcAttr + "set";
|
|
// ua sniffing is done for undetectable img loading features,
|
|
// to do some non crucial perf optimizations
|
|
var ua = navigator.userAgent;
|
|
var supportAbort = (/rident/).test(ua) || ((/ecko/).test(ua) && ua.match(/rv\:(\d+)/) && RegExp.$1 > 35 );
|
|
var curSrcProp = "currentSrc";
|
|
var regWDesc = /\s+\+?\d+(e\d+)?w/;
|
|
var regSize = /(\([^)]+\))?\s*(.+)/;
|
|
var setOptions = window.picturefillCFG;
|
|
/**
|
|
* Shortcut property for https://w3c.github.io/webappsec/specs/mixedcontent/#restricts-mixed-content ( for easy overriding in tests )
|
|
*/
|
|
// baseStyle also used by getEmValue (i.e.: width: 1em is important)
|
|
var baseStyle = "position:absolute;left:0;visibility:hidden;display:block;padding:0;border:none;font-size:1em;width:1em;overflow:hidden;clip:rect(0px, 0px, 0px, 0px)";
|
|
var fsCss = "font-size:100%!important;";
|
|
var isVwDirty = true;
|
|
|
|
var cssCache = {};
|
|
var sizeLengthCache = {};
|
|
var DPR = window.devicePixelRatio;
|
|
var units = {
|
|
px: 1,
|
|
"in": 96
|
|
};
|
|
var anchor = document.createElement("a");
|
|
/**
|
|
* alreadyRun flag used for setOptions. is it true setOptions will reevaluate
|
|
* @type {boolean}
|
|
*/
|
|
var alreadyRun = false;
|
|
|
|
// Reusable, non-"g" Regexes
|
|
|
|
// (Don't use \s, to avoid matching non-breaking space.)
|
|
var regexLeadingSpaces = /^[ \t\n\r\u000c]+/,
|
|
regexLeadingCommasOrSpaces = /^[, \t\n\r\u000c]+/,
|
|
regexLeadingNotSpaces = /^[^ \t\n\r\u000c]+/,
|
|
regexTrailingCommas = /[,]+$/,
|
|
regexNonNegativeInteger = /^\d+$/,
|
|
|
|
// ( Positive or negative or unsigned integers or decimals, without or without exponents.
|
|
// Must include at least one digit.
|
|
// According to spec tests any decimal point must be followed by a digit.
|
|
// No leading plus sign is allowed.)
|
|
// https://html.spec.whatwg.org/multipage/infrastructure.html#valid-floating-point-number
|
|
regexFloatingPoint = /^-?(?:[0-9]+|[0-9]*\.[0-9]+)(?:[eE][+-]?[0-9]+)?$/;
|
|
|
|
var on = function (obj, evt, fn, capture) {
|
|
if (obj.addEventListener) {
|
|
obj.addEventListener(evt, fn, capture || false);
|
|
} else if (obj.attachEvent) {
|
|
obj.attachEvent("on" + evt, fn);
|
|
}
|
|
};
|
|
|
|
/**
|
|
* simple memoize function:
|
|
*/
|
|
|
|
var memoize = function (fn) {
|
|
var cache = {};
|
|
return function (input) {
|
|
if (!(input in cache)) {
|
|
cache[input] = fn(input);
|
|
}
|
|
return cache[input];
|
|
};
|
|
};
|
|
|
|
// UTILITY FUNCTIONS
|
|
|
|
// Manual is faster than RegEx
|
|
// http://jsperf.com/whitespace-character/5
|
|
function isSpace(c) {
|
|
return (c === "\u0020" || // space
|
|
c === "\u0009" || // horizontal tab
|
|
c === "\u000A" || // new line
|
|
c === "\u000C" || // form feed
|
|
c === "\u000D"); // carriage return
|
|
}
|
|
|
|
/**
|
|
* gets a mediaquery and returns a boolean or gets a css length and returns a number
|
|
* @param css mediaqueries or css length
|
|
* @returns {boolean|number}
|
|
*
|
|
* based on: https://gist.github.com/jonathantneal/db4f77009b155f083738
|
|
*/
|
|
var evalCSS = (function () {
|
|
|
|
var regLength = /^([\d\.]+)(em|vw|px)$/;
|
|
var replace = function () {
|
|
var args = arguments, index = 0, string = args[0];
|
|
while (++index in args) {
|
|
string = string.replace(args[index], args[++index]);
|
|
}
|
|
return string;
|
|
};
|
|
|
|
var buildStr = memoize(function (css) {
|
|
|
|
return "return " + replace((css || "").toLowerCase(),
|
|
// interpret `and`
|
|
/\band\b/g, "&&",
|
|
|
|
// interpret `,`
|
|
/,/g, "||",
|
|
|
|
// interpret `min-` as >=
|
|
/min-([a-z-\s]+):/g, "e.$1>=",
|
|
|
|
// interpret `max-` as <=
|
|
/max-([a-z-\s]+):/g, "e.$1<=",
|
|
|
|
//calc value
|
|
/calc([^)]+)/g, "($1)",
|
|
|
|
// interpret css values
|
|
/(\d+[\.]*[\d]*)([a-z]+)/g, "($1 * e.$2)",
|
|
//make eval less evil
|
|
/^(?!(e.[a-z]|[0-9\.&=|><\+\-\*\(\)\/])).*/ig, ""
|
|
) + ";";
|
|
});
|
|
|
|
return function (css, length) {
|
|
var parsedLength;
|
|
if (!(css in cssCache)) {
|
|
cssCache[css] = false;
|
|
if (length && (parsedLength = css.match(regLength))) {
|
|
cssCache[css] = parsedLength[1] * units[parsedLength[2]];
|
|
} else {
|
|
/*jshint evil:true */
|
|
try {
|
|
cssCache[css] = new Function("e", buildStr(css))(units);
|
|
} catch (e) {
|
|
}
|
|
/*jshint evil:false */
|
|
}
|
|
}
|
|
return cssCache[css];
|
|
};
|
|
})();
|
|
|
|
var setResolution = function (candidate, sizesattr) {
|
|
if (candidate.w) { // h = means height: || descriptor.type === 'h' do not handle yet...
|
|
candidate.cWidth = pf.calcListLength(sizesattr || "100vw");
|
|
candidate.res = candidate.w / candidate.cWidth;
|
|
} else {
|
|
candidate.res = candidate.d;
|
|
}
|
|
return candidate;
|
|
};
|
|
|
|
/**
|
|
*
|
|
* @param opt
|
|
*/
|
|
var picturefill = function (opt) {
|
|
|
|
if (!isSupportTestReady) {
|
|
return;
|
|
}
|
|
|
|
var elements, i, plen;
|
|
|
|
var options = opt || {};
|
|
|
|
if (options.elements && options.elements.nodeType === 1) {
|
|
if (options.elements.nodeName.toUpperCase() === "IMG") {
|
|
options.elements = [options.elements];
|
|
} else {
|
|
options.context = options.elements;
|
|
options.elements = null;
|
|
}
|
|
}
|
|
|
|
elements = options.elements || pf.qsa((options.context || document), ( options.reevaluate || options.reselect ) ? pf.sel : pf.selShort);
|
|
|
|
if ((plen = elements.length)) {
|
|
|
|
pf.setupRun(options);
|
|
alreadyRun = true;
|
|
|
|
// Loop through all elements
|
|
for (i = 0; i < plen; i++) {
|
|
pf.fillImg(elements[i], options);
|
|
}
|
|
|
|
pf.teardownRun(options);
|
|
}
|
|
};
|
|
|
|
/**
|
|
* outputs a warning for the developer
|
|
* @param {message}
|
|
* @type {Function}
|
|
*/
|
|
warn = ( window.console && console.warn ) ?
|
|
function (message) {
|
|
console.warn(message);
|
|
} :
|
|
noop
|
|
;
|
|
|
|
if (!(curSrcProp in image)) {
|
|
curSrcProp = "src";
|
|
}
|
|
|
|
// Add support for standard mime types.
|
|
types["image/jpeg"] = true;
|
|
types["image/gif"] = true;
|
|
types["image/png"] = true;
|
|
|
|
function detectTypeSupport(type, typeUri) {
|
|
// based on Modernizr's lossless img-webp test
|
|
// note: asynchronous
|
|
var image = new window.Image();
|
|
image.onerror = function () {
|
|
types[type] = false;
|
|
picturefill();
|
|
};
|
|
image.onload = function () {
|
|
types[type] = image.width === 1;
|
|
picturefill();
|
|
};
|
|
image.src = typeUri;
|
|
return "pending";
|
|
}
|
|
|
|
// test svg support
|
|
types["image/svg+xml"] = document.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#Image", "1.1");
|
|
|
|
/**
|
|
* updates the internal vW property with the current viewport width in px
|
|
*/
|
|
function updateMetrics() {
|
|
|
|
isVwDirty = false;
|
|
DPR = window.devicePixelRatio;
|
|
cssCache = {};
|
|
sizeLengthCache = {};
|
|
|
|
pf.DPR = DPR || 1;
|
|
|
|
units.width = Math.max(window.innerWidth || 0, docElem.clientWidth);
|
|
units.height = Math.max(window.innerHeight || 0, docElem.clientHeight);
|
|
|
|
units.vw = units.width / 100;
|
|
units.vh = units.height / 100;
|
|
|
|
evalId = [units.height, units.width, DPR].join("-");
|
|
|
|
units.em = pf.getEmValue();
|
|
units.rem = units.em;
|
|
}
|
|
|
|
function chooseLowRes(lowerValue, higherValue, dprValue, isCached) {
|
|
var bonusFactor, tooMuch, bonus, meanDensity;
|
|
|
|
//experimental
|
|
if (cfg.algorithm === "saveData") {
|
|
if (lowerValue > 2.7) {
|
|
meanDensity = dprValue + 1;
|
|
} else {
|
|
tooMuch = higherValue - dprValue;
|
|
bonusFactor = Math.pow(lowerValue - 0.6, 1.5);
|
|
|
|
bonus = tooMuch * bonusFactor;
|
|
|
|
if (isCached) {
|
|
bonus += 0.1 * bonusFactor;
|
|
}
|
|
|
|
meanDensity = lowerValue + bonus;
|
|
}
|
|
} else {
|
|
meanDensity = (dprValue > 1) ?
|
|
Math.sqrt(lowerValue * higherValue) :
|
|
lowerValue;
|
|
}
|
|
|
|
return meanDensity > dprValue;
|
|
}
|
|
|
|
function applyBestCandidate(img) {
|
|
var srcSetCandidates;
|
|
var matchingSet = pf.getSet(img);
|
|
var evaluated = false;
|
|
if (matchingSet !== "pending") {
|
|
evaluated = evalId;
|
|
if (matchingSet) {
|
|
srcSetCandidates = pf.setRes(matchingSet);
|
|
pf.applySetCandidate(srcSetCandidates, img);
|
|
}
|
|
}
|
|
img[pf.ns].evaled = evaluated;
|
|
}
|
|
|
|
function ascendingSort(a, b) {
|
|
return a.res - b.res;
|
|
}
|
|
|
|
function setSrcToCur(img, src, set) {
|
|
var candidate;
|
|
if (!set && src) {
|
|
set = img[pf.ns].sets;
|
|
set = set && set[set.length - 1];
|
|
}
|
|
|
|
candidate = getCandidateForSrc(src, set);
|
|
|
|
if (candidate) {
|
|
src = pf.makeUrl(src);
|
|
img[pf.ns].curSrc = src;
|
|
img[pf.ns].curCan = candidate;
|
|
|
|
if (!candidate.res) {
|
|
setResolution(candidate, candidate.set.sizes);
|
|
}
|
|
}
|
|
return candidate;
|
|
}
|
|
|
|
function getCandidateForSrc(src, set) {
|
|
var i, candidate, candidates;
|
|
if (src && set) {
|
|
candidates = pf.parseSet(set);
|
|
src = pf.makeUrl(src);
|
|
for (i = 0; i < candidates.length; i++) {
|
|
if (src === pf.makeUrl(candidates[i].url)) {
|
|
candidate = candidates[i];
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
return candidate;
|
|
}
|
|
|
|
function getAllSourceElements(picture, candidates) {
|
|
var i, len, source, srcset;
|
|
|
|
// SPEC mismatch intended for size and perf:
|
|
// actually only source elements preceding the img should be used
|
|
// also note: don't use qsa here, because IE8 sometimes doesn't like source as the key part in a selector
|
|
var sources = picture.getElementsByTagName("source");
|
|
|
|
for (i = 0, len = sources.length; i < len; i++) {
|
|
source = sources[i];
|
|
source[pf.ns] = true;
|
|
srcset = source.getAttribute("srcset");
|
|
|
|
// if source does not have a srcset attribute, skip
|
|
if (srcset) {
|
|
candidates.push({
|
|
srcset: srcset,
|
|
media: source.getAttribute("media"),
|
|
type: source.getAttribute("type"),
|
|
sizes: source.getAttribute("sizes")
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Srcset Parser
|
|
* By Alex Bell | MIT License
|
|
*
|
|
* @returns Array [{url: _, d: _, w: _, h:_, set:_(????)}, ...]
|
|
*
|
|
* Based super duper closely on the reference algorithm at:
|
|
* https://html.spec.whatwg.org/multipage/embedded-content.html#parse-a-srcset-attribute
|
|
*/
|
|
|
|
// 1. Let input be the value passed to this algorithm.
|
|
// (TO-DO : Explain what "set" argument is here. Maybe choose a more
|
|
// descriptive & more searchable name. Since passing the "set" in really has
|
|
// nothing to do with parsing proper, I would prefer this assignment eventually
|
|
// go in an external fn.)
|
|
function parseSrcset(input, set) {
|
|
|
|
function collectCharacters(regEx) {
|
|
var chars,
|
|
match = regEx.exec(input.substring(pos));
|
|
if (match) {
|
|
chars = match[0];
|
|
pos += chars.length;
|
|
return chars;
|
|
}
|
|
}
|
|
|
|
var inputLength = input.length,
|
|
url,
|
|
descriptors,
|
|
currentDescriptor,
|
|
state,
|
|
c,
|
|
|
|
// 2. Let position be a pointer into input, initially pointing at the start
|
|
// of the string.
|
|
pos = 0,
|
|
|
|
// 3. Let candidates be an initially empty source set.
|
|
candidates = [];
|
|
|
|
/**
|
|
* Adds descriptor properties to a candidate, pushes to the candidates array
|
|
* @return undefined
|
|
*/
|
|
// (Declared outside of the while loop so that it's only created once.
|
|
// (This fn is defined before it is used, in order to pass JSHINT.
|
|
// Unfortunately this breaks the sequencing of the spec comments. :/ )
|
|
function parseDescriptors() {
|
|
|
|
// 9. Descriptor parser: Let error be no.
|
|
var pError = false,
|
|
|
|
// 10. Let width be absent.
|
|
// 11. Let density be absent.
|
|
// 12. Let future-compat-h be absent. (We're implementing it now as h)
|
|
w, d, h, i,
|
|
candidate = {},
|
|
desc, lastChar, value, intVal, floatVal;
|
|
|
|
// 13. For each descriptor in descriptors, run the appropriate set of steps
|
|
// from the following list:
|
|
for (i = 0; i < descriptors.length; i++) {
|
|
desc = descriptors[i];
|
|
|
|
lastChar = desc[desc.length - 1];
|
|
value = desc.substring(0, desc.length - 1);
|
|
intVal = parseInt(value, 10);
|
|
floatVal = parseFloat(value);
|
|
|
|
// If the descriptor consists of a valid non-negative integer followed by
|
|
// a U+0077 LATIN SMALL LETTER W character
|
|
if (regexNonNegativeInteger.test(value) && (lastChar === "w")) {
|
|
|
|
// If width and density are not both absent, then let error be yes.
|
|
if (w || d) {
|
|
pError = true;
|
|
}
|
|
|
|
// Apply the rules for parsing non-negative integers to the descriptor.
|
|
// If the result is zero, let error be yes.
|
|
// Otherwise, let width be the result.
|
|
if (intVal === 0) {
|
|
pError = true;
|
|
} else {
|
|
w = intVal;
|
|
}
|
|
|
|
// If the descriptor consists of a valid floating-point number followed by
|
|
// a U+0078 LATIN SMALL LETTER X character
|
|
} else if (regexFloatingPoint.test(value) && (lastChar === "x")) {
|
|
|
|
// If width, density and future-compat-h are not all absent, then let error
|
|
// be yes.
|
|
if (w || d || h) {
|
|
pError = true;
|
|
}
|
|
|
|
// Apply the rules for parsing floating-point number values to the descriptor.
|
|
// If the result is less than zero, let error be yes. Otherwise, let density
|
|
// be the result.
|
|
if (floatVal < 0) {
|
|
pError = true;
|
|
} else {
|
|
d = floatVal;
|
|
}
|
|
|
|
// If the descriptor consists of a valid non-negative integer followed by
|
|
// a U+0068 LATIN SMALL LETTER H character
|
|
} else if (regexNonNegativeInteger.test(value) && (lastChar === "h")) {
|
|
|
|
// If height and density are not both absent, then let error be yes.
|
|
if (h || d) {
|
|
pError = true;
|
|
}
|
|
|
|
// Apply the rules for parsing non-negative integers to the descriptor.
|
|
// If the result is zero, let error be yes. Otherwise, let future-compat-h
|
|
// be the result.
|
|
if (intVal === 0) {
|
|
pError = true;
|
|
} else {
|
|
h = intVal;
|
|
}
|
|
|
|
// Anything else, Let error be yes.
|
|
} else {
|
|
pError = true;
|
|
}
|
|
} // (close step 13 for loop)
|
|
|
|
// 15. If error is still no, then append a new image source to candidates whose
|
|
// URL is url, associated with a width width if not absent and a pixel
|
|
// density density if not absent. Otherwise, there is a parse error.
|
|
if (!pError) {
|
|
candidate.url = url;
|
|
|
|
if (w) {
|
|
candidate.w = w;
|
|
}
|
|
if (d) {
|
|
candidate.d = d;
|
|
}
|
|
if (h) {
|
|
candidate.h = h;
|
|
}
|
|
if (!h && !d && !w) {
|
|
candidate.d = 1;
|
|
}
|
|
if (candidate.d === 1) {
|
|
set.has1x = true;
|
|
}
|
|
candidate.set = set;
|
|
|
|
candidates.push(candidate);
|
|
}
|
|
} // (close parseDescriptors fn)
|
|
|
|
/**
|
|
* Tokenizes descriptor properties prior to parsing
|
|
* Returns undefined.
|
|
* (Again, this fn is defined before it is used, in order to pass JSHINT.
|
|
* Unfortunately this breaks the logical sequencing of the spec comments. :/ )
|
|
*/
|
|
function tokenize() {
|
|
|
|
// 8.1. Descriptor tokeniser: Skip whitespace
|
|
collectCharacters(regexLeadingSpaces);
|
|
|
|
// 8.2. Let current descriptor be the empty string.
|
|
currentDescriptor = "";
|
|
|
|
// 8.3. Let state be in descriptor.
|
|
state = "in descriptor";
|
|
|
|
while (true) {
|
|
|
|
// 8.4. Let c be the character at position.
|
|
c = input.charAt(pos);
|
|
|
|
// Do the following depending on the value of state.
|
|
// For the purpose of this step, "EOF" is a special character representing
|
|
// that position is past the end of input.
|
|
|
|
// In descriptor
|
|
if (state === "in descriptor") {
|
|
// Do the following, depending on the value of c:
|
|
|
|
// Space character
|
|
// If current descriptor is not empty, append current descriptor to
|
|
// descriptors and let current descriptor be the empty string.
|
|
// Set state to after descriptor.
|
|
if (isSpace(c)) {
|
|
if (currentDescriptor) {
|
|
descriptors.push(currentDescriptor);
|
|
currentDescriptor = "";
|
|
state = "after descriptor";
|
|
}
|
|
|
|
// U+002C COMMA (,)
|
|
// Advance position to the next character in input. If current descriptor
|
|
// is not empty, append current descriptor to descriptors. Jump to the step
|
|
// labeled descriptor parser.
|
|
} else if (c === ",") {
|
|
pos += 1;
|
|
if (currentDescriptor) {
|
|
descriptors.push(currentDescriptor);
|
|
}
|
|
parseDescriptors();
|
|
return;
|
|
|
|
// U+0028 LEFT PARENTHESIS (()
|
|
// Append c to current descriptor. Set state to in parens.
|
|
} else if (c === "\u0028") {
|
|
currentDescriptor = currentDescriptor + c;
|
|
state = "in parens";
|
|
|
|
// EOF
|
|
// If current descriptor is not empty, append current descriptor to
|
|
// descriptors. Jump to the step labeled descriptor parser.
|
|
} else if (c === "") {
|
|
if (currentDescriptor) {
|
|
descriptors.push(currentDescriptor);
|
|
}
|
|
parseDescriptors();
|
|
return;
|
|
|
|
// Anything else
|
|
// Append c to current descriptor.
|
|
} else {
|
|
currentDescriptor = currentDescriptor + c;
|
|
}
|
|
// (end "in descriptor"
|
|
|
|
// In parens
|
|
} else if (state === "in parens") {
|
|
|
|
// U+0029 RIGHT PARENTHESIS ())
|
|
// Append c to current descriptor. Set state to in descriptor.
|
|
if (c === ")") {
|
|
currentDescriptor = currentDescriptor + c;
|
|
state = "in descriptor";
|
|
|
|
// EOF
|
|
// Append current descriptor to descriptors. Jump to the step labeled
|
|
// descriptor parser.
|
|
} else if (c === "") {
|
|
descriptors.push(currentDescriptor);
|
|
parseDescriptors();
|
|
return;
|
|
|
|
// Anything else
|
|
// Append c to current descriptor.
|
|
} else {
|
|
currentDescriptor = currentDescriptor + c;
|
|
}
|
|
|
|
// After descriptor
|
|
} else if (state === "after descriptor") {
|
|
|
|
// Do the following, depending on the value of c:
|
|
// Space character: Stay in this state.
|
|
if (isSpace(c)) {
|
|
|
|
// EOF: Jump to the step labeled descriptor parser.
|
|
} else if (c === "") {
|
|
parseDescriptors();
|
|
return;
|
|
|
|
// Anything else
|
|
// Set state to in descriptor. Set position to the previous character in input.
|
|
} else {
|
|
state = "in descriptor";
|
|
pos -= 1;
|
|
|
|
}
|
|
}
|
|
|
|
// Advance position to the next character in input.
|
|
pos += 1;
|
|
|
|
// Repeat this step.
|
|
} // (close while true loop)
|
|
}
|
|
|
|
// 4. Splitting loop: Collect a sequence of characters that are space
|
|
// characters or U+002C COMMA characters. If any U+002C COMMA characters
|
|
// were collected, that is a parse error.
|
|
while (true) {
|
|
collectCharacters(regexLeadingCommasOrSpaces);
|
|
|
|
// 5. If position is past the end of input, return candidates and abort these steps.
|
|
if (pos >= inputLength) {
|
|
return candidates; // (we're done, this is the sole return path)
|
|
}
|
|
|
|
// 6. Collect a sequence of characters that are not space characters,
|
|
// and let that be url.
|
|
url = collectCharacters(regexLeadingNotSpaces);
|
|
|
|
// 7. Let descriptors be a new empty list.
|
|
descriptors = [];
|
|
|
|
// 8. If url ends with a U+002C COMMA character (,), follow these substeps:
|
|
// (1). Remove all trailing U+002C COMMA characters from url. If this removed
|
|
// more than one character, that is a parse error.
|
|
if (url.slice(-1) === ",") {
|
|
url = url.replace(regexTrailingCommas, "");
|
|
// (Jump ahead to step 9 to skip tokenization and just push the candidate).
|
|
parseDescriptors();
|
|
|
|
// Otherwise, follow these substeps:
|
|
} else {
|
|
tokenize();
|
|
} // (close else of step 8)
|
|
|
|
// 16. Return to the step labeled splitting loop.
|
|
} // (Close of big while loop.)
|
|
}
|
|
|
|
/*
|
|
* Sizes Parser
|
|
*
|
|
* By Alex Bell | MIT License
|
|
*
|
|
* Non-strict but accurate and lightweight JS Parser for the string value <img sizes="here">
|
|
*
|
|
* Reference algorithm at:
|
|
* https://html.spec.whatwg.org/multipage/embedded-content.html#parse-a-sizes-attribute
|
|
*
|
|
* Most comments are copied in directly from the spec
|
|
* (except for comments in parens).
|
|
*
|
|
* Grammar is:
|
|
* <source-size-list> = <source-size># [ , <source-size-value> ]? | <source-size-value>
|
|
* <source-size> = <media-condition> <source-size-value>
|
|
* <source-size-value> = <length>
|
|
* http://www.w3.org/html/wg/drafts/html/master/embedded-content.html#attr-img-sizes
|
|
*
|
|
* E.g. "(max-width: 30em) 100vw, (max-width: 50em) 70vw, 100vw"
|
|
* or "(min-width: 30em), calc(30vw - 15px)" or just "30vw"
|
|
*
|
|
* Returns the first valid <css-length> with a media condition that evaluates to true,
|
|
* or "100vw" if all valid media conditions evaluate to false.
|
|
*
|
|
*/
|
|
|
|
function parseSizes(strValue) {
|
|
|
|
// (Percentage CSS lengths are not allowed in this case, to avoid confusion:
|
|
// https://html.spec.whatwg.org/multipage/embedded-content.html#valid-source-size-list
|
|
// CSS allows a single optional plus or minus sign:
|
|
// http://www.w3.org/TR/CSS2/syndata.html#numbers
|
|
// CSS is ASCII case-insensitive:
|
|
// http://www.w3.org/TR/CSS2/syndata.html#characters )
|
|
// Spec allows exponential notation for <number> type:
|
|
// http://dev.w3.org/csswg/css-values/#numbers
|
|
var regexCssLengthWithUnits = /^(?:[+-]?[0-9]+|[0-9]*\.[0-9]+)(?:[eE][+-]?[0-9]+)?(?:ch|cm|em|ex|in|mm|pc|pt|px|rem|vh|vmin|vmax|vw)$/i;
|
|
|
|
// (This is a quick and lenient test. Because of optional unlimited-depth internal
|
|
// grouping parens and strict spacing rules, this could get very complicated.)
|
|
var regexCssCalc = /^calc\((?:[0-9a-z \.\+\-\*\/\(\)]+)\)$/i;
|
|
|
|
var i;
|
|
var unparsedSizesList;
|
|
var unparsedSizesListLength;
|
|
var unparsedSize;
|
|
var lastComponentValue;
|
|
var size;
|
|
|
|
// UTILITY FUNCTIONS
|
|
|
|
// (Toy CSS parser. The goals here are:
|
|
// 1) expansive test coverage without the weight of a full CSS parser.
|
|
// 2) Avoiding regex wherever convenient.
|
|
// Quick tests: http://jsfiddle.net/gtntL4gr/3/
|
|
// Returns an array of arrays.)
|
|
function parseComponentValues(str) {
|
|
var chrctr;
|
|
var component = "";
|
|
var componentArray = [];
|
|
var listArray = [];
|
|
var parenDepth = 0;
|
|
var pos = 0;
|
|
var inComment = false;
|
|
|
|
function pushComponent() {
|
|
if (component) {
|
|
componentArray.push(component);
|
|
component = "";
|
|
}
|
|
}
|
|
|
|
function pushComponentArray() {
|
|
if (componentArray[0]) {
|
|
listArray.push(componentArray);
|
|
componentArray = [];
|
|
}
|
|
}
|
|
|
|
// (Loop forwards from the beginning of the string.)
|
|
while (true) {
|
|
chrctr = str.charAt(pos);
|
|
|
|
if (chrctr === "") { // ( End of string reached.)
|
|
pushComponent();
|
|
pushComponentArray();
|
|
return listArray;
|
|
} else if (inComment) {
|
|
if ((chrctr === "*") && (str[pos + 1] === "/")) { // (At end of a comment.)
|
|
inComment = false;
|
|
pos += 2;
|
|
pushComponent();
|
|
continue;
|
|
} else {
|
|
pos += 1; // (Skip all characters inside comments.)
|
|
continue;
|
|
}
|
|
} else if (isSpace(chrctr)) {
|
|
// (If previous character in loop was also a space, or if
|
|
// at the beginning of the string, do not add space char to
|
|
// component.)
|
|
if ((str.charAt(pos - 1) && isSpace(str.charAt(pos - 1)) ) || !component) {
|
|
pos += 1;
|
|
continue;
|
|
} else if (parenDepth === 0) {
|
|
pushComponent();
|
|
pos += 1;
|
|
continue;
|
|
} else {
|
|
// (Replace any space character with a plain space for legibility.)
|
|
chrctr = " ";
|
|
}
|
|
} else if (chrctr === "(") {
|
|
parenDepth += 1;
|
|
} else if (chrctr === ")") {
|
|
parenDepth -= 1;
|
|
} else if (chrctr === ",") {
|
|
pushComponent();
|
|
pushComponentArray();
|
|
pos += 1;
|
|
continue;
|
|
} else if ((chrctr === "/") && (str.charAt(pos + 1) === "*")) {
|
|
inComment = true;
|
|
pos += 2;
|
|
continue;
|
|
}
|
|
|
|
component = component + chrctr;
|
|
pos += 1;
|
|
}
|
|
}
|
|
|
|
function isValidNonNegativeSourceSizeValue(s) {
|
|
if (regexCssLengthWithUnits.test(s) && (parseFloat(s) >= 0)) {
|
|
return true;
|
|
}
|
|
if (regexCssCalc.test(s)) {
|
|
return true;
|
|
}
|
|
// ( http://www.w3.org/TR/CSS2/syndata.html#numbers says:
|
|
// "-0 is equivalent to 0 and is not a negative number." which means that
|
|
// unitless zero and unitless negative zero must be accepted as special cases.)
|
|
if ((s === "0") || (s === "-0") || (s === "+0")) {
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
// When asked to parse a sizes attribute from an element, parse a
|
|
// comma-separated list of component values from the value of the element's
|
|
// sizes attribute (or the empty string, if the attribute is absent), and let
|
|
// unparsed sizes list be the result.
|
|
// http://dev.w3.org/csswg/css-syntax/#parse-comma-separated-list-of-component-values
|
|
|
|
unparsedSizesList = parseComponentValues(strValue);
|
|
unparsedSizesListLength = unparsedSizesList.length;
|
|
|
|
// For each unparsed size in unparsed sizes list:
|
|
for (i = 0; i < unparsedSizesListLength; i++) {
|
|
unparsedSize = unparsedSizesList[i];
|
|
|
|
// 1. Remove all consecutive <whitespace-token>s from the end of unparsed size.
|
|
// ( parseComponentValues() already omits spaces outside of parens. )
|
|
|
|
// If unparsed size is now empty, that is a parse error; continue to the next
|
|
// iteration of this algorithm.
|
|
// ( parseComponentValues() won't push an empty array. )
|
|
|
|
// 2. If the last component value in unparsed size is a valid non-negative
|
|
// <source-size-value>, let size be its value and remove the component value
|
|
// from unparsed size. Any CSS function other than the calc() function is
|
|
// invalid. Otherwise, there is a parse error; continue to the next iteration
|
|
// of this algorithm.
|
|
// http://dev.w3.org/csswg/css-syntax/#parse-component-value
|
|
lastComponentValue = unparsedSize[unparsedSize.length - 1];
|
|
|
|
if (isValidNonNegativeSourceSizeValue(lastComponentValue)) {
|
|
size = lastComponentValue;
|
|
unparsedSize.pop();
|
|
} else {
|
|
continue;
|
|
}
|
|
|
|
// 3. Remove all consecutive <whitespace-token>s from the end of unparsed
|
|
// size. If unparsed size is now empty, return size and exit this algorithm.
|
|
// If this was not the last item in unparsed sizes list, that is a parse error.
|
|
if (unparsedSize.length === 0) {
|
|
return size;
|
|
}
|
|
|
|
// 4. Parse the remaining component values in unparsed size as a
|
|
// <media-condition>. If it does not parse correctly, or it does parse
|
|
// correctly but the <media-condition> evaluates to false, continue to the
|
|
// next iteration of this algorithm.
|
|
// (Parsing all possible compound media conditions in JS is heavy, complicated,
|
|
// and the payoff is unclear. Is there ever an situation where the
|
|
// media condition parses incorrectly but still somehow evaluates to true?
|
|
// Can we just rely on the browser/polyfill to do it?)
|
|
unparsedSize = unparsedSize.join(" ");
|
|
if (!(pf.matchesMedia(unparsedSize) )) {
|
|
continue;
|
|
}
|
|
|
|
// 5. Return size and exit this algorithm.
|
|
return size;
|
|
}
|
|
|
|
// If the above algorithm exhausts unparsed sizes list without returning a
|
|
// size value, return 100vw.
|
|
return "100vw";
|
|
}
|
|
|
|
// namespace
|
|
pf.ns = ("pf" + new Date().getTime()).substr(0, 9);
|
|
|
|
// srcset support test
|
|
pf.supSrcset = "srcset" in image;
|
|
pf.supSizes = "sizes" in image;
|
|
pf.supPicture = !!window.HTMLPictureElement;
|
|
|
|
// UC browser does claim to support srcset and picture, but not sizes,
|
|
// this extended test reveals the browser does support nothing
|
|
if (pf.supSrcset && pf.supPicture && !pf.supSizes) {
|
|
(function (image2) {
|
|
image.srcset = "data:,a";
|
|
image2.src = "data:,a";
|
|
pf.supSrcset = image.complete === image2.complete;
|
|
pf.supPicture = pf.supSrcset && pf.supPicture;
|
|
})(document.createElement("img"));
|
|
}
|
|
|
|
// Safari9 has basic support for sizes, but does't expose the `sizes` idl attribute
|
|
if (pf.supSrcset && !pf.supSizes) {
|
|
|
|
(function () {
|
|
var width2 = "data:image/gif;base64,R0lGODlhAgABAPAAAP///wAAACH5BAAAAAAALAAAAAACAAEAAAICBAoAOw==";
|
|
var width1 = "data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==";
|
|
var img = document.createElement("img");
|
|
var test = function () {
|
|
var width = img.width;
|
|
|
|
if (width === 2) {
|
|
pf.supSizes = true;
|
|
}
|
|
|
|
alwaysCheckWDescriptor = pf.supSrcset && !pf.supSizes;
|
|
|
|
isSupportTestReady = true;
|
|
// force async
|
|
setTimeout(picturefill);
|
|
};
|
|
|
|
img.onload = test;
|
|
img.onerror = test;
|
|
img.setAttribute("sizes", "9px");
|
|
|
|
img.srcset = width1 + " 1w," + width2 + " 9w";
|
|
img.src = width1;
|
|
})();
|
|
|
|
} else {
|
|
isSupportTestReady = true;
|
|
}
|
|
|
|
// using pf.qsa instead of dom traversing does scale much better,
|
|
// especially on sites mixing responsive and non-responsive images
|
|
pf.selShort = "picture>img,img[srcset]";
|
|
pf.sel = pf.selShort;
|
|
pf.cfg = cfg;
|
|
|
|
/**
|
|
* Shortcut property for `devicePixelRatio` ( for easy overriding in tests )
|
|
*/
|
|
pf.DPR = (DPR || 1 );
|
|
pf.u = units;
|
|
|
|
// container of supported mime types that one might need to qualify before using
|
|
pf.types = types;
|
|
|
|
pf.setSize = noop;
|
|
|
|
/**
|
|
* Gets a string and returns the absolute URL
|
|
* @param src
|
|
* @returns {String} absolute URL
|
|
*/
|
|
|
|
pf.makeUrl = memoize(function (src) {
|
|
anchor.href = src;
|
|
return anchor.href;
|
|
});
|
|
|
|
/**
|
|
* Gets a DOM element or document and a selctor and returns the found matches
|
|
* Can be extended with jQuery/Sizzle for IE7 support
|
|
* @param context
|
|
* @param sel
|
|
* @returns {NodeList|Array}
|
|
*/
|
|
pf.qsa = function (context, sel) {
|
|
return ( "querySelector" in context ) ? context.querySelectorAll(sel) : [];
|
|
};
|
|
|
|
/**
|
|
* Shortcut method for matchMedia ( for easy overriding in tests )
|
|
* wether native or pf.mMQ is used will be decided lazy on first call
|
|
* @returns {boolean}
|
|
*/
|
|
pf.matchesMedia = function () {
|
|
if (window.matchMedia && (matchMedia("(min-width: 0.1em)") || {}).matches) {
|
|
pf.matchesMedia = function (media) {
|
|
return !media || ( matchMedia(media).matches );
|
|
};
|
|
} else {
|
|
pf.matchesMedia = pf.mMQ;
|
|
}
|
|
|
|
return pf.matchesMedia.apply(this, arguments);
|
|
};
|
|
|
|
/**
|
|
* A simplified matchMedia implementation for IE8 and IE9
|
|
* handles only min-width/max-width with px or em values
|
|
* @param media
|
|
* @returns {boolean}
|
|
*/
|
|
pf.mMQ = function (media) {
|
|
return media ? evalCSS(media) : true;
|
|
};
|
|
|
|
/**
|
|
* Returns the calculated length in css pixel from the given sourceSizeValue
|
|
* http://dev.w3.org/csswg/css-values-3/#length-value
|
|
* intended Spec mismatches:
|
|
* * Does not check for invalid use of CSS functions
|
|
* * Does handle a computed length of 0 the same as a negative and therefore invalid value
|
|
* @param sourceSizeValue
|
|
* @returns {Number}
|
|
*/
|
|
pf.calcLength = function (sourceSizeValue) {
|
|
|
|
var value = evalCSS(sourceSizeValue, true) || false;
|
|
if (value < 0) {
|
|
value = false;
|
|
}
|
|
|
|
return value;
|
|
};
|
|
|
|
/**
|
|
* Takes a type string and checks if its supported
|
|
*/
|
|
|
|
pf.supportsType = function (type) {
|
|
return ( type ) ? types[type] : true;
|
|
};
|
|
|
|
/**
|
|
* Parses a sourceSize into mediaCondition (media) and sourceSizeValue (length)
|
|
* @param sourceSizeStr
|
|
* @returns {*}
|
|
*/
|
|
pf.parseSize = memoize(function (sourceSizeStr) {
|
|
var match = ( sourceSizeStr || "" ).match(regSize);
|
|
return {
|
|
media: match && match[1],
|
|
length: match && match[2]
|
|
};
|
|
});
|
|
|
|
pf.parseSet = function (set) {
|
|
if (!set.cands) {
|
|
set.cands = parseSrcset(set.srcset, set);
|
|
}
|
|
return set.cands;
|
|
};
|
|
|
|
/**
|
|
* returns 1em in css px for html/body default size
|
|
* function taken from respondjs
|
|
* @returns {*|number}
|
|
*/
|
|
pf.getEmValue = function () {
|
|
var body;
|
|
if (!eminpx && (body = document.body)) {
|
|
var div = document.createElement("div"),
|
|
originalHTMLCSS = docElem.style.cssText,
|
|
originalBodyCSS = body.style.cssText;
|
|
|
|
div.style.cssText = baseStyle;
|
|
|
|
// 1em in a media query is the value of the default font size of the browser
|
|
// reset docElem and body to ensure the correct value is returned
|
|
docElem.style.cssText = fsCss;
|
|
body.style.cssText = fsCss;
|
|
|
|
body.appendChild(div);
|
|
eminpx = div.offsetWidth;
|
|
body.removeChild(div);
|
|
|
|
//also update eminpx before returning
|
|
eminpx = parseFloat(eminpx, 10);
|
|
|
|
// restore the original values
|
|
docElem.style.cssText = originalHTMLCSS;
|
|
body.style.cssText = originalBodyCSS;
|
|
|
|
}
|
|
return eminpx || 16;
|
|
};
|
|
|
|
/**
|
|
* Takes a string of sizes and returns the width in pixels as a number
|
|
*/
|
|
pf.calcListLength = function (sourceSizeListStr) {
|
|
// Split up source size list, ie ( max-width: 30em ) 100%, ( max-width: 50em ) 50%, 33%
|
|
//
|
|
// or (min-width:30em) calc(30% - 15px)
|
|
if (!(sourceSizeListStr in sizeLengthCache) || cfg.uT) {
|
|
var winningLength = pf.calcLength(parseSizes(sourceSizeListStr));
|
|
|
|
sizeLengthCache[sourceSizeListStr] = !winningLength ? units.width : winningLength;
|
|
}
|
|
|
|
return sizeLengthCache[sourceSizeListStr];
|
|
};
|
|
|
|
/**
|
|
* Takes a candidate object with a srcset property in the form of url/
|
|
* ex. "images/pic-medium.png 1x, images/pic-medium-2x.png 2x" or
|
|
* "images/pic-medium.png 400w, images/pic-medium-2x.png 800w" or
|
|
* "images/pic-small.png"
|
|
* Get an array of image candidates in the form of
|
|
* {url: "/foo/bar.png", resolution: 1}
|
|
* where resolution is http://dev.w3.org/csswg/css-values-3/#resolution-value
|
|
* If sizes is specified, res is calculated
|
|
*/
|
|
pf.setRes = function (set) {
|
|
var candidates;
|
|
if (set) {
|
|
|
|
candidates = pf.parseSet(set);
|
|
|
|
for (var i = 0, len = candidates.length; i < len; i++) {
|
|
setResolution(candidates[i], set.sizes);
|
|
}
|
|
}
|
|
return candidates;
|
|
};
|
|
|
|
pf.setRes.res = setResolution;
|
|
|
|
pf.applySetCandidate = function (candidates, img) {
|
|
if (!candidates.length) {
|
|
return;
|
|
}
|
|
var candidate,
|
|
i,
|
|
j,
|
|
length,
|
|
bestCandidate,
|
|
curSrc,
|
|
curCan,
|
|
candidateSrc,
|
|
abortCurSrc;
|
|
|
|
var imageData = img[pf.ns];
|
|
var dpr = pf.DPR;
|
|
|
|
curSrc = imageData.curSrc || img[curSrcProp];
|
|
|
|
curCan = imageData.curCan || setSrcToCur(img, curSrc, candidates[0].set);
|
|
|
|
// if we have a current source, we might either become lazy or give this source some advantage
|
|
if (curCan && curCan.set === candidates[0].set) {
|
|
|
|
// if browser can abort image request and the image has a higher pixel density than needed
|
|
// and this image isn't downloaded yet, we skip next part and try to save bandwidth
|
|
abortCurSrc = (supportAbort && !img.complete && curCan.res - 0.1 > dpr);
|
|
|
|
if (!abortCurSrc) {
|
|
curCan.cached = true;
|
|
|
|
// if current candidate is "best", "better" or "okay",
|
|
// set it to bestCandidate
|
|
if (curCan.res >= dpr) {
|
|
bestCandidate = curCan;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!bestCandidate) {
|
|
|
|
candidates.sort(ascendingSort);
|
|
|
|
length = candidates.length;
|
|
bestCandidate = candidates[length - 1];
|
|
|
|
for (i = 0; i < length; i++) {
|
|
candidate = candidates[i];
|
|
if (candidate.res >= dpr) {
|
|
j = i - 1;
|
|
|
|
// we have found the perfect candidate,
|
|
// but let's improve this a little bit with some assumptions ;-)
|
|
if (candidates[j] &&
|
|
(abortCurSrc || curSrc !== pf.makeUrl(candidate.url)) &&
|
|
chooseLowRes(candidates[j].res, candidate.res, dpr, candidates[j].cached)) {
|
|
|
|
bestCandidate = candidates[j];
|
|
|
|
} else {
|
|
bestCandidate = candidate;
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (bestCandidate) {
|
|
|
|
candidateSrc = pf.makeUrl(bestCandidate.url);
|
|
|
|
imageData.curSrc = candidateSrc;
|
|
imageData.curCan = bestCandidate;
|
|
|
|
if (candidateSrc !== curSrc) {
|
|
pf.setSrc(img, bestCandidate);
|
|
}
|
|
pf.setSize(img);
|
|
}
|
|
};
|
|
|
|
pf.setSrc = function (img, bestCandidate) {
|
|
var origWidth;
|
|
img.src = bestCandidate.url;
|
|
|
|
// although this is a specific Safari issue, we don't want to take too much different code paths
|
|
if (bestCandidate.set.type === "image/svg+xml") {
|
|
origWidth = img.style.width;
|
|
img.style.width = (img.offsetWidth + 1) + "px";
|
|
|
|
// next line only should trigger a repaint
|
|
// if... is only done to trick dead code removal
|
|
if (img.offsetWidth + 1) {
|
|
img.style.width = origWidth;
|
|
}
|
|
}
|
|
};
|
|
|
|
pf.getSet = function (img) {
|
|
var i, set, supportsType;
|
|
var match = false;
|
|
var sets = img [pf.ns].sets;
|
|
|
|
for (i = 0; i < sets.length && !match; i++) {
|
|
set = sets[i];
|
|
|
|
if (!set.srcset || !pf.matchesMedia(set.media) || !(supportsType = pf.supportsType(set.type))) {
|
|
continue;
|
|
}
|
|
|
|
if (supportsType === "pending") {
|
|
set = supportsType;
|
|
}
|
|
|
|
match = set;
|
|
break;
|
|
}
|
|
|
|
return match;
|
|
};
|
|
|
|
pf.parseSets = function (element, parent, options) {
|
|
var srcsetAttribute, imageSet, isWDescripor, srcsetParsed;
|
|
|
|
var hasPicture = parent && parent.nodeName.toUpperCase() === "PICTURE";
|
|
var imageData = element[pf.ns];
|
|
|
|
if (imageData.src === undefined || options.src) {
|
|
imageData.src = getImgAttr.call(element, "src");
|
|
if (imageData.src) {
|
|
setImgAttr.call(element, srcAttr, imageData.src);
|
|
} else {
|
|
removeImgAttr.call(element, srcAttr);
|
|
}
|
|
}
|
|
|
|
if (imageData.srcset === undefined || options.srcset || !pf.supSrcset || element.srcset) {
|
|
srcsetAttribute = getImgAttr.call(element, "srcset");
|
|
imageData.srcset = srcsetAttribute;
|
|
srcsetParsed = true;
|
|
}
|
|
|
|
imageData.sets = [];
|
|
|
|
if (hasPicture) {
|
|
imageData.pic = true;
|
|
getAllSourceElements(parent, imageData.sets);
|
|
}
|
|
|
|
if (imageData.srcset) {
|
|
imageSet = {
|
|
srcset: imageData.srcset,
|
|
sizes: getImgAttr.call(element, "sizes")
|
|
};
|
|
|
|
imageData.sets.push(imageSet);
|
|
|
|
isWDescripor = (alwaysCheckWDescriptor || imageData.src) && regWDesc.test(imageData.srcset || "");
|
|
|
|
// add normal src as candidate, if source has no w descriptor
|
|
if (!isWDescripor && imageData.src && !getCandidateForSrc(imageData.src, imageSet) && !imageSet.has1x) {
|
|
imageSet.srcset += ", " + imageData.src;
|
|
imageSet.cands.push({
|
|
url: imageData.src,
|
|
d: 1,
|
|
set: imageSet
|
|
});
|
|
}
|
|
|
|
} else if (imageData.src) {
|
|
imageData.sets.push({
|
|
srcset: imageData.src,
|
|
sizes: null
|
|
});
|
|
}
|
|
|
|
imageData.curCan = null;
|
|
imageData.curSrc = undefined;
|
|
|
|
// if img has picture or the srcset was removed or has a srcset and does not support srcset at all
|
|
// or has a w descriptor (and does not support sizes) set support to false to evaluate
|
|
imageData.supported = !( hasPicture || ( imageSet && !pf.supSrcset ) || (isWDescripor && !pf.supSizes) );
|
|
|
|
if (srcsetParsed && pf.supSrcset && !imageData.supported) {
|
|
if (srcsetAttribute) {
|
|
setImgAttr.call(element, srcsetAttr, srcsetAttribute);
|
|
element.srcset = "";
|
|
} else {
|
|
removeImgAttr.call(element, srcsetAttr);
|
|
}
|
|
}
|
|
|
|
if (imageData.supported && !imageData.srcset && ((!imageData.src && element.src) || element.src !== pf.makeUrl(imageData.src))) {
|
|
if (imageData.src === null) {
|
|
element.removeAttribute("src");
|
|
} else {
|
|
element.src = imageData.src;
|
|
}
|
|
}
|
|
|
|
imageData.parsed = true;
|
|
};
|
|
|
|
pf.fillImg = function (element, options) {
|
|
var imageData;
|
|
var extreme = options.reselect || options.reevaluate;
|
|
|
|
// expando for caching data on the img
|
|
if (!element[pf.ns]) {
|
|
element[pf.ns] = {};
|
|
}
|
|
|
|
imageData = element[pf.ns];
|
|
|
|
// if the element has already been evaluated, skip it
|
|
// unless `options.reevaluate` is set to true ( this, for example,
|
|
// is set to true when running `picturefill` on `resize` ).
|
|
if (!extreme && imageData.evaled === evalId) {
|
|
return;
|
|
}
|
|
|
|
if (!imageData.parsed || options.reevaluate) {
|
|
pf.parseSets(element, element.parentNode, options);
|
|
}
|
|
|
|
if (!imageData.supported) {
|
|
applyBestCandidate(element);
|
|
} else {
|
|
imageData.evaled = evalId;
|
|
}
|
|
};
|
|
|
|
pf.setupRun = function () {
|
|
if (!alreadyRun || isVwDirty || (DPR !== window.devicePixelRatio)) {
|
|
updateMetrics();
|
|
}
|
|
};
|
|
|
|
// If picture is supported, well, that's awesome.
|
|
if (pf.supPicture) {
|
|
picturefill = noop;
|
|
pf.fillImg = noop;
|
|
} else {
|
|
|
|
// Set up picture polyfill by polling the document
|
|
(function () {
|
|
var isDomReady;
|
|
var regReady = window.attachEvent ? /d$|^c/ : /d$|^c|^i/;
|
|
|
|
var run = function () {
|
|
var readyState = document.readyState || "";
|
|
|
|
timerId = setTimeout(run, readyState === "loading" ? 200 : 999);
|
|
if (document.body) {
|
|
pf.fillImgs();
|
|
isDomReady = isDomReady || regReady.test(readyState);
|
|
if (isDomReady) {
|
|
clearTimeout(timerId);
|
|
}
|
|
|
|
}
|
|
};
|
|
|
|
var timerId = setTimeout(run, document.body ? 9 : 99);
|
|
|
|
// Also attach picturefill on resize and readystatechange
|
|
// http://modernjavascript.blogspot.com/2013/08/building-better-debounce.html
|
|
var debounce = function (func, wait) {
|
|
var timeout, timestamp;
|
|
var later = function () {
|
|
var last = (new Date()) - timestamp;
|
|
|
|
if (last < wait) {
|
|
timeout = setTimeout(later, wait - last);
|
|
} else {
|
|
timeout = null;
|
|
func();
|
|
}
|
|
};
|
|
|
|
return function () {
|
|
timestamp = new Date();
|
|
|
|
if (!timeout) {
|
|
timeout = setTimeout(later, wait);
|
|
}
|
|
};
|
|
};
|
|
var lastClientWidth = docElem.clientHeight;
|
|
var onResize = function () {
|
|
isVwDirty = Math.max(window.innerWidth || 0, docElem.clientWidth) !== units.width || docElem.clientHeight !== lastClientWidth;
|
|
lastClientWidth = docElem.clientHeight;
|
|
if (isVwDirty) {
|
|
pf.fillImgs();
|
|
}
|
|
};
|
|
|
|
on(window, "resize", debounce(onResize, 99));
|
|
on(document, "readystatechange", run);
|
|
})();
|
|
}
|
|
|
|
pf.picturefill = picturefill;
|
|
//use this internally for easy monkey patching/performance testing
|
|
pf.fillImgs = picturefill;
|
|
pf.teardownRun = noop;
|
|
|
|
/* expose methods for testing */
|
|
picturefill._ = pf;
|
|
|
|
window.picturefillCFG = {
|
|
pf: pf,
|
|
push: function (args) {
|
|
var name = args.shift();
|
|
if (typeof pf[name] === "function") {
|
|
pf[name].apply(pf, args);
|
|
} else {
|
|
cfg[name] = args[0];
|
|
if (alreadyRun) {
|
|
pf.fillImgs({reselect: true});
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
while (setOptions && setOptions.length) {
|
|
window.picturefillCFG.push(setOptions.shift());
|
|
}
|
|
|
|
/* expose picturefill */
|
|
window.picturefill = picturefill;
|
|
|
|
/* expose picturefill */
|
|
if (typeof module === "object" && typeof module.exports === "object") {
|
|
// CommonJS, just export
|
|
module.exports = picturefill;
|
|
} else if (typeof define === "function" && define.amd) {
|
|
// AMD support
|
|
define("picturefill", function () {
|
|
return picturefill;
|
|
});
|
|
}
|
|
|
|
// IE8 evals this sync, so it must be the last thing we do
|
|
if (!pf.supPicture) {
|
|
types["image/webp"] = detectTypeSupport("image/webp", "data:image/webp;base64,UklGRkoAAABXRUJQVlA4WAoAAAAQAAAAAAAAAAAAQUxQSAwAAAABBxAR/Q9ERP8DAABWUDggGAAAADABAJ0BKgEAAQADADQlpAADcAD++/1QAA==");
|
|
}
|
|
|
|
})(window, document);
|
|
|
|
/*! jQuery v2.2.4 | (c) jQuery Foundation | jquery.org/license */
|
|
!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){var c=[],d=a.document,e=c.slice,f=c.concat,g=c.push,h=c.indexOf,i={},j=i.toString,k=i.hasOwnProperty,l={},m="2.2.4",n=function(a,b){return new n.fn.init(a,b)},o=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,p=/^-ms-/,q=/-([\da-z])/gi,r=function(a,b){return b.toUpperCase()};n.fn=n.prototype={jquery:m,constructor:n,selector:"",length:0,toArray:function(){return e.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:e.call(this)},pushStack:function(a){var b=n.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a){return n.each(this,a)},map:function(a){return this.pushStack(n.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(e.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor()},push:g,sort:c.sort,splice:c.splice},n.extend=n.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||n.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(a=arguments[h]))for(b in a)c=g[b],d=a[b],g!==d&&(j&&d&&(n.isPlainObject(d)||(e=n.isArray(d)))?(e?(e=!1,f=c&&n.isArray(c)?c:[]):f=c&&n.isPlainObject(c)?c:{},g[b]=n.extend(j,f,d)):void 0!==d&&(g[b]=d));return g},n.extend({expando:"jQuery"+(m+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===n.type(a)},isArray:Array.isArray,isWindow:function(a){return null!=a&&a===a.window},isNumeric:function(a){var b=a&&a.toString();return!n.isArray(a)&&b-parseFloat(b)+1>=0},isPlainObject:function(a){var b;if("object"!==n.type(a)||a.nodeType||n.isWindow(a))return!1;if(a.constructor&&!k.call(a,"constructor")&&!k.call(a.constructor.prototype||{},"isPrototypeOf"))return!1;for(b in a);return void 0===b||k.call(a,b)},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?i[j.call(a)]||"object":typeof a},globalEval:function(a){var b,c=eval;a=n.trim(a),a&&(1===a.indexOf("use strict")?(b=d.createElement("script"),b.text=a,d.head.appendChild(b).parentNode.removeChild(b)):c(a))},camelCase:function(a){return a.replace(p,"ms-").replace(q,r)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b){var c,d=0;if(s(a)){for(c=a.length;c>d;d++)if(b.call(a[d],d,a[d])===!1)break}else for(d in a)if(b.call(a[d],d,a[d])===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(o,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(s(Object(a))?n.merge(c,"string"==typeof a?[a]:a):g.call(c,a)),c},inArray:function(a,b,c){return null==b?-1:h.call(b,a,c)},merge:function(a,b){for(var c=+b.length,d=0,e=a.length;c>d;d++)a[e++]=b[d];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;g>f;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,e,g=0,h=[];if(s(a))for(d=a.length;d>g;g++)e=b(a[g],g,c),null!=e&&h.push(e);else for(g in a)e=b(a[g],g,c),null!=e&&h.push(e);return f.apply([],h)},guid:1,proxy:function(a,b){var c,d,f;return"string"==typeof b&&(c=a[b],b=a,a=c),n.isFunction(a)?(d=e.call(arguments,2),f=function(){return a.apply(b||this,d.concat(e.call(arguments)))},f.guid=a.guid=a.guid||n.guid++,f):void 0},now:Date.now,support:l}),"function"==typeof Symbol&&(n.fn[Symbol.iterator]=c[Symbol.iterator]),n.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(a,b){i["[object "+b+"]"]=b.toLowerCase()});function s(a){var b=!!a&&"length"in a&&a.length,c=n.type(a);return"function"===c||n.isWindow(a)?!1:"array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a}var t=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+1*new Date,v=a.document,w=0,x=0,y=ga(),z=ga(),A=ga(),B=function(a,b){return a===b&&(l=!0),0},C=1<<31,D={}.hasOwnProperty,E=[],F=E.pop,G=E.push,H=E.push,I=E.slice,J=function(a,b){for(var c=0,d=a.length;d>c;c++)if(a[c]===b)return c;return-1},K="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",L="[\\x20\\t\\r\\n\\f]",M="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",N="\\["+L+"*("+M+")(?:"+L+"*([*^$|!~]?=)"+L+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+M+"))|)"+L+"*\\]",O=":("+M+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+N+")*)|.*)\\)|)",P=new RegExp(L+"+","g"),Q=new RegExp("^"+L+"+|((?:^|[^\\\\])(?:\\\\.)*)"+L+"+$","g"),R=new RegExp("^"+L+"*,"+L+"*"),S=new RegExp("^"+L+"*([>+~]|"+L+")"+L+"*"),T=new RegExp("="+L+"*([^\\]'\"]*?)"+L+"*\\]","g"),U=new RegExp(O),V=new RegExp("^"+M+"$"),W={ID:new RegExp("^#("+M+")"),CLASS:new RegExp("^\\.("+M+")"),TAG:new RegExp("^("+M+"|[*])"),ATTR:new RegExp("^"+N),PSEUDO:new RegExp("^"+O),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+L+"*(even|odd|(([+-]|)(\\d*)n|)"+L+"*(?:([+-]|)"+L+"*(\\d+)|))"+L+"*\\)|)","i"),bool:new RegExp("^(?:"+K+")$","i"),needsContext:new RegExp("^"+L+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+L+"*((?:-\\d)?\\d*)"+L+"*\\)|)(?=[^-]|$)","i")},X=/^(?:input|select|textarea|button)$/i,Y=/^h\d$/i,Z=/^[^{]+\{\s*\[native \w/,$=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,_=/[+~]/,aa=/'|\\/g,ba=new RegExp("\\\\([\\da-f]{1,6}"+L+"?|("+L+")|.)","ig"),ca=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)},da=function(){m()};try{H.apply(E=I.call(v.childNodes),v.childNodes),E[v.childNodes.length].nodeType}catch(ea){H={apply:E.length?function(a,b){G.apply(a,I.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function fa(a,b,d,e){var f,h,j,k,l,o,r,s,w=b&&b.ownerDocument,x=b?b.nodeType:9;if(d=d||[],"string"!=typeof a||!a||1!==x&&9!==x&&11!==x)return d;if(!e&&((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,p)){if(11!==x&&(o=$.exec(a)))if(f=o[1]){if(9===x){if(!(j=b.getElementById(f)))return d;if(j.id===f)return d.push(j),d}else if(w&&(j=w.getElementById(f))&&t(b,j)&&j.id===f)return d.push(j),d}else{if(o[2])return H.apply(d,b.getElementsByTagName(a)),d;if((f=o[3])&&c.getElementsByClassName&&b.getElementsByClassName)return H.apply(d,b.getElementsByClassName(f)),d}if(c.qsa&&!A[a+" "]&&(!q||!q.test(a))){if(1!==x)w=b,s=a;else if("object"!==b.nodeName.toLowerCase()){(k=b.getAttribute("id"))?k=k.replace(aa,"\\$&"):b.setAttribute("id",k=u),r=g(a),h=r.length,l=V.test(k)?"#"+k:"[id='"+k+"']";while(h--)r[h]=l+" "+qa(r[h]);s=r.join(","),w=_.test(a)&&oa(b.parentNode)||b}if(s)try{return H.apply(d,w.querySelectorAll(s)),d}catch(y){}finally{k===u&&b.removeAttribute("id")}}}return i(a.replace(Q,"$1"),b,d,e)}function ga(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function ha(a){return a[u]=!0,a}function ia(a){var b=n.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function ja(a,b){var c=a.split("|"),e=c.length;while(e--)d.attrHandle[c[e]]=b}function ka(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||C)-(~a.sourceIndex||C);if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function la(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function ma(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function na(a){return ha(function(b){return b=+b,ha(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function oa(a){return a&&"undefined"!=typeof a.getElementsByTagName&&a}c=fa.support={},f=fa.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?"HTML"!==b.nodeName:!1},m=fa.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=n.documentElement,p=!f(n),(e=n.defaultView)&&e.top!==e&&(e.addEventListener?e.addEventListener("unload",da,!1):e.attachEvent&&e.attachEvent("onunload",da)),c.attributes=ia(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ia(function(a){return a.appendChild(n.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=Z.test(n.getElementsByClassName),c.getById=ia(function(a){return o.appendChild(a).id=u,!n.getElementsByName||!n.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c?[c]:[]}},d.filter.ID=function(a){var b=a.replace(ba,ca);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(ba,ca);return function(a){var c="undefined"!=typeof a.getAttributeNode&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return"undefined"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return"undefined"!=typeof b.getElementsByClassName&&p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=Z.test(n.querySelectorAll))&&(ia(function(a){o.appendChild(a).innerHTML="<a id='"+u+"'></a><select id='"+u+"-\r\\' msallowcapture=''><option selected=''></option></select>",a.querySelectorAll("[msallowcapture^='']").length&&q.push("[*^$]="+L+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+L+"*(?:value|"+K+")"),a.querySelectorAll("[id~="+u+"-]").length||q.push("~="),a.querySelectorAll(":checked").length||q.push(":checked"),a.querySelectorAll("a#"+u+"+*").length||q.push(".#.+[+~]")}),ia(function(a){var b=n.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+L+"*[*^$|!~]?="),a.querySelectorAll(":enabled").length||q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=Z.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ia(function(a){c.disconnectedMatch=s.call(a,"div"),s.call(a,"[s!='']:x"),r.push("!=",O)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=Z.test(o.compareDocumentPosition),t=b||Z.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===n||a.ownerDocument===v&&t(v,a)?-1:b===n||b.ownerDocument===v&&t(v,b)?1:k?J(k,a)-J(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,g=[a],h=[b];if(!e||!f)return a===n?-1:b===n?1:e?-1:f?1:k?J(k,a)-J(k,b):0;if(e===f)return ka(a,b);c=a;while(c=c.parentNode)g.unshift(c);c=b;while(c=c.parentNode)h.unshift(c);while(g[d]===h[d])d++;return d?ka(g[d],h[d]):g[d]===v?-1:h[d]===v?1:0},n):n},fa.matches=function(a,b){return fa(a,null,null,b)},fa.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(T,"='$1']"),c.matchesSelector&&p&&!A[b+" "]&&(!r||!r.test(b))&&(!q||!q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return fa(b,n,null,[a]).length>0},fa.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},fa.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&D.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},fa.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},fa.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=fa.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=fa.selectors={cacheLength:50,createPseudo:ha,match:W,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(ba,ca),a[3]=(a[3]||a[4]||a[5]||"").replace(ba,ca),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||fa.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&fa.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return W.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&U.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(ba,ca).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+L+")"+a+"("+L+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||"undefined"!=typeof a.getAttribute&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=fa.attr(d,a);return null==e?"!="===b:b?(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e.replace(P," ")+" ").indexOf(c)>-1:"|="===b?e===c||e.slice(0,c.length+1)===c+"-":!1):!0}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h,t=!1;if(q){if(f){while(p){m=b;while(m=m[p])if(h?m.nodeName.toLowerCase()===r:1===m.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){m=q,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n&&j[2],m=n&&q.childNodes[n];while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if(1===m.nodeType&&++t&&m===b){k[a]=[w,n,t];break}}else if(s&&(m=b,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n),t===!1)while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if((h?m.nodeName.toLowerCase()===r:1===m.nodeType)&&++t&&(s&&(l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),k[a]=[w,t]),m===b))break;return t-=e,t===d||t%d===0&&t/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||fa.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ha(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=J(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ha(function(a){var b=[],c=[],d=h(a.replace(Q,"$1"));return d[u]?ha(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),b[0]=null,!c.pop()}}),has:ha(function(a){return function(b){return fa(a,b).length>0}}),contains:ha(function(a){return a=a.replace(ba,ca),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ha(function(a){return V.test(a||"")||fa.error("unsupported lang: "+a),a=a.replace(ba,ca).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return Y.test(a.nodeName)},input:function(a){return X.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:na(function(){return[0]}),last:na(function(a,b){return[b-1]}),eq:na(function(a,b,c){return[0>c?c+b:c]}),even:na(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:na(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:na(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:na(function(a,b,c){for(var d=0>c?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=la(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=ma(b);function pa(){}pa.prototype=d.filters=d.pseudos,d.setFilters=new pa,g=fa.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);h=a,i=[],j=d.preFilter;while(h){c&&!(e=R.exec(h))||(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=S.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(Q," ")}),h=h.slice(c.length));for(g in d.filter)!(e=W[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?fa.error(a):z(a,i).slice(0)};function qa(a){for(var b=0,c=a.length,d="";c>b;b++)d+=a[b].value;return d}function ra(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=x++;return b.first?function(b,c,f){while(b=b[d])if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j,k=[w,f];if(g){while(b=b[d])if((1===b.nodeType||e)&&a(b,c,g))return!0}else while(b=b[d])if(1===b.nodeType||e){if(j=b[u]||(b[u]={}),i=j[b.uniqueID]||(j[b.uniqueID]={}),(h=i[d])&&h[0]===w&&h[1]===f)return k[2]=h[2];if(i[d]=k,k[2]=a(b,c,g))return!0}}}function sa(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function ta(a,b,c){for(var d=0,e=b.length;e>d;d++)fa(a,b[d],c);return c}function ua(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(c&&!c(f,d,e)||(g.push(f),j&&b.push(h)));return g}function va(a,b,c,d,e,f){return d&&!d[u]&&(d=va(d)),e&&!e[u]&&(e=va(e,f)),ha(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||ta(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:ua(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=ua(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?J(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=ua(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):H.apply(g,r)})}function wa(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=ra(function(a){return a===b},h,!0),l=ra(function(a){return J(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];f>i;i++)if(c=d.relative[a[i].type])m=[ra(sa(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e;e++)if(d.relative[a[e].type])break;return va(i>1&&sa(m),i>1&&qa(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(Q,"$1"),c,e>i&&wa(a.slice(i,e)),f>e&&wa(a=a.slice(e)),f>e&&qa(a))}m.push(c)}return sa(m)}function xa(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,o,q,r=0,s="0",t=f&&[],u=[],v=j,x=f||e&&d.find.TAG("*",k),y=w+=null==v?1:Math.random()||.1,z=x.length;for(k&&(j=g===n||g||k);s!==z&&null!=(l=x[s]);s++){if(e&&l){o=0,g||l.ownerDocument===n||(m(l),h=!p);while(q=a[o++])if(q(l,g||n,h)){i.push(l);break}k&&(w=y)}c&&((l=!q&&l)&&r--,f&&t.push(l))}if(r+=s,c&&s!==r){o=0;while(q=b[o++])q(t,u,g,h);if(f){if(r>0)while(s--)t[s]||u[s]||(u[s]=F.call(i));u=ua(u)}H.apply(i,u),k&&!f&&u.length>0&&r+b.length>1&&fa.uniqueSort(i)}return k&&(w=y,j=v),t};return c?ha(f):f}return h=fa.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=wa(b[c]),f[u]?d.push(f):e.push(f);f=A(a,xa(e,d)),f.selector=a}return f},i=fa.select=function(a,b,e,f){var i,j,k,l,m,n="function"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&"ID"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(b=(d.find.ID(k.matches[0].replace(ba,ca),b)||[])[0],!b)return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}i=W.needsContext.test(a)?0:j.length;while(i--){if(k=j[i],d.relative[l=k.type])break;if((m=d.find[l])&&(f=m(k.matches[0].replace(ba,ca),_.test(j[0].type)&&oa(b.parentNode)||b))){if(j.splice(i,1),a=f.length&&qa(j),!a)return H.apply(e,f),e;break}}}return(n||h(a,o))(f,b,!p,e,!b||_.test(a)&&oa(b.parentNode)||b),e},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ia(function(a){return 1&a.compareDocumentPosition(n.createElement("div"))}),ia(function(a){return a.innerHTML="<a href='#'></a>","#"===a.firstChild.getAttribute("href")})||ja("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ia(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||ja("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),ia(function(a){return null==a.getAttribute("disabled")})||ja(K,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),fa}(a);n.find=t,n.expr=t.selectors,n.expr[":"]=n.expr.pseudos,n.uniqueSort=n.unique=t.uniqueSort,n.text=t.getText,n.isXMLDoc=t.isXML,n.contains=t.contains;var u=function(a,b,c){var d=[],e=void 0!==c;while((a=a[b])&&9!==a.nodeType)if(1===a.nodeType){if(e&&n(a).is(c))break;d.push(a)}return d},v=function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c},w=n.expr.match.needsContext,x=/^<([\w-]+)\s*\/?>(?:<\/\1>|)$/,y=/^.[^:#\[\.,]*$/;function z(a,b,c){if(n.isFunction(b))return n.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return n.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(y.test(b))return n.filter(b,a,c);b=n.filter(b,a)}return n.grep(a,function(a){return h.call(b,a)>-1!==c})}n.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?n.find.matchesSelector(d,a)?[d]:[]:n.find.matches(a,n.grep(b,function(a){return 1===a.nodeType}))},n.fn.extend({find:function(a){var b,c=this.length,d=[],e=this;if("string"!=typeof a)return this.pushStack(n(a).filter(function(){for(b=0;c>b;b++)if(n.contains(e[b],this))return!0}));for(b=0;c>b;b++)n.find(a,e[b],d);return d=this.pushStack(c>1?n.unique(d):d),d.selector=this.selector?this.selector+" "+a:a,d},filter:function(a){return this.pushStack(z(this,a||[],!1))},not:function(a){return this.pushStack(z(this,a||[],!0))},is:function(a){return!!z(this,"string"==typeof a&&w.test(a)?n(a):a||[],!1).length}});var A,B=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,C=n.fn.init=function(a,b,c){var e,f;if(!a)return this;if(c=c||A,"string"==typeof a){if(e="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:B.exec(a),!e||!e[1]&&b)return!b||b.jquery?(b||c).find(a):this.constructor(b).find(a);if(e[1]){if(b=b instanceof n?b[0]:b,n.merge(this,n.parseHTML(e[1],b&&b.nodeType?b.ownerDocument||b:d,!0)),x.test(e[1])&&n.isPlainObject(b))for(e in b)n.isFunction(this[e])?this[e](b[e]):this.attr(e,b[e]);return this}return f=d.getElementById(e[2]),f&&f.parentNode&&(this.length=1,this[0]=f),this.context=d,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):n.isFunction(a)?void 0!==c.ready?c.ready(a):a(n):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),n.makeArray(a,this))};C.prototype=n.fn,A=n(d);var D=/^(?:parents|prev(?:Until|All))/,E={children:!0,contents:!0,next:!0,prev:!0};n.fn.extend({has:function(a){var b=n(a,this),c=b.length;return this.filter(function(){for(var a=0;c>a;a++)if(n.contains(this,b[a]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=w.test(a)||"string"!=typeof a?n(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&n.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?n.uniqueSort(f):f)},index:function(a){return a?"string"==typeof a?h.call(n(a),this[0]):h.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(n.uniqueSort(n.merge(this.get(),n(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function F(a,b){while((a=a[b])&&1!==a.nodeType);return a}n.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return u(a,"parentNode")},parentsUntil:function(a,b,c){return u(a,"parentNode",c)},next:function(a){return F(a,"nextSibling")},prev:function(a){return F(a,"previousSibling")},nextAll:function(a){return u(a,"nextSibling")},prevAll:function(a){return u(a,"previousSibling")},nextUntil:function(a,b,c){return u(a,"nextSibling",c)},prevUntil:function(a,b,c){return u(a,"previousSibling",c)},siblings:function(a){return v((a.parentNode||{}).firstChild,a)},children:function(a){return v(a.firstChild)},contents:function(a){return a.contentDocument||n.merge([],a.childNodes)}},function(a,b){n.fn[a]=function(c,d){var e=n.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=n.filter(d,e)),this.length>1&&(E[a]||n.uniqueSort(e),D.test(a)&&e.reverse()),this.pushStack(e)}});var G=/\S+/g;function H(a){var b={};return n.each(a.match(G)||[],function(a,c){b[c]=!0}),b}n.Callbacks=function(a){a="string"==typeof a?H(a):n.extend({},a);var b,c,d,e,f=[],g=[],h=-1,i=function(){for(e=a.once,d=b=!0;g.length;h=-1){c=g.shift();while(++h<f.length)f[h].apply(c[0],c[1])===!1&&a.stopOnFalse&&(h=f.length,c=!1)}a.memory||(c=!1),b=!1,e&&(f=c?[]:"")},j={add:function(){return f&&(c&&!b&&(h=f.length-1,g.push(c)),function d(b){n.each(b,function(b,c){n.isFunction(c)?a.unique&&j.has(c)||f.push(c):c&&c.length&&"string"!==n.type(c)&&d(c)})}(arguments),c&&!b&&i()),this},remove:function(){return n.each(arguments,function(a,b){var c;while((c=n.inArray(b,f,c))>-1)f.splice(c,1),h>=c&&h--}),this},has:function(a){return a?n.inArray(a,f)>-1:f.length>0},empty:function(){return f&&(f=[]),this},disable:function(){return e=g=[],f=c="",this},disabled:function(){return!f},lock:function(){return e=g=[],c||(f=c=""),this},locked:function(){return!!e},fireWith:function(a,c){return e||(c=c||[],c=[a,c.slice?c.slice():c],g.push(c),b||i()),this},fire:function(){return j.fireWith(this,arguments),this},fired:function(){return!!d}};return j},n.extend({Deferred:function(a){var b=[["resolve","done",n.Callbacks("once memory"),"resolved"],["reject","fail",n.Callbacks("once memory"),"rejected"],["notify","progress",n.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return n.Deferred(function(c){n.each(b,function(b,f){var g=n.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&n.isFunction(a.promise)?a.promise().progress(c.notify).done(c.resolve).fail(c.reject):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?n.extend(a,d):d}},e={};return d.pipe=d.then,n.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=e.call(arguments),d=c.length,f=1!==d||a&&n.isFunction(a.promise)?d:0,g=1===f?a:n.Deferred(),h=function(a,b,c){return function(d){b[a]=this,c[a]=arguments.length>1?e.call(arguments):d,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}},i,j,k;if(d>1)for(i=new Array(d),j=new Array(d),k=new Array(d);d>b;b++)c[b]&&n.isFunction(c[b].promise)?c[b].promise().progress(h(b,j,i)).done(h(b,k,c)).fail(g.reject):--f;return f||g.resolveWith(k,c),g.promise()}});var I;n.fn.ready=function(a){return n.ready.promise().done(a),this},n.extend({isReady:!1,readyWait:1,holdReady:function(a){a?n.readyWait++:n.ready(!0)},ready:function(a){(a===!0?--n.readyWait:n.isReady)||(n.isReady=!0,a!==!0&&--n.readyWait>0||(I.resolveWith(d,[n]),n.fn.triggerHandler&&(n(d).triggerHandler("ready"),n(d).off("ready"))))}});function J(){d.removeEventListener("DOMContentLoaded",J),a.removeEventListener("load",J),n.ready()}n.ready.promise=function(b){return I||(I=n.Deferred(),"complete"===d.readyState||"loading"!==d.readyState&&!d.documentElement.doScroll?a.setTimeout(n.ready):(d.addEventListener("DOMContentLoaded",J),a.addEventListener("load",J))),I.promise(b)},n.ready.promise();var K=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===n.type(c)){e=!0;for(h in c)K(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,n.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(n(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f},L=function(a){return 1===a.nodeType||9===a.nodeType||!+a.nodeType};function M(){this.expando=n.expando+M.uid++}M.uid=1,M.prototype={register:function(a,b){var c=b||{};return a.nodeType?a[this.expando]=c:Object.defineProperty(a,this.expando,{value:c,writable:!0,configurable:!0}),a[this.expando]},cache:function(a){if(!L(a))return{};var b=a[this.expando];return b||(b={},L(a)&&(a.nodeType?a[this.expando]=b:Object.defineProperty(a,this.expando,{value:b,configurable:!0}))),b},set:function(a,b,c){var d,e=this.cache(a);if("string"==typeof b)e[b]=c;else for(d in b)e[d]=b[d];return e},get:function(a,b){return void 0===b?this.cache(a):a[this.expando]&&a[this.expando][b]},access:function(a,b,c){var d;return void 0===b||b&&"string"==typeof b&&void 0===c?(d=this.get(a,b),void 0!==d?d:this.get(a,n.camelCase(b))):(this.set(a,b,c),void 0!==c?c:b)},remove:function(a,b){var c,d,e,f=a[this.expando];if(void 0!==f){if(void 0===b)this.register(a);else{n.isArray(b)?d=b.concat(b.map(n.camelCase)):(e=n.camelCase(b),b in f?d=[b,e]:(d=e,d=d in f?[d]:d.match(G)||[])),c=d.length;while(c--)delete f[d[c]]}(void 0===b||n.isEmptyObject(f))&&(a.nodeType?a[this.expando]=void 0:delete a[this.expando])}},hasData:function(a){var b=a[this.expando];return void 0!==b&&!n.isEmptyObject(b)}};var N=new M,O=new M,P=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,Q=/[A-Z]/g;function R(a,b,c){var d;if(void 0===c&&1===a.nodeType)if(d="data-"+b.replace(Q,"-$&").toLowerCase(),c=a.getAttribute(d),"string"==typeof c){try{c="true"===c?!0:"false"===c?!1:"null"===c?null:+c+""===c?+c:P.test(c)?n.parseJSON(c):c;
|
|
}catch(e){}O.set(a,b,c)}else c=void 0;return c}n.extend({hasData:function(a){return O.hasData(a)||N.hasData(a)},data:function(a,b,c){return O.access(a,b,c)},removeData:function(a,b){O.remove(a,b)},_data:function(a,b,c){return N.access(a,b,c)},_removeData:function(a,b){N.remove(a,b)}}),n.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=O.get(f),1===f.nodeType&&!N.get(f,"hasDataAttrs"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=n.camelCase(d.slice(5)),R(f,d,e[d])));N.set(f,"hasDataAttrs",!0)}return e}return"object"==typeof a?this.each(function(){O.set(this,a)}):K(this,function(b){var c,d;if(f&&void 0===b){if(c=O.get(f,a)||O.get(f,a.replace(Q,"-$&").toLowerCase()),void 0!==c)return c;if(d=n.camelCase(a),c=O.get(f,d),void 0!==c)return c;if(c=R(f,d,void 0),void 0!==c)return c}else d=n.camelCase(a),this.each(function(){var c=O.get(this,d);O.set(this,d,b),a.indexOf("-")>-1&&void 0!==c&&O.set(this,a,b)})},null,b,arguments.length>1,null,!0)},removeData:function(a){return this.each(function(){O.remove(this,a)})}}),n.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=N.get(a,b),c&&(!d||n.isArray(c)?d=N.access(a,b,n.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=n.queue(a,b),d=c.length,e=c.shift(),f=n._queueHooks(a,b),g=function(){n.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return N.get(a,c)||N.access(a,c,{empty:n.Callbacks("once memory").add(function(){N.remove(a,[b+"queue",c])})})}}),n.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?n.queue(this[0],a):void 0===b?this:this.each(function(){var c=n.queue(this,a,b);n._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&n.dequeue(this,a)})},dequeue:function(a){return this.each(function(){n.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=n.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};"string"!=typeof a&&(b=a,a=void 0),a=a||"fx";while(g--)c=N.get(f[g],a+"queueHooks"),c&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var S=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,T=new RegExp("^(?:([+-])=|)("+S+")([a-z%]*)$","i"),U=["Top","Right","Bottom","Left"],V=function(a,b){return a=b||a,"none"===n.css(a,"display")||!n.contains(a.ownerDocument,a)};function W(a,b,c,d){var e,f=1,g=20,h=d?function(){return d.cur()}:function(){return n.css(a,b,"")},i=h(),j=c&&c[3]||(n.cssNumber[b]?"":"px"),k=(n.cssNumber[b]||"px"!==j&&+i)&&T.exec(n.css(a,b));if(k&&k[3]!==j){j=j||k[3],c=c||[],k=+i||1;do f=f||".5",k/=f,n.style(a,b,k+j);while(f!==(f=h()/i)&&1!==f&&--g)}return c&&(k=+k||+i||0,e=c[1]?k+(c[1]+1)*c[2]:+c[2],d&&(d.unit=j,d.start=k,d.end=e)),e}var X=/^(?:checkbox|radio)$/i,Y=/<([\w:-]+)/,Z=/^$|\/(?:java|ecma)script/i,$={option:[1,"<select multiple='multiple'>","</select>"],thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};$.optgroup=$.option,$.tbody=$.tfoot=$.colgroup=$.caption=$.thead,$.th=$.td;function _(a,b){var c="undefined"!=typeof a.getElementsByTagName?a.getElementsByTagName(b||"*"):"undefined"!=typeof a.querySelectorAll?a.querySelectorAll(b||"*"):[];return void 0===b||b&&n.nodeName(a,b)?n.merge([a],c):c}function aa(a,b){for(var c=0,d=a.length;d>c;c++)N.set(a[c],"globalEval",!b||N.get(b[c],"globalEval"))}var ba=/<|&#?\w+;/;function ca(a,b,c,d,e){for(var f,g,h,i,j,k,l=b.createDocumentFragment(),m=[],o=0,p=a.length;p>o;o++)if(f=a[o],f||0===f)if("object"===n.type(f))n.merge(m,f.nodeType?[f]:f);else if(ba.test(f)){g=g||l.appendChild(b.createElement("div")),h=(Y.exec(f)||["",""])[1].toLowerCase(),i=$[h]||$._default,g.innerHTML=i[1]+n.htmlPrefilter(f)+i[2],k=i[0];while(k--)g=g.lastChild;n.merge(m,g.childNodes),g=l.firstChild,g.textContent=""}else m.push(b.createTextNode(f));l.textContent="",o=0;while(f=m[o++])if(d&&n.inArray(f,d)>-1)e&&e.push(f);else if(j=n.contains(f.ownerDocument,f),g=_(l.appendChild(f),"script"),j&&aa(g),c){k=0;while(f=g[k++])Z.test(f.type||"")&&c.push(f)}return l}!function(){var a=d.createDocumentFragment(),b=a.appendChild(d.createElement("div")),c=d.createElement("input");c.setAttribute("type","radio"),c.setAttribute("checked","checked"),c.setAttribute("name","t"),b.appendChild(c),l.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML="<textarea>x</textarea>",l.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var da=/^key/,ea=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,fa=/^([^.]*)(?:\.(.+)|)/;function ga(){return!0}function ha(){return!1}function ia(){try{return d.activeElement}catch(a){}}function ja(a,b,c,d,e,f){var g,h;if("object"==typeof b){"string"!=typeof c&&(d=d||c,c=void 0);for(h in b)ja(a,h,c,d,b[h],f);return a}if(null==d&&null==e?(e=c,d=c=void 0):null==e&&("string"==typeof c?(e=d,d=void 0):(e=d,d=c,c=void 0)),e===!1)e=ha;else if(!e)return a;return 1===f&&(g=e,e=function(a){return n().off(a),g.apply(this,arguments)},e.guid=g.guid||(g.guid=n.guid++)),a.each(function(){n.event.add(this,b,e,d,c)})}n.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=N.get(a);if(r){c.handler&&(f=c,c=f.handler,e=f.selector),c.guid||(c.guid=n.guid++),(i=r.events)||(i=r.events={}),(g=r.handle)||(g=r.handle=function(b){return"undefined"!=typeof n&&n.event.triggered!==b.type?n.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(G)||[""],j=b.length;while(j--)h=fa.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o&&(l=n.event.special[o]||{},o=(e?l.delegateType:l.bindType)||o,l=n.event.special[o]||{},k=n.extend({type:o,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&n.expr.match.needsContext.test(e),namespace:p.join(".")},f),(m=i[o])||(m=i[o]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,p,g)!==!1||a.addEventListener&&a.addEventListener(o,g)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),n.event.global[o]=!0)}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,o,p,q,r=N.hasData(a)&&N.get(a);if(r&&(i=r.events)){b=(b||"").match(G)||[""],j=b.length;while(j--)if(h=fa.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o){l=n.event.special[o]||{},o=(d?l.delegateType:l.bindType)||o,m=i[o]||[],h=h[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;while(f--)k=m[f],!e&&q!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||n.removeEvent(a,o,r.handle),delete i[o])}else for(o in i)n.event.remove(a,o+b[j],c,d,!0);n.isEmptyObject(i)&&N.remove(a,"handle events")}},dispatch:function(a){a=n.event.fix(a);var b,c,d,f,g,h=[],i=e.call(arguments),j=(N.get(this,"events")||{})[a.type]||[],k=n.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){h=n.event.handlers.call(this,a,j),b=0;while((f=h[b++])&&!a.isPropagationStopped()){a.currentTarget=f.elem,c=0;while((g=f.handlers[c++])&&!a.isImmediatePropagationStopped())a.rnamespace&&!a.rnamespace.test(g.namespace)||(a.handleObj=g,a.data=g.data,d=((n.event.special[g.origType]||{}).handle||g.handler).apply(f.elem,i),void 0!==d&&(a.result=d)===!1&&(a.preventDefault(),a.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&("click"!==a.type||isNaN(a.button)||a.button<1))for(;i!==this;i=i.parentNode||this)if(1===i.nodeType&&(i.disabled!==!0||"click"!==a.type)){for(d=[],c=0;h>c;c++)f=b[c],e=f.selector+" ",void 0===d[e]&&(d[e]=f.needsContext?n(e,this).index(i)>-1:n.find(e,this,null,[i]).length),d[e]&&d.push(f);d.length&&g.push({elem:i,handlers:d})}return h<b.length&&g.push({elem:this,handlers:b.slice(h)}),g},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(a,b){return null==a.which&&(a.which=null!=b.charCode?b.charCode:b.keyCode),a}},mouseHooks:{props:"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(a,b){var c,e,f,g=b.button;return null==a.pageX&&null!=b.clientX&&(c=a.target.ownerDocument||d,e=c.documentElement,f=c.body,a.pageX=b.clientX+(e&&e.scrollLeft||f&&f.scrollLeft||0)-(e&&e.clientLeft||f&&f.clientLeft||0),a.pageY=b.clientY+(e&&e.scrollTop||f&&f.scrollTop||0)-(e&&e.clientTop||f&&f.clientTop||0)),a.which||void 0===g||(a.which=1&g?1:2&g?3:4&g?2:0),a}},fix:function(a){if(a[n.expando])return a;var b,c,e,f=a.type,g=a,h=this.fixHooks[f];h||(this.fixHooks[f]=h=ea.test(f)?this.mouseHooks:da.test(f)?this.keyHooks:{}),e=h.props?this.props.concat(h.props):this.props,a=new n.Event(g),b=e.length;while(b--)c=e[b],a[c]=g[c];return a.target||(a.target=d),3===a.target.nodeType&&(a.target=a.target.parentNode),h.filter?h.filter(a,g):a},special:{load:{noBubble:!0},focus:{trigger:function(){return this!==ia()&&this.focus?(this.focus(),!1):void 0},delegateType:"focusin"},blur:{trigger:function(){return this===ia()&&this.blur?(this.blur(),!1):void 0},delegateType:"focusout"},click:{trigger:function(){return"checkbox"===this.type&&this.click&&n.nodeName(this,"input")?(this.click(),!1):void 0},_default:function(a){return n.nodeName(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}}},n.removeEvent=function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c)},n.Event=function(a,b){return this instanceof n.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?ga:ha):this.type=a,b&&n.extend(this,b),this.timeStamp=a&&a.timeStamp||n.now(),void(this[n.expando]=!0)):new n.Event(a,b)},n.Event.prototype={constructor:n.Event,isDefaultPrevented:ha,isPropagationStopped:ha,isImmediatePropagationStopped:ha,isSimulated:!1,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=ga,a&&!this.isSimulated&&a.preventDefault()},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=ga,a&&!this.isSimulated&&a.stopPropagation()},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=ga,a&&!this.isSimulated&&a.stopImmediatePropagation(),this.stopPropagation()}},n.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){n.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return e&&(e===d||n.contains(d,e))||(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),n.fn.extend({on:function(a,b,c,d){return ja(this,a,b,c,d)},one:function(a,b,c,d){return ja(this,a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,n(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);return this}return b!==!1&&"function"!=typeof b||(c=b,b=void 0),c===!1&&(c=ha),this.each(function(){n.event.remove(this,a,c,b)})}});var ka=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:-]+)[^>]*)\/>/gi,la=/<script|<style|<link/i,ma=/checked\s*(?:[^=]|=\s*.checked.)/i,na=/^true\/(.*)/,oa=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function pa(a,b){return n.nodeName(a,"table")&&n.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function qa(a){return a.type=(null!==a.getAttribute("type"))+"/"+a.type,a}function ra(a){var b=na.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function sa(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(N.hasData(a)&&(f=N.access(a),g=N.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;d>c;c++)n.event.add(b,e,j[e][c])}O.hasData(a)&&(h=O.access(a),i=n.extend({},h),O.set(b,i))}}function ta(a,b){var c=b.nodeName.toLowerCase();"input"===c&&X.test(a.type)?b.checked=a.checked:"input"!==c&&"textarea"!==c||(b.defaultValue=a.defaultValue)}function ua(a,b,c,d){b=f.apply([],b);var e,g,h,i,j,k,m=0,o=a.length,p=o-1,q=b[0],r=n.isFunction(q);if(r||o>1&&"string"==typeof q&&!l.checkClone&&ma.test(q))return a.each(function(e){var f=a.eq(e);r&&(b[0]=q.call(this,e,f.html())),ua(f,b,c,d)});if(o&&(e=ca(b,a[0].ownerDocument,!1,a,d),g=e.firstChild,1===e.childNodes.length&&(e=g),g||d)){for(h=n.map(_(e,"script"),qa),i=h.length;o>m;m++)j=e,m!==p&&(j=n.clone(j,!0,!0),i&&n.merge(h,_(j,"script"))),c.call(a[m],j,m);if(i)for(k=h[h.length-1].ownerDocument,n.map(h,ra),m=0;i>m;m++)j=h[m],Z.test(j.type||"")&&!N.access(j,"globalEval")&&n.contains(k,j)&&(j.src?n._evalUrl&&n._evalUrl(j.src):n.globalEval(j.textContent.replace(oa,"")))}return a}function va(a,b,c){for(var d,e=b?n.filter(b,a):a,f=0;null!=(d=e[f]);f++)c||1!==d.nodeType||n.cleanData(_(d)),d.parentNode&&(c&&n.contains(d.ownerDocument,d)&&aa(_(d,"script")),d.parentNode.removeChild(d));return a}n.extend({htmlPrefilter:function(a){return a.replace(ka,"<$1></$2>")},clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=n.contains(a.ownerDocument,a);if(!(l.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||n.isXMLDoc(a)))for(g=_(h),f=_(a),d=0,e=f.length;e>d;d++)ta(f[d],g[d]);if(b)if(c)for(f=f||_(a),g=g||_(h),d=0,e=f.length;e>d;d++)sa(f[d],g[d]);else sa(a,h);return g=_(h,"script"),g.length>0&&aa(g,!i&&_(a,"script")),h},cleanData:function(a){for(var b,c,d,e=n.event.special,f=0;void 0!==(c=a[f]);f++)if(L(c)){if(b=c[N.expando]){if(b.events)for(d in b.events)e[d]?n.event.remove(c,d):n.removeEvent(c,d,b.handle);c[N.expando]=void 0}c[O.expando]&&(c[O.expando]=void 0)}}}),n.fn.extend({domManip:ua,detach:function(a){return va(this,a,!0)},remove:function(a){return va(this,a)},text:function(a){return K(this,function(a){return void 0===a?n.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=a)})},null,a,arguments.length)},append:function(){return ua(this,arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=pa(this,a);b.appendChild(a)}})},prepend:function(){return ua(this,arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=pa(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return ua(this,arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return ua(this,arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},empty:function(){for(var a,b=0;null!=(a=this[b]);b++)1===a.nodeType&&(n.cleanData(_(a,!1)),a.textContent="");return this},clone:function(a,b){return a=null==a?!1:a,b=null==b?a:b,this.map(function(){return n.clone(this,a,b)})},html:function(a){return K(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if("string"==typeof a&&!la.test(a)&&!$[(Y.exec(a)||["",""])[1].toLowerCase()]){a=n.htmlPrefilter(a);try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(n.cleanData(_(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=[];return ua(this,arguments,function(b){var c=this.parentNode;n.inArray(this,a)<0&&(n.cleanData(_(this)),c&&c.replaceChild(b,this))},a)}}),n.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){n.fn[a]=function(a){for(var c,d=[],e=n(a),f=e.length-1,h=0;f>=h;h++)c=h===f?this:this.clone(!0),n(e[h])[b](c),g.apply(d,c.get());return this.pushStack(d)}});var wa,xa={HTML:"block",BODY:"block"};function ya(a,b){var c=n(b.createElement(a)).appendTo(b.body),d=n.css(c[0],"display");return c.detach(),d}function za(a){var b=d,c=xa[a];return c||(c=ya(a,b),"none"!==c&&c||(wa=(wa||n("<iframe frameborder='0' width='0' height='0'/>")).appendTo(b.documentElement),b=wa[0].contentDocument,b.write(),b.close(),c=ya(a,b),wa.detach()),xa[a]=c),c}var Aa=/^margin/,Ba=new RegExp("^("+S+")(?!px)[a-z%]+$","i"),Ca=function(b){var c=b.ownerDocument.defaultView;return c&&c.opener||(c=a),c.getComputedStyle(b)},Da=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e},Ea=d.documentElement;!function(){var b,c,e,f,g=d.createElement("div"),h=d.createElement("div");if(h.style){h.style.backgroundClip="content-box",h.cloneNode(!0).style.backgroundClip="",l.clearCloneStyle="content-box"===h.style.backgroundClip,g.style.cssText="border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute",g.appendChild(h);function i(){h.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%",h.innerHTML="",Ea.appendChild(g);var d=a.getComputedStyle(h);b="1%"!==d.top,f="2px"===d.marginLeft,c="4px"===d.width,h.style.marginRight="50%",e="4px"===d.marginRight,Ea.removeChild(g)}n.extend(l,{pixelPosition:function(){return i(),b},boxSizingReliable:function(){return null==c&&i(),c},pixelMarginRight:function(){return null==c&&i(),e},reliableMarginLeft:function(){return null==c&&i(),f},reliableMarginRight:function(){var b,c=h.appendChild(d.createElement("div"));return c.style.cssText=h.style.cssText="-webkit-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",c.style.marginRight=c.style.width="0",h.style.width="1px",Ea.appendChild(g),b=!parseFloat(a.getComputedStyle(c).marginRight),Ea.removeChild(g),h.removeChild(c),b}})}}();function Fa(a,b,c){var d,e,f,g,h=a.style;return c=c||Ca(a),g=c?c.getPropertyValue(b)||c[b]:void 0,""!==g&&void 0!==g||n.contains(a.ownerDocument,a)||(g=n.style(a,b)),c&&!l.pixelMarginRight()&&Ba.test(g)&&Aa.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f),void 0!==g?g+"":g}function Ga(a,b){return{get:function(){return a()?void delete this.get:(this.get=b).apply(this,arguments)}}}var Ha=/^(none|table(?!-c[ea]).+)/,Ia={position:"absolute",visibility:"hidden",display:"block"},Ja={letterSpacing:"0",fontWeight:"400"},Ka=["Webkit","O","Moz","ms"],La=d.createElement("div").style;function Ma(a){if(a in La)return a;var b=a[0].toUpperCase()+a.slice(1),c=Ka.length;while(c--)if(a=Ka[c]+b,a in La)return a}function Na(a,b,c){var d=T.exec(b);return d?Math.max(0,d[2]-(c||0))+(d[3]||"px"):b}function Oa(a,b,c,d,e){for(var f=c===(d?"border":"content")?4:"width"===b?1:0,g=0;4>f;f+=2)"margin"===c&&(g+=n.css(a,c+U[f],!0,e)),d?("content"===c&&(g-=n.css(a,"padding"+U[f],!0,e)),"margin"!==c&&(g-=n.css(a,"border"+U[f]+"Width",!0,e))):(g+=n.css(a,"padding"+U[f],!0,e),"padding"!==c&&(g+=n.css(a,"border"+U[f]+"Width",!0,e)));return g}function Pa(a,b,c){var d=!0,e="width"===b?a.offsetWidth:a.offsetHeight,f=Ca(a),g="border-box"===n.css(a,"boxSizing",!1,f);if(0>=e||null==e){if(e=Fa(a,b,f),(0>e||null==e)&&(e=a.style[b]),Ba.test(e))return e;d=g&&(l.boxSizingReliable()||e===a.style[b]),e=parseFloat(e)||0}return e+Oa(a,b,c||(g?"border":"content"),d,f)+"px"}function Qa(a,b){for(var c,d,e,f=[],g=0,h=a.length;h>g;g++)d=a[g],d.style&&(f[g]=N.get(d,"olddisplay"),c=d.style.display,b?(f[g]||"none"!==c||(d.style.display=""),""===d.style.display&&V(d)&&(f[g]=N.access(d,"olddisplay",za(d.nodeName)))):(e=V(d),"none"===c&&e||N.set(d,"olddisplay",e?c:n.css(d,"display"))));for(g=0;h>g;g++)d=a[g],d.style&&(b&&"none"!==d.style.display&&""!==d.style.display||(d.style.display=b?f[g]||"":"none"));return a}n.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=Fa(a,"opacity");return""===c?"1":c}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":"cssFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=n.camelCase(b),i=a.style;return b=n.cssProps[h]||(n.cssProps[h]=Ma(h)||h),g=n.cssHooks[b]||n.cssHooks[h],void 0===c?g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b]:(f=typeof c,"string"===f&&(e=T.exec(c))&&e[1]&&(c=W(a,b,e),f="number"),null!=c&&c===c&&("number"===f&&(c+=e&&e[3]||(n.cssNumber[h]?"":"px")),l.clearCloneStyle||""!==c||0!==b.indexOf("background")||(i[b]="inherit"),g&&"set"in g&&void 0===(c=g.set(a,c,d))||(i[b]=c)),void 0)}},css:function(a,b,c,d){var e,f,g,h=n.camelCase(b);return b=n.cssProps[h]||(n.cssProps[h]=Ma(h)||h),g=n.cssHooks[b]||n.cssHooks[h],g&&"get"in g&&(e=g.get(a,!0,c)),void 0===e&&(e=Fa(a,b,d)),"normal"===e&&b in Ja&&(e=Ja[b]),""===c||c?(f=parseFloat(e),c===!0||isFinite(f)?f||0:e):e}}),n.each(["height","width"],function(a,b){n.cssHooks[b]={get:function(a,c,d){return c?Ha.test(n.css(a,"display"))&&0===a.offsetWidth?Da(a,Ia,function(){return Pa(a,b,d)}):Pa(a,b,d):void 0},set:function(a,c,d){var e,f=d&&Ca(a),g=d&&Oa(a,b,d,"border-box"===n.css(a,"boxSizing",!1,f),f);return g&&(e=T.exec(c))&&"px"!==(e[3]||"px")&&(a.style[b]=c,c=n.css(a,b)),Na(a,c,g)}}}),n.cssHooks.marginLeft=Ga(l.reliableMarginLeft,function(a,b){return b?(parseFloat(Fa(a,"marginLeft"))||a.getBoundingClientRect().left-Da(a,{marginLeft:0},function(){return a.getBoundingClientRect().left}))+"px":void 0}),n.cssHooks.marginRight=Ga(l.reliableMarginRight,function(a,b){return b?Da(a,{display:"inline-block"},Fa,[a,"marginRight"]):void 0}),n.each({margin:"",padding:"",border:"Width"},function(a,b){n.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];4>d;d++)e[a+U[d]+b]=f[d]||f[d-2]||f[0];return e}},Aa.test(a)||(n.cssHooks[a+b].set=Na)}),n.fn.extend({css:function(a,b){return K(this,function(a,b,c){var d,e,f={},g=0;if(n.isArray(b)){for(d=Ca(a),e=b.length;e>g;g++)f[b[g]]=n.css(a,b[g],!1,d);return f}return void 0!==c?n.style(a,b,c):n.css(a,b)},a,b,arguments.length>1)},show:function(){return Qa(this,!0)},hide:function(){return Qa(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){V(this)?n(this).show():n(this).hide()})}});function Ra(a,b,c,d,e){return new Ra.prototype.init(a,b,c,d,e)}n.Tween=Ra,Ra.prototype={constructor:Ra,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||n.easing._default,this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(n.cssNumber[c]?"":"px")},cur:function(){var a=Ra.propHooks[this.prop];return a&&a.get?a.get(this):Ra.propHooks._default.get(this)},run:function(a){var b,c=Ra.propHooks[this.prop];return this.options.duration?this.pos=b=n.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):this.pos=b=a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Ra.propHooks._default.set(this),this}},Ra.prototype.init.prototype=Ra.prototype,Ra.propHooks={_default:{get:function(a){var b;return 1!==a.elem.nodeType||null!=a.elem[a.prop]&&null==a.elem.style[a.prop]?a.elem[a.prop]:(b=n.css(a.elem,a.prop,""),b&&"auto"!==b?b:0)},set:function(a){n.fx.step[a.prop]?n.fx.step[a.prop](a):1!==a.elem.nodeType||null==a.elem.style[n.cssProps[a.prop]]&&!n.cssHooks[a.prop]?a.elem[a.prop]=a.now:n.style(a.elem,a.prop,a.now+a.unit)}}},Ra.propHooks.scrollTop=Ra.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},n.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2},_default:"swing"},n.fx=Ra.prototype.init,n.fx.step={};var Sa,Ta,Ua=/^(?:toggle|show|hide)$/,Va=/queueHooks$/;function Wa(){return a.setTimeout(function(){Sa=void 0}),Sa=n.now()}function Xa(a,b){var c,d=0,e={height:a};for(b=b?1:0;4>d;d+=2-b)c=U[d],e["margin"+c]=e["padding"+c]=a;return b&&(e.opacity=e.width=a),e}function Ya(a,b,c){for(var d,e=(_a.tweeners[b]||[]).concat(_a.tweeners["*"]),f=0,g=e.length;g>f;f++)if(d=e[f].call(c,b,a))return d}function Za(a,b,c){var d,e,f,g,h,i,j,k,l=this,m={},o=a.style,p=a.nodeType&&V(a),q=N.get(a,"fxshow");c.queue||(h=n._queueHooks(a,"fx"),null==h.unqueued&&(h.unqueued=0,i=h.empty.fire,h.empty.fire=function(){h.unqueued||i()}),h.unqueued++,l.always(function(){l.always(function(){h.unqueued--,n.queue(a,"fx").length||h.empty.fire()})})),1===a.nodeType&&("height"in b||"width"in b)&&(c.overflow=[o.overflow,o.overflowX,o.overflowY],j=n.css(a,"display"),k="none"===j?N.get(a,"olddisplay")||za(a.nodeName):j,"inline"===k&&"none"===n.css(a,"float")&&(o.display="inline-block")),c.overflow&&(o.overflow="hidden",l.always(function(){o.overflow=c.overflow[0],o.overflowX=c.overflow[1],o.overflowY=c.overflow[2]}));for(d in b)if(e=b[d],Ua.exec(e)){if(delete b[d],f=f||"toggle"===e,e===(p?"hide":"show")){if("show"!==e||!q||void 0===q[d])continue;p=!0}m[d]=q&&q[d]||n.style(a,d)}else j=void 0;if(n.isEmptyObject(m))"inline"===("none"===j?za(a.nodeName):j)&&(o.display=j);else{q?"hidden"in q&&(p=q.hidden):q=N.access(a,"fxshow",{}),f&&(q.hidden=!p),p?n(a).show():l.done(function(){n(a).hide()}),l.done(function(){var b;N.remove(a,"fxshow");for(b in m)n.style(a,b,m[b])});for(d in m)g=Ya(p?q[d]:0,d,l),d in q||(q[d]=g.start,p&&(g.end=g.start,g.start="width"===d||"height"===d?1:0))}}function $a(a,b){var c,d,e,f,g;for(c in a)if(d=n.camelCase(c),e=b[d],f=a[c],n.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),g=n.cssHooks[d],g&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function _a(a,b,c){var d,e,f=0,g=_a.prefilters.length,h=n.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=Sa||Wa(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;i>g;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),1>f&&i?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:n.extend({},b),opts:n.extend(!0,{specialEasing:{},easing:n.easing._default},c),originalProperties:b,originalOptions:c,startTime:Sa||Wa(),duration:c.duration,tweens:[],createTween:function(b,c){var d=n.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;d>c;c++)j.tweens[c].run(1);return b?(h.notifyWith(a,[j,1,0]),h.resolveWith(a,[j,b])):h.rejectWith(a,[j,b]),this}}),k=j.props;for($a(k,j.opts.specialEasing);g>f;f++)if(d=_a.prefilters[f].call(j,a,k,j.opts))return n.isFunction(d.stop)&&(n._queueHooks(j.elem,j.opts.queue).stop=n.proxy(d.stop,d)),d;return n.map(k,Ya,j),n.isFunction(j.opts.start)&&j.opts.start.call(a,j),n.fx.timer(n.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}n.Animation=n.extend(_a,{tweeners:{"*":[function(a,b){var c=this.createTween(a,b);return W(c.elem,a,T.exec(b),c),c}]},tweener:function(a,b){n.isFunction(a)?(b=a,a=["*"]):a=a.match(G);for(var c,d=0,e=a.length;e>d;d++)c=a[d],_a.tweeners[c]=_a.tweeners[c]||[],_a.tweeners[c].unshift(b)},prefilters:[Za],prefilter:function(a,b){b?_a.prefilters.unshift(a):_a.prefilters.push(a)}}),n.speed=function(a,b,c){var d=a&&"object"==typeof a?n.extend({},a):{complete:c||!c&&b||n.isFunction(a)&&a,duration:a,easing:c&&b||b&&!n.isFunction(b)&&b};return d.duration=n.fx.off?0:"number"==typeof d.duration?d.duration:d.duration in n.fx.speeds?n.fx.speeds[d.duration]:n.fx.speeds._default,null!=d.queue&&d.queue!==!0||(d.queue="fx"),d.old=d.complete,d.complete=function(){n.isFunction(d.old)&&d.old.call(this),d.queue&&n.dequeue(this,d.queue)},d},n.fn.extend({fadeTo:function(a,b,c,d){return this.filter(V).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=n.isEmptyObject(a),f=n.speed(b,c,d),g=function(){var b=_a(this,n.extend({},a),f);(e||N.get(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=n.timers,g=N.get(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&Va.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));!b&&c||n.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=N.get(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=n.timers,g=d?d.length:0;for(c.finish=!0,n.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;g>b;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}),n.each(["toggle","show","hide"],function(a,b){var c=n.fn[b];n.fn[b]=function(a,d,e){return null==a||"boolean"==typeof a?c.apply(this,arguments):this.animate(Xa(b,!0),a,d,e)}}),n.each({slideDown:Xa("show"),slideUp:Xa("hide"),slideToggle:Xa("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){n.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),n.timers=[],n.fx.tick=function(){var a,b=0,c=n.timers;for(Sa=n.now();b<c.length;b++)a=c[b],a()||c[b]!==a||c.splice(b--,1);c.length||n.fx.stop(),Sa=void 0},n.fx.timer=function(a){n.timers.push(a),a()?n.fx.start():n.timers.pop()},n.fx.interval=13,n.fx.start=function(){Ta||(Ta=a.setInterval(n.fx.tick,n.fx.interval))},n.fx.stop=function(){a.clearInterval(Ta),Ta=null},n.fx.speeds={slow:600,fast:200,_default:400},n.fn.delay=function(b,c){return b=n.fx?n.fx.speeds[b]||b:b,c=c||"fx",this.queue(c,function(c,d){var e=a.setTimeout(c,b);d.stop=function(){a.clearTimeout(e)}})},function(){var a=d.createElement("input"),b=d.createElement("select"),c=b.appendChild(d.createElement("option"));a.type="checkbox",l.checkOn=""!==a.value,l.optSelected=c.selected,b.disabled=!0,l.optDisabled=!c.disabled,a=d.createElement("input"),a.value="t",a.type="radio",l.radioValue="t"===a.value}();var ab,bb=n.expr.attrHandle;n.fn.extend({attr:function(a,b){return K(this,n.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){n.removeAttr(this,a)})}}),n.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(3!==f&&8!==f&&2!==f)return"undefined"==typeof a.getAttribute?n.prop(a,b,c):(1===f&&n.isXMLDoc(a)||(b=b.toLowerCase(),e=n.attrHooks[b]||(n.expr.match.bool.test(b)?ab:void 0)),void 0!==c?null===c?void n.removeAttr(a,b):e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:(a.setAttribute(b,c+""),c):e&&"get"in e&&null!==(d=e.get(a,b))?d:(d=n.find.attr(a,b),null==d?void 0:d))},attrHooks:{type:{set:function(a,b){if(!l.radioValue&&"radio"===b&&n.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}},removeAttr:function(a,b){var c,d,e=0,f=b&&b.match(G);if(f&&1===a.nodeType)while(c=f[e++])d=n.propFix[c]||c,n.expr.match.bool.test(c)&&(a[d]=!1),a.removeAttribute(c)}}),ab={set:function(a,b,c){return b===!1?n.removeAttr(a,c):a.setAttribute(c,c),c}},n.each(n.expr.match.bool.source.match(/\w+/g),function(a,b){var c=bb[b]||n.find.attr;bb[b]=function(a,b,d){var e,f;return d||(f=bb[b],bb[b]=e,e=null!=c(a,b,d)?b.toLowerCase():null,bb[b]=f),e}});var cb=/^(?:input|select|textarea|button)$/i,db=/^(?:a|area)$/i;n.fn.extend({prop:function(a,b){return K(this,n.prop,a,b,arguments.length>1)},removeProp:function(a){return this.each(function(){delete this[n.propFix[a]||a]})}}),n.extend({prop:function(a,b,c){var d,e,f=a.nodeType;if(3!==f&&8!==f&&2!==f)return 1===f&&n.isXMLDoc(a)||(b=n.propFix[b]||b,e=n.propHooks[b]),
|
|
void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){var b=n.find.attr(a,"tabindex");return b?parseInt(b,10):cb.test(a.nodeName)||db.test(a.nodeName)&&a.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),l.optSelected||(n.propHooks.selected={get:function(a){var b=a.parentNode;return b&&b.parentNode&&b.parentNode.selectedIndex,null},set:function(a){var b=a.parentNode;b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex)}}),n.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){n.propFix[this.toLowerCase()]=this});var eb=/[\t\r\n\f]/g;function fb(a){return a.getAttribute&&a.getAttribute("class")||""}n.fn.extend({addClass:function(a){var b,c,d,e,f,g,h,i=0;if(n.isFunction(a))return this.each(function(b){n(this).addClass(a.call(this,b,fb(this)))});if("string"==typeof a&&a){b=a.match(G)||[];while(c=this[i++])if(e=fb(c),d=1===c.nodeType&&(" "+e+" ").replace(eb," ")){g=0;while(f=b[g++])d.indexOf(" "+f+" ")<0&&(d+=f+" ");h=n.trim(d),e!==h&&c.setAttribute("class",h)}}return this},removeClass:function(a){var b,c,d,e,f,g,h,i=0;if(n.isFunction(a))return this.each(function(b){n(this).removeClass(a.call(this,b,fb(this)))});if(!arguments.length)return this.attr("class","");if("string"==typeof a&&a){b=a.match(G)||[];while(c=this[i++])if(e=fb(c),d=1===c.nodeType&&(" "+e+" ").replace(eb," ")){g=0;while(f=b[g++])while(d.indexOf(" "+f+" ")>-1)d=d.replace(" "+f+" "," ");h=n.trim(d),e!==h&&c.setAttribute("class",h)}}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):n.isFunction(a)?this.each(function(c){n(this).toggleClass(a.call(this,c,fb(this),b),b)}):this.each(function(){var b,d,e,f;if("string"===c){d=0,e=n(this),f=a.match(G)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else void 0!==a&&"boolean"!==c||(b=fb(this),b&&N.set(this,"__className__",b),this.setAttribute&&this.setAttribute("class",b||a===!1?"":N.get(this,"__className__")||""))})},hasClass:function(a){var b,c,d=0;b=" "+a+" ";while(c=this[d++])if(1===c.nodeType&&(" "+fb(c)+" ").replace(eb," ").indexOf(b)>-1)return!0;return!1}});var gb=/\r/g,hb=/[\x20\t\r\n\f]+/g;n.fn.extend({val:function(a){var b,c,d,e=this[0];{if(arguments.length)return d=n.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,n(this).val()):a,null==e?e="":"number"==typeof e?e+="":n.isArray(e)&&(e=n.map(e,function(a){return null==a?"":a+""})),b=n.valHooks[this.type]||n.valHooks[this.nodeName.toLowerCase()],b&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))});if(e)return b=n.valHooks[e.type]||n.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(gb,""):null==c?"":c)}}}),n.extend({valHooks:{option:{get:function(a){var b=n.find.attr(a,"value");return null!=b?b:n.trim(n.text(a)).replace(hb," ")}},select:{get:function(a){for(var b,c,d=a.options,e=a.selectedIndex,f="select-one"===a.type||0>e,g=f?null:[],h=f?e+1:d.length,i=0>e?h:f?e:0;h>i;i++)if(c=d[i],(c.selected||i===e)&&(l.optDisabled?!c.disabled:null===c.getAttribute("disabled"))&&(!c.parentNode.disabled||!n.nodeName(c.parentNode,"optgroup"))){if(b=n(c).val(),f)return b;g.push(b)}return g},set:function(a,b){var c,d,e=a.options,f=n.makeArray(b),g=e.length;while(g--)d=e[g],(d.selected=n.inArray(n.valHooks.option.get(d),f)>-1)&&(c=!0);return c||(a.selectedIndex=-1),f}}}}),n.each(["radio","checkbox"],function(){n.valHooks[this]={set:function(a,b){return n.isArray(b)?a.checked=n.inArray(n(a).val(),b)>-1:void 0}},l.checkOn||(n.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})});var ib=/^(?:focusinfocus|focusoutblur)$/;n.extend(n.event,{trigger:function(b,c,e,f){var g,h,i,j,l,m,o,p=[e||d],q=k.call(b,"type")?b.type:b,r=k.call(b,"namespace")?b.namespace.split("."):[];if(h=i=e=e||d,3!==e.nodeType&&8!==e.nodeType&&!ib.test(q+n.event.triggered)&&(q.indexOf(".")>-1&&(r=q.split("."),q=r.shift(),r.sort()),l=q.indexOf(":")<0&&"on"+q,b=b[n.expando]?b:new n.Event(q,"object"==typeof b&&b),b.isTrigger=f?2:3,b.namespace=r.join("."),b.rnamespace=b.namespace?new RegExp("(^|\\.)"+r.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=e),c=null==c?[b]:n.makeArray(c,[b]),o=n.event.special[q]||{},f||!o.trigger||o.trigger.apply(e,c)!==!1)){if(!f&&!o.noBubble&&!n.isWindow(e)){for(j=o.delegateType||q,ib.test(j+q)||(h=h.parentNode);h;h=h.parentNode)p.push(h),i=h;i===(e.ownerDocument||d)&&p.push(i.defaultView||i.parentWindow||a)}g=0;while((h=p[g++])&&!b.isPropagationStopped())b.type=g>1?j:o.bindType||q,m=(N.get(h,"events")||{})[b.type]&&N.get(h,"handle"),m&&m.apply(h,c),m=l&&h[l],m&&m.apply&&L(h)&&(b.result=m.apply(h,c),b.result===!1&&b.preventDefault());return b.type=q,f||b.isDefaultPrevented()||o._default&&o._default.apply(p.pop(),c)!==!1||!L(e)||l&&n.isFunction(e[q])&&!n.isWindow(e)&&(i=e[l],i&&(e[l]=null),n.event.triggered=q,e[q](),n.event.triggered=void 0,i&&(e[l]=i)),b.result}},simulate:function(a,b,c){var d=n.extend(new n.Event,c,{type:a,isSimulated:!0});n.event.trigger(d,null,b)}}),n.fn.extend({trigger:function(a,b){return this.each(function(){n.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];return c?n.event.trigger(a,b,c,!0):void 0}}),n.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(a,b){n.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),n.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}}),l.focusin="onfocusin"in a,l.focusin||n.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){n.event.simulate(b,a.target,n.event.fix(a))};n.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=N.access(d,b);e||d.addEventListener(a,c,!0),N.access(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=N.access(d,b)-1;e?N.access(d,b,e):(d.removeEventListener(a,c,!0),N.remove(d,b))}}});var jb=a.location,kb=n.now(),lb=/\?/;n.parseJSON=function(a){return JSON.parse(a+"")},n.parseXML=function(b){var c;if(!b||"string"!=typeof b)return null;try{c=(new a.DOMParser).parseFromString(b,"text/xml")}catch(d){c=void 0}return c&&!c.getElementsByTagName("parsererror").length||n.error("Invalid XML: "+b),c};var mb=/#.*$/,nb=/([?&])_=[^&]*/,ob=/^(.*?):[ \t]*([^\r\n]*)$/gm,pb=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,qb=/^(?:GET|HEAD)$/,rb=/^\/\//,sb={},tb={},ub="*/".concat("*"),vb=d.createElement("a");vb.href=jb.href;function wb(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(G)||[];if(n.isFunction(c))while(d=f[e++])"+"===d[0]?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function xb(a,b,c,d){var e={},f=a===tb;function g(h){var i;return e[h]=!0,n.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}return g(b.dataTypes[0])||!e["*"]&&g("*")}function yb(a,b){var c,d,e=n.ajaxSettings.flatOptions||{};for(c in b)void 0!==b[c]&&((e[c]?a:d||(d={}))[c]=b[c]);return d&&n.extend(!0,a,d),a}function zb(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while("*"===i[0])i.shift(),void 0===d&&(d=a.mimeType||b.getResponseHeader("Content-Type"));if(d)for(e in h)if(h[e]&&h[e].test(d)){i.unshift(e);break}if(i[0]in c)f=i[0];else{for(e in c){if(!i[0]||a.converters[e+" "+i[0]]){f=e;break}g||(g=e)}f=f||g}return f?(f!==i[0]&&i.unshift(f),c[f]):void 0}function Ab(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];f=k.shift();while(f)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(g=j[i+" "+f]||j["* "+f],!g)for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a["throws"])b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}n.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:jb.href,type:"GET",isLocal:pb.test(jb.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":ub,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":n.parseJSON,"text xml":n.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?yb(yb(a,n.ajaxSettings),b):yb(n.ajaxSettings,a)},ajaxPrefilter:wb(sb),ajaxTransport:wb(tb),ajax:function(b,c){"object"==typeof b&&(c=b,b=void 0),c=c||{};var e,f,g,h,i,j,k,l,m=n.ajaxSetup({},c),o=m.context||m,p=m.context&&(o.nodeType||o.jquery)?n(o):n.event,q=n.Deferred(),r=n.Callbacks("once memory"),s=m.statusCode||{},t={},u={},v=0,w="canceled",x={readyState:0,getResponseHeader:function(a){var b;if(2===v){if(!h){h={};while(b=ob.exec(g))h[b[1].toLowerCase()]=b[2]}b=h[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return 2===v?g:null},setRequestHeader:function(a,b){var c=a.toLowerCase();return v||(a=u[c]=u[c]||a,t[a]=b),this},overrideMimeType:function(a){return v||(m.mimeType=a),this},statusCode:function(a){var b;if(a)if(2>v)for(b in a)s[b]=[s[b],a[b]];else x.always(a[x.status]);return this},abort:function(a){var b=a||w;return e&&e.abort(b),z(0,b),this}};if(q.promise(x).complete=r.add,x.success=x.done,x.error=x.fail,m.url=((b||m.url||jb.href)+"").replace(mb,"").replace(rb,jb.protocol+"//"),m.type=c.method||c.type||m.method||m.type,m.dataTypes=n.trim(m.dataType||"*").toLowerCase().match(G)||[""],null==m.crossDomain){j=d.createElement("a");try{j.href=m.url,j.href=j.href,m.crossDomain=vb.protocol+"//"+vb.host!=j.protocol+"//"+j.host}catch(y){m.crossDomain=!0}}if(m.data&&m.processData&&"string"!=typeof m.data&&(m.data=n.param(m.data,m.traditional)),xb(sb,m,c,x),2===v)return x;k=n.event&&m.global,k&&0===n.active++&&n.event.trigger("ajaxStart"),m.type=m.type.toUpperCase(),m.hasContent=!qb.test(m.type),f=m.url,m.hasContent||(m.data&&(f=m.url+=(lb.test(f)?"&":"?")+m.data,delete m.data),m.cache===!1&&(m.url=nb.test(f)?f.replace(nb,"$1_="+kb++):f+(lb.test(f)?"&":"?")+"_="+kb++)),m.ifModified&&(n.lastModified[f]&&x.setRequestHeader("If-Modified-Since",n.lastModified[f]),n.etag[f]&&x.setRequestHeader("If-None-Match",n.etag[f])),(m.data&&m.hasContent&&m.contentType!==!1||c.contentType)&&x.setRequestHeader("Content-Type",m.contentType),x.setRequestHeader("Accept",m.dataTypes[0]&&m.accepts[m.dataTypes[0]]?m.accepts[m.dataTypes[0]]+("*"!==m.dataTypes[0]?", "+ub+"; q=0.01":""):m.accepts["*"]);for(l in m.headers)x.setRequestHeader(l,m.headers[l]);if(m.beforeSend&&(m.beforeSend.call(o,x,m)===!1||2===v))return x.abort();w="abort";for(l in{success:1,error:1,complete:1})x[l](m[l]);if(e=xb(tb,m,c,x)){if(x.readyState=1,k&&p.trigger("ajaxSend",[x,m]),2===v)return x;m.async&&m.timeout>0&&(i=a.setTimeout(function(){x.abort("timeout")},m.timeout));try{v=1,e.send(t,z)}catch(y){if(!(2>v))throw y;z(-1,y)}}else z(-1,"No Transport");function z(b,c,d,h){var j,l,t,u,w,y=c;2!==v&&(v=2,i&&a.clearTimeout(i),e=void 0,g=h||"",x.readyState=b>0?4:0,j=b>=200&&300>b||304===b,d&&(u=zb(m,x,d)),u=Ab(m,u,x,j),j?(m.ifModified&&(w=x.getResponseHeader("Last-Modified"),w&&(n.lastModified[f]=w),w=x.getResponseHeader("etag"),w&&(n.etag[f]=w)),204===b||"HEAD"===m.type?y="nocontent":304===b?y="notmodified":(y=u.state,l=u.data,t=u.error,j=!t)):(t=y,!b&&y||(y="error",0>b&&(b=0))),x.status=b,x.statusText=(c||y)+"",j?q.resolveWith(o,[l,y,x]):q.rejectWith(o,[x,y,t]),x.statusCode(s),s=void 0,k&&p.trigger(j?"ajaxSuccess":"ajaxError",[x,m,j?l:t]),r.fireWith(o,[x,y]),k&&(p.trigger("ajaxComplete",[x,m]),--n.active||n.event.trigger("ajaxStop")))}return x},getJSON:function(a,b,c){return n.get(a,b,c,"json")},getScript:function(a,b){return n.get(a,void 0,b,"script")}}),n.each(["get","post"],function(a,b){n[b]=function(a,c,d,e){return n.isFunction(c)&&(e=e||d,d=c,c=void 0),n.ajax(n.extend({url:a,type:b,dataType:e,data:c,success:d},n.isPlainObject(a)&&a))}}),n._evalUrl=function(a){return n.ajax({url:a,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})},n.fn.extend({wrapAll:function(a){var b;return n.isFunction(a)?this.each(function(b){n(this).wrapAll(a.call(this,b))}):(this[0]&&(b=n(a,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstElementChild)a=a.firstElementChild;return a}).append(this)),this)},wrapInner:function(a){return n.isFunction(a)?this.each(function(b){n(this).wrapInner(a.call(this,b))}):this.each(function(){var b=n(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=n.isFunction(a);return this.each(function(c){n(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){n.nodeName(this,"body")||n(this).replaceWith(this.childNodes)}).end()}}),n.expr.filters.hidden=function(a){return!n.expr.filters.visible(a)},n.expr.filters.visible=function(a){return a.offsetWidth>0||a.offsetHeight>0||a.getClientRects().length>0};var Bb=/%20/g,Cb=/\[\]$/,Db=/\r?\n/g,Eb=/^(?:submit|button|image|reset|file)$/i,Fb=/^(?:input|select|textarea|keygen)/i;function Gb(a,b,c,d){var e;if(n.isArray(b))n.each(b,function(b,e){c||Cb.test(a)?d(a,e):Gb(a+"["+("object"==typeof e&&null!=e?b:"")+"]",e,c,d)});else if(c||"object"!==n.type(b))d(a,b);else for(e in b)Gb(a+"["+e+"]",b[e],c,d)}n.param=function(a,b){var c,d=[],e=function(a,b){b=n.isFunction(b)?b():null==b?"":b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};if(void 0===b&&(b=n.ajaxSettings&&n.ajaxSettings.traditional),n.isArray(a)||a.jquery&&!n.isPlainObject(a))n.each(a,function(){e(this.name,this.value)});else for(c in a)Gb(c,a[c],b,e);return d.join("&").replace(Bb,"+")},n.fn.extend({serialize:function(){return n.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=n.prop(this,"elements");return a?n.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!n(this).is(":disabled")&&Fb.test(this.nodeName)&&!Eb.test(a)&&(this.checked||!X.test(a))}).map(function(a,b){var c=n(this).val();return null==c?null:n.isArray(c)?n.map(c,function(a){return{name:b.name,value:a.replace(Db,"\r\n")}}):{name:b.name,value:c.replace(Db,"\r\n")}}).get()}}),n.ajaxSettings.xhr=function(){try{return new a.XMLHttpRequest}catch(b){}};var Hb={0:200,1223:204},Ib=n.ajaxSettings.xhr();l.cors=!!Ib&&"withCredentials"in Ib,l.ajax=Ib=!!Ib,n.ajaxTransport(function(b){var c,d;return l.cors||Ib&&!b.crossDomain?{send:function(e,f){var g,h=b.xhr();if(h.open(b.type,b.url,b.async,b.username,b.password),b.xhrFields)for(g in b.xhrFields)h[g]=b.xhrFields[g];b.mimeType&&h.overrideMimeType&&h.overrideMimeType(b.mimeType),b.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest");for(g in e)h.setRequestHeader(g,e[g]);c=function(a){return function(){c&&(c=d=h.onload=h.onerror=h.onabort=h.onreadystatechange=null,"abort"===a?h.abort():"error"===a?"number"!=typeof h.status?f(0,"error"):f(h.status,h.statusText):f(Hb[h.status]||h.status,h.statusText,"text"!==(h.responseType||"text")||"string"!=typeof h.responseText?{binary:h.response}:{text:h.responseText},h.getAllResponseHeaders()))}},h.onload=c(),d=h.onerror=c("error"),void 0!==h.onabort?h.onabort=d:h.onreadystatechange=function(){4===h.readyState&&a.setTimeout(function(){c&&d()})},c=c("abort");try{h.send(b.hasContent&&b.data||null)}catch(i){if(c)throw i}},abort:function(){c&&c()}}:void 0}),n.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(a){return n.globalEval(a),a}}}),n.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET")}),n.ajaxTransport("script",function(a){if(a.crossDomain){var b,c;return{send:function(e,f){b=n("<script>").prop({charset:a.scriptCharset,src:a.url}).on("load error",c=function(a){b.remove(),c=null,a&&f("error"===a.type?404:200,a.type)}),d.head.appendChild(b[0])},abort:function(){c&&c()}}}});var Jb=[],Kb=/(=)\?(?=&|$)|\?\?/;n.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=Jb.pop()||n.expando+"_"+kb++;return this[a]=!0,a}}),n.ajaxPrefilter("json jsonp",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(Kb.test(b.url)?"url":"string"==typeof b.data&&0===(b.contentType||"").indexOf("application/x-www-form-urlencoded")&&Kb.test(b.data)&&"data");return h||"jsonp"===b.dataTypes[0]?(e=b.jsonpCallback=n.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,h?b[h]=b[h].replace(Kb,"$1"+e):b.jsonp!==!1&&(b.url+=(lb.test(b.url)?"&":"?")+b.jsonp+"="+e),b.converters["script json"]=function(){return g||n.error(e+" was not called"),g[0]},b.dataTypes[0]="json",f=a[e],a[e]=function(){g=arguments},d.always(function(){void 0===f?n(a).removeProp(e):a[e]=f,b[e]&&(b.jsonpCallback=c.jsonpCallback,Jb.push(e)),g&&n.isFunction(f)&&f(g[0]),g=f=void 0}),"script"):void 0}),n.parseHTML=function(a,b,c){if(!a||"string"!=typeof a)return null;"boolean"==typeof b&&(c=b,b=!1),b=b||d;var e=x.exec(a),f=!c&&[];return e?[b.createElement(e[1])]:(e=ca([a],b,f),f&&f.length&&n(f).remove(),n.merge([],e.childNodes))};var Lb=n.fn.load;n.fn.load=function(a,b,c){if("string"!=typeof a&&Lb)return Lb.apply(this,arguments);var d,e,f,g=this,h=a.indexOf(" ");return h>-1&&(d=n.trim(a.slice(h)),a=a.slice(0,h)),n.isFunction(b)?(c=b,b=void 0):b&&"object"==typeof b&&(e="POST"),g.length>0&&n.ajax({url:a,type:e||"GET",dataType:"html",data:b}).done(function(a){f=arguments,g.html(d?n("<div>").append(n.parseHTML(a)).find(d):a)}).always(c&&function(a,b){g.each(function(){c.apply(this,f||[a.responseText,b,a])})}),this},n.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(a,b){n.fn[b]=function(a){return this.on(b,a)}}),n.expr.filters.animated=function(a){return n.grep(n.timers,function(b){return a===b.elem}).length};function Mb(a){return n.isWindow(a)?a:9===a.nodeType&&a.defaultView}n.offset={setOffset:function(a,b,c){var d,e,f,g,h,i,j,k=n.css(a,"position"),l=n(a),m={};"static"===k&&(a.style.position="relative"),h=l.offset(),f=n.css(a,"top"),i=n.css(a,"left"),j=("absolute"===k||"fixed"===k)&&(f+i).indexOf("auto")>-1,j?(d=l.position(),g=d.top,e=d.left):(g=parseFloat(f)||0,e=parseFloat(i)||0),n.isFunction(b)&&(b=b.call(a,c,n.extend({},h))),null!=b.top&&(m.top=b.top-h.top+g),null!=b.left&&(m.left=b.left-h.left+e),"using"in b?b.using.call(a,m):l.css(m)}},n.fn.extend({offset:function(a){if(arguments.length)return void 0===a?this:this.each(function(b){n.offset.setOffset(this,a,b)});var b,c,d=this[0],e={top:0,left:0},f=d&&d.ownerDocument;if(f)return b=f.documentElement,n.contains(b,d)?(e=d.getBoundingClientRect(),c=Mb(f),{top:e.top+c.pageYOffset-b.clientTop,left:e.left+c.pageXOffset-b.clientLeft}):e},position:function(){if(this[0]){var a,b,c=this[0],d={top:0,left:0};return"fixed"===n.css(c,"position")?b=c.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),n.nodeName(a[0],"html")||(d=a.offset()),d.top+=n.css(a[0],"borderTopWidth",!0),d.left+=n.css(a[0],"borderLeftWidth",!0)),{top:b.top-d.top-n.css(c,"marginTop",!0),left:b.left-d.left-n.css(c,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var a=this.offsetParent;while(a&&"static"===n.css(a,"position"))a=a.offsetParent;return a||Ea})}}),n.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,b){var c="pageYOffset"===b;n.fn[a]=function(d){return K(this,function(a,d,e){var f=Mb(a);return void 0===e?f?f[b]:a[d]:void(f?f.scrollTo(c?f.pageXOffset:e,c?e:f.pageYOffset):a[d]=e)},a,d,arguments.length)}}),n.each(["top","left"],function(a,b){n.cssHooks[b]=Ga(l.pixelPosition,function(a,c){return c?(c=Fa(a,b),Ba.test(c)?n(a).position()[b]+"px":c):void 0})}),n.each({Height:"height",Width:"width"},function(a,b){n.each({padding:"inner"+a,content:b,"":"outer"+a},function(c,d){n.fn[d]=function(d,e){var f=arguments.length&&(c||"boolean"!=typeof d),g=c||(d===!0||e===!0?"margin":"border");return K(this,function(b,c,d){var e;return n.isWindow(b)?b.document.documentElement["client"+a]:9===b.nodeType?(e=b.documentElement,Math.max(b.body["scroll"+a],e["scroll"+a],b.body["offset"+a],e["offset"+a],e["client"+a])):void 0===d?n.css(b,c,g):n.style(b,c,d,g)},b,f?d:void 0,f,null)}})}),n.fn.extend({bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},delegate:function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return 1===arguments.length?this.off(a,"**"):this.off(b,a||"**",c)},size:function(){return this.length}}),n.fn.andSelf=n.fn.addBack,"function"==typeof define&&define.amd&&define("jquery",[],function(){return n});var Nb=a.jQuery,Ob=a.$;return n.noConflict=function(b){return a.$===n&&(a.$=Ob),b&&a.jQuery===n&&(a.jQuery=Nb),n},b||(a.jQuery=a.$=n),n});
|
|
|
|
/*
|
|
* Foundation Responsive Library
|
|
* http://foundation.zurb.com
|
|
* Copyright 2014, ZURB
|
|
* Free to use under the MIT license.
|
|
* http://www.opensource.org/licenses/mit-license.php
|
|
*/
|
|
|
|
(function ($, window, document, undefined) {
|
|
'use strict';
|
|
|
|
var header_helpers = function (class_array) {
|
|
var i = class_array.length;
|
|
var head = $('head');
|
|
|
|
while (i--) {
|
|
if (head.has('.' + class_array[i]).length === 0) {
|
|
head.append('<meta class="' + class_array[i] + '" />');
|
|
}
|
|
}
|
|
};
|
|
|
|
header_helpers([
|
|
'foundation-mq-small',
|
|
'foundation-mq-small-only',
|
|
'foundation-mq-medium',
|
|
'foundation-mq-medium-only',
|
|
'foundation-mq-large',
|
|
'foundation-mq-large-only',
|
|
'foundation-mq-xlarge',
|
|
'foundation-mq-xlarge-only',
|
|
'foundation-mq-xxlarge',
|
|
'foundation-data-attribute-namespace']);
|
|
|
|
// Enable FastClick if present
|
|
|
|
$(function () {
|
|
if (typeof FastClick !== 'undefined') {
|
|
// Don't attach to body if undefined
|
|
if (typeof document.body !== 'undefined') {
|
|
FastClick.attach(document.body);
|
|
}
|
|
}
|
|
});
|
|
|
|
// private Fast Selector wrapper,
|
|
// returns jQuery object. Only use where
|
|
// getElementById is not available.
|
|
var S = function (selector, context) {
|
|
if (typeof selector === 'string') {
|
|
if (context) {
|
|
var cont;
|
|
if (context.jquery) {
|
|
cont = context[0];
|
|
if (!cont) {
|
|
return context;
|
|
}
|
|
} else {
|
|
cont = context;
|
|
}
|
|
return $(cont.querySelectorAll(selector));
|
|
}
|
|
|
|
return $(document.querySelectorAll(selector));
|
|
}
|
|
|
|
return $(selector, context);
|
|
};
|
|
|
|
// Namespace functions.
|
|
|
|
var attr_name = function (init) {
|
|
var arr = [];
|
|
if (!init) {
|
|
arr.push('data');
|
|
}
|
|
if (this.namespace.length > 0) {
|
|
arr.push(this.namespace);
|
|
}
|
|
arr.push(this.name);
|
|
|
|
return arr.join('-');
|
|
};
|
|
|
|
var add_namespace = function (str) {
|
|
var parts = str.split('-'),
|
|
i = parts.length,
|
|
arr = [];
|
|
|
|
while (i--) {
|
|
if (i !== 0) {
|
|
arr.push(parts[i]);
|
|
} else {
|
|
if (this.namespace.length > 0) {
|
|
arr.push(this.namespace, parts[i]);
|
|
} else {
|
|
arr.push(parts[i]);
|
|
}
|
|
}
|
|
}
|
|
|
|
return arr.reverse().join('-');
|
|
};
|
|
|
|
// Event binding and data-options updating.
|
|
|
|
var bindings = function (method, options) {
|
|
var self = this,
|
|
bind = function(){
|
|
var $this = S(this),
|
|
should_bind_events = !$this.data(self.attr_name(true) + '-init');
|
|
$this.data(self.attr_name(true) + '-init', $.extend({}, self.settings, (options || method), self.data_options($this)));
|
|
|
|
if (should_bind_events) {
|
|
self.events(this);
|
|
}
|
|
};
|
|
|
|
if (S(this.scope).is('[' + this.attr_name() +']')) {
|
|
bind.call(this.scope);
|
|
} else {
|
|
S('[' + this.attr_name() +']', this.scope).each(bind);
|
|
}
|
|
// # Patch to fix #5043 to move this *after* the if/else clause in order for Backbone and similar frameworks to have improved control over event binding and data-options updating.
|
|
if (typeof method === 'string') {
|
|
return this[method].call(this, options);
|
|
}
|
|
|
|
};
|
|
|
|
var single_image_loaded = function (image, callback) {
|
|
function loaded () {
|
|
callback(image[0]);
|
|
}
|
|
|
|
function bindLoad () {
|
|
this.one('load', loaded);
|
|
|
|
if (/MSIE (\d+\.\d+);/.test(navigator.userAgent)) {
|
|
var src = this.attr( 'src' ),
|
|
param = src.match( /\?/ ) ? '&' : '?';
|
|
|
|
param += 'random=' + (new Date()).getTime();
|
|
this.attr('src', src + param);
|
|
}
|
|
}
|
|
|
|
if (!image.attr('src')) {
|
|
loaded();
|
|
return;
|
|
}
|
|
|
|
if (image[0].complete || image[0].readyState === 4) {
|
|
loaded();
|
|
} else {
|
|
bindLoad.call(image);
|
|
}
|
|
};
|
|
|
|
/*
|
|
https://github.com/paulirish/matchMedia.js
|
|
*/
|
|
|
|
window.matchMedia = window.matchMedia || (function ( doc ) {
|
|
|
|
'use strict';
|
|
|
|
var bool,
|
|
docElem = doc.documentElement,
|
|
refNode = docElem.firstElementChild || docElem.firstChild,
|
|
// fakeBody required for <FF4 when executed in <head>
|
|
fakeBody = doc.createElement( 'body' ),
|
|
div = doc.createElement( 'div' );
|
|
|
|
div.id = 'mq-test-1';
|
|
div.style.cssText = 'position:absolute;top:-100em';
|
|
fakeBody.style.background = 'none';
|
|
fakeBody.appendChild(div);
|
|
|
|
return function (q) {
|
|
|
|
div.innerHTML = '­<style media="' + q + '"> #mq-test-1 { width: 42px; }</style>';
|
|
|
|
docElem.insertBefore( fakeBody, refNode );
|
|
bool = div.offsetWidth === 42;
|
|
docElem.removeChild( fakeBody );
|
|
|
|
return {
|
|
matches : bool,
|
|
media : q
|
|
};
|
|
|
|
};
|
|
|
|
}( document ));
|
|
|
|
/*
|
|
* jquery.requestAnimationFrame
|
|
* https://github.com/gnarf37/jquery-requestAnimationFrame
|
|
* Requires jQuery 1.8+
|
|
*
|
|
* Copyright (c) 2012 Corey Frang
|
|
* Licensed under the MIT license.
|
|
*/
|
|
|
|
(function(jQuery) {
|
|
|
|
|
|
// requestAnimationFrame polyfill adapted from Erik Möller
|
|
// fixes from Paul Irish and Tino Zijdel
|
|
// http://paulirish.com/2011/requestanimationframe-for-smart-animating/
|
|
// http://my.opera.com/emoller/blog/2011/12/20/requestanimationframe-for-smart-er-animating
|
|
|
|
var animating,
|
|
lastTime = 0,
|
|
vendors = ['webkit', 'moz'],
|
|
requestAnimationFrame = window.requestAnimationFrame,
|
|
cancelAnimationFrame = window.cancelAnimationFrame,
|
|
jqueryFxAvailable = 'undefined' !== typeof jQuery.fx;
|
|
|
|
for (; lastTime < vendors.length && !requestAnimationFrame; lastTime++) {
|
|
requestAnimationFrame = window[ vendors[lastTime] + 'RequestAnimationFrame' ];
|
|
cancelAnimationFrame = cancelAnimationFrame ||
|
|
window[ vendors[lastTime] + 'CancelAnimationFrame' ] ||
|
|
window[ vendors[lastTime] + 'CancelRequestAnimationFrame' ];
|
|
}
|
|
|
|
function raf() {
|
|
if (animating) {
|
|
requestAnimationFrame(raf);
|
|
|
|
if (jqueryFxAvailable) {
|
|
jQuery.fx.tick();
|
|
}
|
|
}
|
|
}
|
|
|
|
if (requestAnimationFrame) {
|
|
// use rAF
|
|
window.requestAnimationFrame = requestAnimationFrame;
|
|
window.cancelAnimationFrame = cancelAnimationFrame;
|
|
|
|
if (jqueryFxAvailable) {
|
|
jQuery.fx.timer = function (timer) {
|
|
if (timer() && jQuery.timers.push(timer) && !animating) {
|
|
animating = true;
|
|
raf();
|
|
}
|
|
};
|
|
|
|
jQuery.fx.stop = function () {
|
|
animating = false;
|
|
};
|
|
}
|
|
} else {
|
|
// polyfill
|
|
window.requestAnimationFrame = function (callback) {
|
|
var currTime = new Date().getTime(),
|
|
timeToCall = Math.max(0, 16 - (currTime - lastTime)),
|
|
id = window.setTimeout(function () {
|
|
callback(currTime + timeToCall);
|
|
}, timeToCall);
|
|
lastTime = currTime + timeToCall;
|
|
return id;
|
|
};
|
|
|
|
window.cancelAnimationFrame = function (id) {
|
|
clearTimeout(id);
|
|
};
|
|
|
|
}
|
|
|
|
}( $ ));
|
|
|
|
function removeQuotes (string) {
|
|
if (typeof string === 'string' || string instanceof String) {
|
|
string = string.replace(/^['\\/"]+|(;\s?})+|['\\/"]+$/g, '');
|
|
}
|
|
|
|
return string;
|
|
}
|
|
|
|
window.Foundation = {
|
|
name : 'Foundation',
|
|
|
|
version : '5.5.1',
|
|
|
|
media_queries : {
|
|
'small' : S('.foundation-mq-small').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
|
|
'small-only' : S('.foundation-mq-small-only').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
|
|
'medium' : S('.foundation-mq-medium').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
|
|
'medium-only' : S('.foundation-mq-medium-only').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
|
|
'large' : S('.foundation-mq-large').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
|
|
'large-only' : S('.foundation-mq-large-only').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
|
|
'xlarge' : S('.foundation-mq-xlarge').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
|
|
'xlarge-only' : S('.foundation-mq-xlarge-only').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, ''),
|
|
'xxlarge' : S('.foundation-mq-xxlarge').css('font-family').replace(/^[\/\\'"]+|(;\s?})+|[\/\\'"]+$/g, '')
|
|
},
|
|
|
|
stylesheet : $('<style></style>').appendTo('head')[0].sheet,
|
|
|
|
global : {
|
|
namespace : undefined
|
|
},
|
|
|
|
init : function (scope, libraries, method, options, response) {
|
|
var args = [scope, method, options, response],
|
|
responses = [];
|
|
|
|
// check RTL
|
|
this.rtl = /rtl/i.test(S('html').attr('dir'));
|
|
|
|
// set foundation global scope
|
|
this.scope = scope || this.scope;
|
|
|
|
this.set_namespace();
|
|
|
|
if (libraries && typeof libraries === 'string' && !/reflow/i.test(libraries)) {
|
|
if (this.libs.hasOwnProperty(libraries)) {
|
|
responses.push(this.init_lib(libraries, args));
|
|
}
|
|
} else {
|
|
for (var lib in this.libs) {
|
|
responses.push(this.init_lib(lib, libraries));
|
|
}
|
|
}
|
|
|
|
S(window).load(function () {
|
|
S(window)
|
|
.trigger('resize.fndtn.clearing')
|
|
.trigger('resize.fndtn.dropdown')
|
|
.trigger('resize.fndtn.equalizer')
|
|
.trigger('resize.fndtn.interchange')
|
|
.trigger('resize.fndtn.joyride')
|
|
.trigger('resize.fndtn.magellan')
|
|
.trigger('resize.fndtn.topbar')
|
|
.trigger('resize.fndtn.slider');
|
|
});
|
|
|
|
return scope;
|
|
},
|
|
|
|
init_lib : function (lib, args) {
|
|
if (this.libs.hasOwnProperty(lib)) {
|
|
this.patch(this.libs[lib]);
|
|
|
|
if (args && args.hasOwnProperty(lib)) {
|
|
if (typeof this.libs[lib].settings !== 'undefined') {
|
|
$.extend(true, this.libs[lib].settings, args[lib]);
|
|
} else if (typeof this.libs[lib].defaults !== 'undefined') {
|
|
$.extend(true, this.libs[lib].defaults, args[lib]);
|
|
}
|
|
return this.libs[lib].init.apply(this.libs[lib], [this.scope, args[lib]]);
|
|
}
|
|
|
|
args = args instanceof Array ? args : new Array(args);
|
|
return this.libs[lib].init.apply(this.libs[lib], args);
|
|
}
|
|
|
|
return function () {};
|
|
},
|
|
|
|
patch : function (lib) {
|
|
lib.scope = this.scope;
|
|
lib.namespace = this.global.namespace;
|
|
lib.rtl = this.rtl;
|
|
lib['data_options'] = this.utils.data_options;
|
|
lib['attr_name'] = attr_name;
|
|
lib['add_namespace'] = add_namespace;
|
|
lib['bindings'] = bindings;
|
|
lib['S'] = this.utils.S;
|
|
},
|
|
|
|
inherit : function (scope, methods) {
|
|
var methods_arr = methods.split(' '),
|
|
i = methods_arr.length;
|
|
|
|
while (i--) {
|
|
if (this.utils.hasOwnProperty(methods_arr[i])) {
|
|
scope[methods_arr[i]] = this.utils[methods_arr[i]];
|
|
}
|
|
}
|
|
},
|
|
|
|
set_namespace : function () {
|
|
|
|
// Description:
|
|
// Don't bother reading the namespace out of the meta tag
|
|
// if the namespace has been set globally in javascript
|
|
//
|
|
// Example:
|
|
// Foundation.global.namespace = 'my-namespace';
|
|
// or make it an empty string:
|
|
// Foundation.global.namespace = '';
|
|
//
|
|
//
|
|
|
|
// If the namespace has not been set (is undefined), try to read it out of the meta element.
|
|
// Otherwise use the globally defined namespace, even if it's empty ('')
|
|
var namespace = ( this.global.namespace === undefined ) ? $('.foundation-data-attribute-namespace').css('font-family') : this.global.namespace;
|
|
|
|
// Finally, if the namsepace is either undefined or false, set it to an empty string.
|
|
// Otherwise use the namespace value.
|
|
this.global.namespace = ( namespace === undefined || /false/i.test(namespace) ) ? '' : namespace;
|
|
},
|
|
|
|
libs : {},
|
|
|
|
// methods that can be inherited in libraries
|
|
utils : {
|
|
|
|
// Description:
|
|
// Fast Selector wrapper returns jQuery object. Only use where getElementById
|
|
// is not available.
|
|
//
|
|
// Arguments:
|
|
// Selector (String): CSS selector describing the element(s) to be
|
|
// returned as a jQuery object.
|
|
//
|
|
// Scope (String): CSS selector describing the area to be searched. Default
|
|
// is document.
|
|
//
|
|
// Returns:
|
|
// Element (jQuery Object): jQuery object containing elements matching the
|
|
// selector within the scope.
|
|
S : S,
|
|
|
|
// Description:
|
|
// Executes a function a max of once every n milliseconds
|
|
//
|
|
// Arguments:
|
|
// Func (Function): Function to be throttled.
|
|
//
|
|
// Delay (Integer): Function execution threshold in milliseconds.
|
|
//
|
|
// Returns:
|
|
// Lazy_function (Function): Function with throttling applied.
|
|
throttle : function (func, delay) {
|
|
var timer = null;
|
|
|
|
return function () {
|
|
var context = this, args = arguments;
|
|
|
|
if (timer == null) {
|
|
timer = setTimeout(function () {
|
|
func.apply(context, args);
|
|
timer = null;
|
|
}, delay);
|
|
}
|
|
};
|
|
},
|
|
|
|
// Description:
|
|
// Executes a function when it stops being invoked for n seconds
|
|
// Modified version of _.debounce() http://underscorejs.org
|
|
//
|
|
// Arguments:
|
|
// Func (Function): Function to be debounced.
|
|
//
|
|
// Delay (Integer): Function execution threshold in milliseconds.
|
|
//
|
|
// Immediate (Bool): Whether the function should be called at the beginning
|
|
// of the delay instead of the end. Default is false.
|
|
//
|
|
// Returns:
|
|
// Lazy_function (Function): Function with debouncing applied.
|
|
debounce : function (func, delay, immediate) {
|
|
var timeout, result;
|
|
return function () {
|
|
var context = this, args = arguments;
|
|
var later = function () {
|
|
timeout = null;
|
|
if (!immediate) {
|
|
result = func.apply(context, args);
|
|
}
|
|
};
|
|
var callNow = immediate && !timeout;
|
|
clearTimeout(timeout);
|
|
timeout = setTimeout(later, delay);
|
|
if (callNow) {
|
|
result = func.apply(context, args);
|
|
}
|
|
return result;
|
|
};
|
|
},
|
|
|
|
// Description:
|
|
// Parses data-options attribute
|
|
//
|
|
// Arguments:
|
|
// El (jQuery Object): Element to be parsed.
|
|
//
|
|
// Returns:
|
|
// Options (Javascript Object): Contents of the element's data-options
|
|
// attribute.
|
|
data_options : function (el, data_attr_name) {
|
|
data_attr_name = data_attr_name || 'options';
|
|
var opts = {}, ii, p, opts_arr,
|
|
data_options = function (el) {
|
|
var namespace = Foundation.global.namespace;
|
|
|
|
if (namespace.length > 0) {
|
|
return el.data(namespace + '-' + data_attr_name);
|
|
}
|
|
|
|
return el.data(data_attr_name);
|
|
};
|
|
|
|
var cached_options = data_options(el);
|
|
|
|
if (typeof cached_options === 'object') {
|
|
return cached_options;
|
|
}
|
|
|
|
opts_arr = (cached_options || ':').split(';');
|
|
ii = opts_arr.length;
|
|
|
|
function isNumber (o) {
|
|
return !isNaN (o - 0) && o !== null && o !== '' && o !== false && o !== true;
|
|
}
|
|
|
|
function trim (str) {
|
|
if (typeof str === 'string') {
|
|
return $.trim(str);
|
|
}
|
|
return str;
|
|
}
|
|
|
|
while (ii--) {
|
|
p = opts_arr[ii].split(':');
|
|
p = [p[0], p.slice(1).join(':')];
|
|
|
|
if (/true/i.test(p[1])) {
|
|
p[1] = true;
|
|
}
|
|
if (/false/i.test(p[1])) {
|
|
p[1] = false;
|
|
}
|
|
if (isNumber(p[1])) {
|
|
if (p[1].indexOf('.') === -1) {
|
|
p[1] = parseInt(p[1], 10);
|
|
} else {
|
|
p[1] = parseFloat(p[1]);
|
|
}
|
|
}
|
|
|
|
if (p.length === 2 && p[0].length > 0) {
|
|
opts[trim(p[0])] = trim(p[1]);
|
|
}
|
|
}
|
|
|
|
return opts;
|
|
},
|
|
|
|
// Description:
|
|
// Adds JS-recognizable media queries
|
|
//
|
|
// Arguments:
|
|
// Media (String): Key string for the media query to be stored as in
|
|
// Foundation.media_queries
|
|
//
|
|
// Class (String): Class name for the generated <meta> tag
|
|
register_media : function (media, media_class) {
|
|
if (Foundation.media_queries[media] === undefined) {
|
|
$('head').append('<meta class="' + media_class + '"/>');
|
|
Foundation.media_queries[media] = removeQuotes($('.' + media_class).css('font-family'));
|
|
}
|
|
},
|
|
|
|
// Description:
|
|
// Add custom CSS within a JS-defined media query
|
|
//
|
|
// Arguments:
|
|
// Rule (String): CSS rule to be appended to the document.
|
|
//
|
|
// Media (String): Optional media query string for the CSS rule to be
|
|
// nested under.
|
|
add_custom_rule : function (rule, media) {
|
|
if (media === undefined && Foundation.stylesheet) {
|
|
Foundation.stylesheet.insertRule(rule, Foundation.stylesheet.cssRules.length);
|
|
} else {
|
|
var query = Foundation.media_queries[media];
|
|
|
|
if (query !== undefined) {
|
|
Foundation.stylesheet.insertRule('@media ' +
|
|
Foundation.media_queries[media] + '{ ' + rule + ' }');
|
|
}
|
|
}
|
|
},
|
|
|
|
// Description:
|
|
// Performs a callback function when an image is fully loaded
|
|
//
|
|
// Arguments:
|
|
// Image (jQuery Object): Image(s) to check if loaded.
|
|
//
|
|
// Callback (Function): Function to execute when image is fully loaded.
|
|
image_loaded : function (images, callback) {
|
|
var self = this,
|
|
unloaded = images.length;
|
|
|
|
if (unloaded === 0) {
|
|
callback(images);
|
|
}
|
|
|
|
images.each(function () {
|
|
single_image_loaded(self.S(this), function () {
|
|
unloaded -= 1;
|
|
if (unloaded === 0) {
|
|
callback(images);
|
|
}
|
|
});
|
|
});
|
|
},
|
|
|
|
// Description:
|
|
// Returns a random, alphanumeric string
|
|
//
|
|
// Arguments:
|
|
// Length (Integer): Length of string to be generated. Defaults to random
|
|
// integer.
|
|
//
|
|
// Returns:
|
|
// Rand (String): Pseudo-random, alphanumeric string.
|
|
random_str : function () {
|
|
if (!this.fidx) {
|
|
this.fidx = 0;
|
|
}
|
|
this.prefix = this.prefix || [(this.name || 'F'), (+new Date).toString(36)].join('-');
|
|
|
|
return this.prefix + (this.fidx++).toString(36);
|
|
},
|
|
|
|
// Description:
|
|
// Helper for window.matchMedia
|
|
//
|
|
// Arguments:
|
|
// mq (String): Media query
|
|
//
|
|
// Returns:
|
|
// (Boolean): Whether the media query passes or not
|
|
match : function (mq) {
|
|
return window.matchMedia(mq).matches;
|
|
},
|
|
|
|
// Description:
|
|
// Helpers for checking Foundation default media queries with JS
|
|
//
|
|
// Returns:
|
|
// (Boolean): Whether the media query passes or not
|
|
|
|
is_small_up : function () {
|
|
return this.match(Foundation.media_queries.small);
|
|
},
|
|
|
|
is_medium_up : function () {
|
|
return this.match(Foundation.media_queries.medium);
|
|
},
|
|
|
|
is_large_up : function () {
|
|
return this.match(Foundation.media_queries.large);
|
|
},
|
|
|
|
is_xlarge_up : function () {
|
|
return this.match(Foundation.media_queries.xlarge);
|
|
},
|
|
|
|
is_xxlarge_up : function () {
|
|
return this.match(Foundation.media_queries.xxlarge);
|
|
},
|
|
|
|
is_small_only : function () {
|
|
return !this.is_medium_up() && !this.is_large_up() && !this.is_xlarge_up() && !this.is_xxlarge_up();
|
|
},
|
|
|
|
is_medium_only : function () {
|
|
return this.is_medium_up() && !this.is_large_up() && !this.is_xlarge_up() && !this.is_xxlarge_up();
|
|
},
|
|
|
|
is_large_only : function () {
|
|
return this.is_medium_up() && this.is_large_up() && !this.is_xlarge_up() && !this.is_xxlarge_up();
|
|
},
|
|
|
|
is_xlarge_only : function () {
|
|
return this.is_medium_up() && this.is_large_up() && this.is_xlarge_up() && !this.is_xxlarge_up();
|
|
},
|
|
|
|
is_xxlarge_only : function () {
|
|
return this.is_medium_up() && this.is_large_up() && this.is_xlarge_up() && this.is_xxlarge_up();
|
|
}
|
|
}
|
|
};
|
|
|
|
$.fn.foundation = function () {
|
|
var args = Array.prototype.slice.call(arguments, 0);
|
|
|
|
return this.each(function () {
|
|
Foundation.init.apply(Foundation, [this].concat(args));
|
|
return this;
|
|
});
|
|
};
|
|
|
|
}(jQuery, window, window.document));
|
|
|
|
;(function ($, window, document, undefined) {
|
|
'use strict';
|
|
|
|
Foundation.libs.topbar = {
|
|
name : 'topbar',
|
|
|
|
version : '5.5.1',
|
|
|
|
settings : {
|
|
index : 0,
|
|
sticky_class : 'sticky',
|
|
custom_back_text : true,
|
|
back_text : 'Back',
|
|
mobile_show_parent_link : true,
|
|
is_hover : true,
|
|
scrolltop : true, // jump to top when sticky nav menu toggle is clicked
|
|
sticky_on : 'all'
|
|
},
|
|
|
|
init : function (section, method, options) {
|
|
Foundation.inherit(this, 'add_custom_rule register_media throttle');
|
|
var self = this;
|
|
|
|
self.register_media('topbar', 'foundation-mq-topbar');
|
|
|
|
this.bindings(method, options);
|
|
|
|
self.S('[' + this.attr_name() + ']', this.scope).each(function () {
|
|
var topbar = $(this),
|
|
settings = topbar.data(self.attr_name(true) + '-init'),
|
|
section = self.S('section, .top-bar-section', this);
|
|
topbar.data('index', 0);
|
|
var topbarContainer = topbar.parent();
|
|
if (topbarContainer.hasClass('fixed') || self.is_sticky(topbar, topbarContainer, settings) ) {
|
|
self.settings.sticky_class = settings.sticky_class;
|
|
self.settings.sticky_topbar = topbar;
|
|
topbar.data('height', topbarContainer.outerHeight());
|
|
topbar.data('stickyoffset', topbarContainer.offset().top);
|
|
} else {
|
|
topbar.data('height', topbar.outerHeight());
|
|
}
|
|
|
|
if (!settings.assembled) {
|
|
self.assemble(topbar);
|
|
}
|
|
|
|
if (settings.is_hover) {
|
|
self.S('.has-dropdown', topbar).addClass('not-click');
|
|
} else {
|
|
self.S('.has-dropdown', topbar).removeClass('not-click');
|
|
}
|
|
|
|
// Pad body when sticky (scrolled) or fixed.
|
|
self.add_custom_rule('.f-topbar-fixed { padding-top: ' + topbar.data('height') + 'px }');
|
|
|
|
if (topbarContainer.hasClass('fixed')) {
|
|
self.S('body').addClass('f-topbar-fixed');
|
|
}
|
|
});
|
|
|
|
},
|
|
|
|
is_sticky : function (topbar, topbarContainer, settings) {
|
|
var sticky = topbarContainer.hasClass(settings.sticky_class);
|
|
var smallMatch = matchMedia(Foundation.media_queries.small).matches;
|
|
var medMatch = matchMedia(Foundation.media_queries.medium).matches;
|
|
var lrgMatch = matchMedia(Foundation.media_queries.large).matches;
|
|
|
|
if (sticky && settings.sticky_on === 'all') {
|
|
return true;
|
|
}
|
|
if (sticky && this.small() && settings.sticky_on.indexOf('small') !== -1) {
|
|
if (smallMatch && !medMatch && !lrgMatch) { return true; }
|
|
}
|
|
if (sticky && this.medium() && settings.sticky_on.indexOf('medium') !== -1) {
|
|
if (smallMatch && medMatch && !lrgMatch) { return true; }
|
|
}
|
|
if (sticky && this.large() && settings.sticky_on.indexOf('large') !== -1) {
|
|
if (smallMatch && medMatch && lrgMatch) { return true; }
|
|
}
|
|
|
|
// fix for iOS browsers
|
|
if (sticky && navigator.userAgent.match(/(iPad|iPhone|iPod)/g)) {
|
|
return true;
|
|
}
|
|
return false;
|
|
},
|
|
|
|
toggle : function (toggleEl) {
|
|
var self = this,
|
|
topbar;
|
|
|
|
if (toggleEl) {
|
|
topbar = self.S(toggleEl).closest('[' + this.attr_name() + ']');
|
|
} else {
|
|
topbar = self.S('[' + this.attr_name() + ']');
|
|
}
|
|
|
|
var settings = topbar.data(this.attr_name(true) + '-init');
|
|
|
|
var section = self.S('section, .top-bar-section', topbar);
|
|
|
|
if (self.breakpoint()) {
|
|
if (!self.rtl) {
|
|
section.css({left : '0%'});
|
|
$('>.name', section).css({left : '100%'});
|
|
} else {
|
|
section.css({right : '0%'});
|
|
$('>.name', section).css({right : '100%'});
|
|
}
|
|
|
|
self.S('li.moved', section).removeClass('moved');
|
|
topbar.data('index', 0);
|
|
|
|
topbar
|
|
.toggleClass('expanded')
|
|
.css('height', '');
|
|
}
|
|
|
|
if (settings.scrolltop) {
|
|
if (!topbar.hasClass('expanded')) {
|
|
if (topbar.hasClass('fixed')) {
|
|
topbar.parent().addClass('fixed');
|
|
topbar.removeClass('fixed');
|
|
self.S('body').addClass('f-topbar-fixed');
|
|
}
|
|
} else if (topbar.parent().hasClass('fixed')) {
|
|
if (settings.scrolltop) {
|
|
topbar.parent().removeClass('fixed');
|
|
topbar.addClass('fixed');
|
|
self.S('body').removeClass('f-topbar-fixed');
|
|
|
|
window.scrollTo(0, 0);
|
|
} else {
|
|
topbar.parent().removeClass('expanded');
|
|
}
|
|
}
|
|
} else {
|
|
if (self.is_sticky(topbar, topbar.parent(), settings)) {
|
|
topbar.parent().addClass('fixed');
|
|
}
|
|
|
|
if (topbar.parent().hasClass('fixed')) {
|
|
if (!topbar.hasClass('expanded')) {
|
|
topbar.removeClass('fixed');
|
|
topbar.parent().removeClass('expanded');
|
|
self.update_sticky_positioning();
|
|
} else {
|
|
topbar.addClass('fixed');
|
|
topbar.parent().addClass('expanded');
|
|
self.S('body').addClass('f-topbar-fixed');
|
|
}
|
|
}
|
|
}
|
|
},
|
|
|
|
timer : null,
|
|
|
|
events : function (bar) {
|
|
var self = this,
|
|
S = this.S;
|
|
|
|
S(this.scope)
|
|
.off('.topbar')
|
|
.on('click.fndtn.topbar', '[' + this.attr_name() + '] .toggle-topbar', function (e) {
|
|
e.preventDefault();
|
|
self.toggle(this);
|
|
})
|
|
.on('click.fndtn.topbar', '.top-bar .top-bar-section li a[href^="#"],[' + this.attr_name() + '] .top-bar-section li a[href^="#"]', function (e) {
|
|
var li = $(this).closest('li');
|
|
if (self.breakpoint() && !li.hasClass('back') && !li.hasClass('has-dropdown')) {
|
|
self.toggle();
|
|
}
|
|
})
|
|
.on('click.fndtn.topbar', '[' + this.attr_name() + '] li.has-dropdown', function (e) {
|
|
var li = S(this),
|
|
target = S(e.target),
|
|
topbar = li.closest('[' + self.attr_name() + ']'),
|
|
settings = topbar.data(self.attr_name(true) + '-init');
|
|
|
|
if (target.data('revealId')) {
|
|
self.toggle();
|
|
return;
|
|
}
|
|
|
|
if (self.breakpoint()) {
|
|
return;
|
|
}
|
|
|
|
if (settings.is_hover && !Modernizr.touch) {
|
|
return;
|
|
}
|
|
|
|
e.stopImmediatePropagation();
|
|
|
|
if (li.hasClass('hover')) {
|
|
li
|
|
.removeClass('hover')
|
|
.find('li')
|
|
.removeClass('hover');
|
|
|
|
li.parents('li.hover')
|
|
.removeClass('hover');
|
|
} else {
|
|
li.addClass('hover');
|
|
|
|
$(li).siblings().removeClass('hover');
|
|
|
|
if (target[0].nodeName === 'A' && target.parent().hasClass('has-dropdown')) {
|
|
e.preventDefault();
|
|
}
|
|
}
|
|
})
|
|
.on('click.fndtn.topbar', '[' + this.attr_name() + '] .has-dropdown>a', function (e) {
|
|
if (self.breakpoint()) {
|
|
|
|
e.preventDefault();
|
|
|
|
var $this = S(this),
|
|
topbar = $this.closest('[' + self.attr_name() + ']'),
|
|
section = topbar.find('section, .top-bar-section'),
|
|
dropdownHeight = $this.next('.dropdown').outerHeight(),
|
|
$selectedLi = $this.closest('li');
|
|
|
|
topbar.data('index', topbar.data('index') + 1);
|
|
$selectedLi.addClass('moved');
|
|
|
|
if (!self.rtl) {
|
|
section.css({left : -(100 * topbar.data('index')) + '%'});
|
|
section.find('>.name').css({left : 100 * topbar.data('index') + '%'});
|
|
} else {
|
|
section.css({right : -(100 * topbar.data('index')) + '%'});
|
|
section.find('>.name').css({right : 100 * topbar.data('index') + '%'});
|
|
}
|
|
|
|
topbar.css('height', $this.siblings('ul').outerHeight(true) + topbar.data('height'));
|
|
}
|
|
});
|
|
|
|
S(window).off('.topbar').on('resize.fndtn.topbar', self.throttle(function () {
|
|
self.resize.call(self);
|
|
}, 50)).trigger('resize').trigger('resize.fndtn.topbar').load(function () {
|
|
// Ensure that the offset is calculated after all of the pages resources have loaded
|
|
S(this).trigger('resize.fndtn.topbar');
|
|
});
|
|
|
|
S('body').off('.topbar').on('click.fndtn.topbar', function (e) {
|
|
var parent = S(e.target).closest('li').closest('li.hover');
|
|
|
|
if (parent.length > 0) {
|
|
return;
|
|
}
|
|
|
|
S('[' + self.attr_name() + '] li.hover').removeClass('hover');
|
|
});
|
|
|
|
// Go up a level on Click
|
|
S(this.scope).on('click.fndtn.topbar', '[' + this.attr_name() + '] .has-dropdown .back', function (e) {
|
|
e.preventDefault();
|
|
|
|
var $this = S(this),
|
|
topbar = $this.closest('[' + self.attr_name() + ']'),
|
|
section = topbar.find('section, .top-bar-section'),
|
|
settings = topbar.data(self.attr_name(true) + '-init'),
|
|
$movedLi = $this.closest('li.moved'),
|
|
$previousLevelUl = $movedLi.parent();
|
|
|
|
topbar.data('index', topbar.data('index') - 1);
|
|
|
|
if (!self.rtl) {
|
|
section.css({left : -(100 * topbar.data('index')) + '%'});
|
|
section.find('>.name').css({left : 100 * topbar.data('index') + '%'});
|
|
} else {
|
|
section.css({right : -(100 * topbar.data('index')) + '%'});
|
|
section.find('>.name').css({right : 100 * topbar.data('index') + '%'});
|
|
}
|
|
|
|
if (topbar.data('index') === 0) {
|
|
topbar.css('height', '');
|
|
} else {
|
|
topbar.css('height', $previousLevelUl.outerHeight(true) + topbar.data('height'));
|
|
}
|
|
|
|
setTimeout(function () {
|
|
$movedLi.removeClass('moved');
|
|
}, 300);
|
|
});
|
|
|
|
// Show dropdown menus when their items are focused
|
|
S(this.scope).find('.dropdown a')
|
|
.focus(function () {
|
|
$(this).parents('.has-dropdown').addClass('hover');
|
|
})
|
|
.blur(function () {
|
|
$(this).parents('.has-dropdown').removeClass('hover');
|
|
});
|
|
},
|
|
|
|
resize : function () {
|
|
var self = this;
|
|
self.S('[' + this.attr_name() + ']').each(function () {
|
|
var topbar = self.S(this),
|
|
settings = topbar.data(self.attr_name(true) + '-init');
|
|
|
|
var stickyContainer = topbar.parent('.' + self.settings.sticky_class);
|
|
var stickyOffset;
|
|
|
|
if (!self.breakpoint()) {
|
|
var doToggle = topbar.hasClass('expanded');
|
|
topbar
|
|
.css('height', '')
|
|
.removeClass('expanded')
|
|
.find('li')
|
|
.removeClass('hover');
|
|
|
|
if (doToggle) {
|
|
self.toggle(topbar);
|
|
}
|
|
}
|
|
|
|
if (self.is_sticky(topbar, stickyContainer, settings)) {
|
|
if (stickyContainer.hasClass('fixed')) {
|
|
// Remove the fixed to allow for correct calculation of the offset.
|
|
stickyContainer.removeClass('fixed');
|
|
|
|
stickyOffset = stickyContainer.offset().top;
|
|
if (self.S(document.body).hasClass('f-topbar-fixed')) {
|
|
stickyOffset -= topbar.data('height');
|
|
}
|
|
|
|
topbar.data('stickyoffset', stickyOffset);
|
|
stickyContainer.addClass('fixed');
|
|
} else {
|
|
stickyOffset = stickyContainer.offset().top;
|
|
topbar.data('stickyoffset', stickyOffset);
|
|
}
|
|
}
|
|
|
|
});
|
|
},
|
|
|
|
breakpoint : function () {
|
|
return !matchMedia(Foundation.media_queries['topbar']).matches;
|
|
},
|
|
|
|
small : function () {
|
|
return matchMedia(Foundation.media_queries['small']).matches;
|
|
},
|
|
|
|
medium : function () {
|
|
return matchMedia(Foundation.media_queries['medium']).matches;
|
|
},
|
|
|
|
large : function () {
|
|
return matchMedia(Foundation.media_queries['large']).matches;
|
|
},
|
|
|
|
assemble : function (topbar) {
|
|
var self = this,
|
|
settings = topbar.data(this.attr_name(true) + '-init'),
|
|
section = self.S('section, .top-bar-section', topbar);
|
|
|
|
// Pull element out of the DOM for manipulation
|
|
section.detach();
|
|
|
|
self.S('.has-dropdown>a', section).each(function () {
|
|
var $link = self.S(this),
|
|
$dropdown = $link.siblings('.dropdown'),
|
|
url = $link.attr('href'),
|
|
$titleLi;
|
|
|
|
if (!$dropdown.find('.title.back').length) {
|
|
|
|
if (settings.mobile_show_parent_link == true && url) {
|
|
$titleLi = $('<li class="title back js-generated"><h5><a href="javascript:void(0)"></a></h5></li><li class="parent-link hide-for-large-up"><a class="parent-link js-generated" href="' + url + '">' + $link.html() +'</a></li>');
|
|
} else {
|
|
$titleLi = $('<li class="title back js-generated"><h5><a href="javascript:void(0)"></a></h5>');
|
|
}
|
|
|
|
// Copy link to subnav
|
|
if (settings.custom_back_text == true) {
|
|
$('h5>a', $titleLi).html(settings.back_text);
|
|
} else {
|
|
$('h5>a', $titleLi).html('« ' + $link.html());
|
|
}
|
|
$dropdown.prepend($titleLi);
|
|
}
|
|
});
|
|
|
|
// Put element back in the DOM
|
|
section.appendTo(topbar);
|
|
|
|
// check for sticky
|
|
this.sticky();
|
|
|
|
this.assembled(topbar);
|
|
},
|
|
|
|
assembled : function (topbar) {
|
|
topbar.data(this.attr_name(true), $.extend({}, topbar.data(this.attr_name(true)), {assembled : true}));
|
|
},
|
|
|
|
height : function (ul) {
|
|
var total = 0,
|
|
self = this;
|
|
|
|
$('> li', ul).each(function () {
|
|
total += self.S(this).outerHeight(true);
|
|
});
|
|
|
|
return total;
|
|
},
|
|
|
|
sticky : function () {
|
|
var self = this;
|
|
|
|
this.S(window).on('scroll', function () {
|
|
self.update_sticky_positioning();
|
|
});
|
|
},
|
|
|
|
update_sticky_positioning : function () {
|
|
var klass = '.' + this.settings.sticky_class,
|
|
$window = this.S(window),
|
|
self = this;
|
|
|
|
if (self.settings.sticky_topbar && self.is_sticky(this.settings.sticky_topbar, this.settings.sticky_topbar.parent(), this.settings)) {
|
|
var distance = this.settings.sticky_topbar.data('stickyoffset');
|
|
if (!self.S(klass).hasClass('expanded')) {
|
|
if ($window.scrollTop() > (distance)) {
|
|
if (!self.S(klass).hasClass('fixed')) {
|
|
self.S(klass).addClass('fixed');
|
|
self.S('body').addClass('f-topbar-fixed');
|
|
}
|
|
} else if ($window.scrollTop() <= distance) {
|
|
if (self.S(klass).hasClass('fixed')) {
|
|
self.S(klass).removeClass('fixed');
|
|
self.S('body').removeClass('f-topbar-fixed');
|
|
}
|
|
}
|
|
}
|
|
}
|
|
},
|
|
|
|
off : function () {
|
|
this.S(this.scope).off('.fndtn.topbar');
|
|
this.S(window).off('.fndtn.topbar');
|
|
},
|
|
|
|
reflow : function () {}
|
|
};
|
|
}(jQuery, window, window.document));
|
|
|
|
;(function ($, window, document, undefined) {
|
|
'use strict';
|
|
|
|
Foundation.libs.clearing = {
|
|
name : 'clearing',
|
|
|
|
version : '5.5.1',
|
|
|
|
settings : {
|
|
templates : {
|
|
viewing : '<a href="#" class="clearing-close">×</a>' +
|
|
'<div class="visible-img" style="display: none"><div class="clearing-touch-label"></div><img src="data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs%3D" alt="" />' +
|
|
'<p class="clearing-caption"></p><a href="#" class="clearing-main-prev"><span></span></a>' +
|
|
'<a href="#" class="clearing-main-next"><span></span></a></div>'
|
|
},
|
|
|
|
// comma delimited list of selectors that, on click, will close clearing,
|
|
// add 'div.clearing-blackout, div.visible-img' to close on background click
|
|
close_selectors : '.clearing-close, div.clearing-blackout',
|
|
|
|
// Default to the entire li element.
|
|
open_selectors : '',
|
|
|
|
// Image will be skipped in carousel.
|
|
skip_selector : '',
|
|
|
|
touch_label : '',
|
|
|
|
// event initializers and locks
|
|
init : false,
|
|
locked : false
|
|
},
|
|
|
|
init : function (scope, method, options) {
|
|
var self = this;
|
|
Foundation.inherit(this, 'throttle image_loaded');
|
|
|
|
this.bindings(method, options);
|
|
|
|
if (self.S(this.scope).is('[' + this.attr_name() + ']')) {
|
|
this.assemble(self.S('li', this.scope));
|
|
} else {
|
|
self.S('[' + this.attr_name() + ']', this.scope).each(function () {
|
|
self.assemble(self.S('li', this));
|
|
});
|
|
}
|
|
},
|
|
|
|
events : function (scope) {
|
|
var self = this,
|
|
S = self.S,
|
|
$scroll_container = $('.scroll-container');
|
|
|
|
if ($scroll_container.length > 0) {
|
|
this.scope = $scroll_container;
|
|
}
|
|
|
|
S(this.scope)
|
|
.off('.clearing')
|
|
.on('click.fndtn.clearing', 'ul[' + this.attr_name() + '] li ' + this.settings.open_selectors,
|
|
function (e, current, target) {
|
|
var current = current || S(this),
|
|
target = target || current,
|
|
next = current.next('li'),
|
|
settings = current.closest('[' + self.attr_name() + ']').data(self.attr_name(true) + '-init'),
|
|
image = S(e.target);
|
|
|
|
e.preventDefault();
|
|
|
|
if (!settings) {
|
|
self.init();
|
|
settings = current.closest('[' + self.attr_name() + ']').data(self.attr_name(true) + '-init');
|
|
}
|
|
|
|
// if clearing is open and the current image is
|
|
// clicked, go to the next image in sequence
|
|
if (target.hasClass('visible') &&
|
|
current[0] === target[0] &&
|
|
next.length > 0 && self.is_open(current)) {
|
|
target = next;
|
|
image = S('img', target);
|
|
}
|
|
|
|
// set current and target to the clicked li if not otherwise defined.
|
|
self.open(image, current, target);
|
|
self.update_paddles(target);
|
|
})
|
|
|
|
.on('click.fndtn.clearing', '.clearing-main-next',
|
|
function (e) { self.nav(e, 'next') })
|
|
.on('click.fndtn.clearing', '.clearing-main-prev',
|
|
function (e) { self.nav(e, 'prev') })
|
|
.on('click.fndtn.clearing', this.settings.close_selectors,
|
|
function (e) { Foundation.libs.clearing.close(e, this) });
|
|
|
|
$(document).on('keydown.fndtn.clearing',
|
|
function (e) { self.keydown(e) });
|
|
|
|
S(window).off('.clearing').on('resize.fndtn.clearing',
|
|
function () { self.resize() });
|
|
|
|
this.swipe_events(scope);
|
|
},
|
|
|
|
swipe_events : function (scope) {
|
|
var self = this,
|
|
S = self.S;
|
|
|
|
S(this.scope)
|
|
.on('touchstart.fndtn.clearing', '.visible-img', function (e) {
|
|
if (!e.touches) { e = e.originalEvent; }
|
|
var data = {
|
|
start_page_x : e.touches[0].pageX,
|
|
start_page_y : e.touches[0].pageY,
|
|
start_time : (new Date()).getTime(),
|
|
delta_x : 0,
|
|
is_scrolling : undefined
|
|
};
|
|
|
|
S(this).data('swipe-transition', data);
|
|
e.stopPropagation();
|
|
})
|
|
.on('touchmove.fndtn.clearing', '.visible-img', function (e) {
|
|
if (!e.touches) {
|
|
e = e.originalEvent;
|
|
}
|
|
// Ignore pinch/zoom events
|
|
if (e.touches.length > 1 || e.scale && e.scale !== 1) {
|
|
return;
|
|
}
|
|
|
|
var data = S(this).data('swipe-transition');
|
|
|
|
if (typeof data === 'undefined') {
|
|
data = {};
|
|
}
|
|
|
|
data.delta_x = e.touches[0].pageX - data.start_page_x;
|
|
|
|
if (Foundation.rtl) {
|
|
data.delta_x = -data.delta_x;
|
|
}
|
|
|
|
if (typeof data.is_scrolling === 'undefined') {
|
|
data.is_scrolling = !!( data.is_scrolling || Math.abs(data.delta_x) < Math.abs(e.touches[0].pageY - data.start_page_y) );
|
|
}
|
|
|
|
if (!data.is_scrolling && !data.active) {
|
|
e.preventDefault();
|
|
var direction = (data.delta_x < 0) ? 'next' : 'prev';
|
|
data.active = true;
|
|
self.nav(e, direction);
|
|
}
|
|
})
|
|
.on('touchend.fndtn.clearing', '.visible-img', function (e) {
|
|
S(this).data('swipe-transition', {});
|
|
e.stopPropagation();
|
|
});
|
|
},
|
|
|
|
assemble : function ($li) {
|
|
var $el = $li.parent();
|
|
|
|
if ($el.parent().hasClass('carousel')) {
|
|
return;
|
|
}
|
|
|
|
$el.after('<div id="foundationClearingHolder"></div>');
|
|
|
|
var grid = $el.detach(),
|
|
grid_outerHTML = '';
|
|
|
|
if (grid[0] == null) {
|
|
return;
|
|
} else {
|
|
grid_outerHTML = grid[0].outerHTML;
|
|
}
|
|
|
|
var holder = this.S('#foundationClearingHolder'),
|
|
settings = $el.data(this.attr_name(true) + '-init'),
|
|
data = {
|
|
grid : '<div class="carousel">' + grid_outerHTML + '</div>',
|
|
viewing : settings.templates.viewing
|
|
},
|
|
wrapper = '<div class="clearing-assembled"><div>' + data.viewing +
|
|
data.grid + '</div></div>',
|
|
touch_label = this.settings.touch_label;
|
|
|
|
if (Modernizr.touch) {
|
|
wrapper = $(wrapper).find('.clearing-touch-label').html(touch_label).end();
|
|
}
|
|
|
|
holder.after(wrapper).remove();
|
|
},
|
|
|
|
open : function ($image, current, target) {
|
|
var self = this,
|
|
body = $(document.body),
|
|
root = target.closest('.clearing-assembled'),
|
|
container = self.S('div', root).first(),
|
|
visible_image = self.S('.visible-img', container),
|
|
image = self.S('img', visible_image).not($image),
|
|
label = self.S('.clearing-touch-label', container),
|
|
error = false;
|
|
|
|
// Event to disable scrolling on touch devices when Clearing is activated
|
|
$('body').on('touchmove', function (e) {
|
|
e.preventDefault();
|
|
});
|
|
|
|
image.error(function () {
|
|
error = true;
|
|
});
|
|
|
|
function startLoad() {
|
|
setTimeout(function () {
|
|
this.image_loaded(image, function () {
|
|
if (image.outerWidth() === 1 && !error) {
|
|
startLoad.call(this);
|
|
} else {
|
|
cb.call(this, image);
|
|
}
|
|
}.bind(this));
|
|
}.bind(this), 100);
|
|
}
|
|
|
|
function cb (image) {
|
|
var $image = $(image);
|
|
$image.css('visibility', 'visible');
|
|
// toggle the gallery
|
|
body.css('overflow', 'hidden');
|
|
root.addClass('clearing-blackout');
|
|
container.addClass('clearing-container');
|
|
visible_image.show();
|
|
this.fix_height(target)
|
|
.caption(self.S('.clearing-caption', visible_image), self.S('img', target))
|
|
.center_and_label(image, label)
|
|
.shift(current, target, function () {
|
|
target.closest('li').siblings().removeClass('visible');
|
|
target.closest('li').addClass('visible');
|
|
});
|
|
visible_image.trigger('opened.fndtn.clearing')
|
|
}
|
|
|
|
if (!this.locked()) {
|
|
visible_image.trigger('open.fndtn.clearing');
|
|
// set the image to the selected thumbnail
|
|
image
|
|
.attr('src', this.load($image))
|
|
.css('visibility', 'hidden');
|
|
|
|
startLoad.call(this);
|
|
}
|
|
},
|
|
|
|
close : function (e, el) {
|
|
e.preventDefault();
|
|
|
|
var root = (function (target) {
|
|
if (/blackout/.test(target.selector)) {
|
|
return target;
|
|
} else {
|
|
return target.closest('.clearing-blackout');
|
|
}
|
|
}($(el))),
|
|
body = $(document.body), container, visible_image;
|
|
|
|
if (el === e.target && root) {
|
|
body.css('overflow', '');
|
|
container = $('div', root).first();
|
|
visible_image = $('.visible-img', container);
|
|
visible_image.trigger('close.fndtn.clearing');
|
|
this.settings.prev_index = 0;
|
|
$('ul[' + this.attr_name() + ']', root)
|
|
.attr('style', '').closest('.clearing-blackout')
|
|
.removeClass('clearing-blackout');
|
|
container.removeClass('clearing-container');
|
|
visible_image.hide();
|
|
visible_image.trigger('closed.fndtn.clearing');
|
|
}
|
|
|
|
// Event to re-enable scrolling on touch devices
|
|
$('body').off('touchmove');
|
|
|
|
return false;
|
|
},
|
|
|
|
is_open : function (current) {
|
|
return current.parent().prop('style').length > 0;
|
|
},
|
|
|
|
keydown : function (e) {
|
|
var clearing = $('.clearing-blackout ul[' + this.attr_name() + ']'),
|
|
NEXT_KEY = this.rtl ? 37 : 39,
|
|
PREV_KEY = this.rtl ? 39 : 37,
|
|
ESC_KEY = 27;
|
|
|
|
if (e.which === NEXT_KEY) {
|
|
this.go(clearing, 'next');
|
|
}
|
|
if (e.which === PREV_KEY) {
|
|
this.go(clearing, 'prev');
|
|
}
|
|
if (e.which === ESC_KEY) {
|
|
this.S('a.clearing-close').trigger('click').trigger('click.fndtn.clearing');
|
|
}
|
|
},
|
|
|
|
nav : function (e, direction) {
|
|
var clearing = $('ul[' + this.attr_name() + ']', '.clearing-blackout');
|
|
|
|
e.preventDefault();
|
|
this.go(clearing, direction);
|
|
},
|
|
|
|
resize : function () {
|
|
var image = $('img', '.clearing-blackout .visible-img'),
|
|
label = $('.clearing-touch-label', '.clearing-blackout');
|
|
|
|
if (image.length) {
|
|
this.center_and_label(image, label);
|
|
image.trigger('resized.fndtn.clearing')
|
|
}
|
|
},
|
|
|
|
// visual adjustments
|
|
fix_height : function (target) {
|
|
var lis = target.parent().children(),
|
|
self = this;
|
|
|
|
lis.each(function () {
|
|
var li = self.S(this),
|
|
image = li.find('img');
|
|
|
|
if (li.height() > image.outerHeight()) {
|
|
li.addClass('fix-height');
|
|
}
|
|
})
|
|
.closest('ul')
|
|
.width(lis.length * 100 + '%');
|
|
|
|
return this;
|
|
},
|
|
|
|
update_paddles : function (target) {
|
|
target = target.closest('li');
|
|
var visible_image = target
|
|
.closest('.carousel')
|
|
.siblings('.visible-img');
|
|
|
|
if (target.next().length > 0) {
|
|
this.S('.clearing-main-next', visible_image).removeClass('disabled');
|
|
} else {
|
|
this.S('.clearing-main-next', visible_image).addClass('disabled');
|
|
}
|
|
|
|
if (target.prev().length > 0) {
|
|
this.S('.clearing-main-prev', visible_image).removeClass('disabled');
|
|
} else {
|
|
this.S('.clearing-main-prev', visible_image).addClass('disabled');
|
|
}
|
|
},
|
|
|
|
center_and_label : function (target, label) {
|
|
if (!this.rtl && label.length > 0) {
|
|
label.css({
|
|
marginLeft : -(label.outerWidth() / 2),
|
|
marginTop : -(target.outerHeight() / 2)-label.outerHeight()-10
|
|
});
|
|
} else {
|
|
label.css({
|
|
marginRight : -(label.outerWidth() / 2),
|
|
marginTop : -(target.outerHeight() / 2)-label.outerHeight()-10,
|
|
left: 'auto',
|
|
right: '50%'
|
|
});
|
|
}
|
|
return this;
|
|
},
|
|
|
|
// image loading and preloading
|
|
|
|
load : function ($image) {
|
|
var href;
|
|
|
|
if ($image[0].nodeName === 'A') {
|
|
href = $image.attr('href');
|
|
} else {
|
|
href = $image.closest('a').attr('href');
|
|
}
|
|
|
|
this.preload($image);
|
|
|
|
if (href) {
|
|
return href;
|
|
}
|
|
return $image.attr('src');
|
|
},
|
|
|
|
preload : function ($image) {
|
|
this
|
|
.img($image.closest('li').next())
|
|
.img($image.closest('li').prev());
|
|
},
|
|
|
|
img : function (img) {
|
|
if (img.length) {
|
|
var new_img = new Image(),
|
|
new_a = this.S('a', img);
|
|
|
|
if (new_a.length) {
|
|
new_img.src = new_a.attr('href');
|
|
} else {
|
|
new_img.src = this.S('img', img).attr('src');
|
|
}
|
|
}
|
|
return this;
|
|
},
|
|
|
|
// image caption
|
|
|
|
caption : function (container, $image) {
|
|
var caption = $image.attr('data-caption');
|
|
|
|
if (caption) {
|
|
container
|
|
.html(caption)
|
|
.show();
|
|
} else {
|
|
container
|
|
.text('')
|
|
.hide();
|
|
}
|
|
return this;
|
|
},
|
|
|
|
// directional methods
|
|
|
|
go : function ($ul, direction) {
|
|
var current = this.S('.visible', $ul),
|
|
target = current[direction]();
|
|
|
|
// Check for skip selector.
|
|
if (this.settings.skip_selector && target.find(this.settings.skip_selector).length != 0) {
|
|
target = target[direction]();
|
|
}
|
|
|
|
if (target.length) {
|
|
this.S('img', target)
|
|
.trigger('click', [current, target]).trigger('click.fndtn.clearing', [current, target])
|
|
.trigger('change.fndtn.clearing');
|
|
}
|
|
},
|
|
|
|
shift : function (current, target, callback) {
|
|
var clearing = target.parent(),
|
|
old_index = this.settings.prev_index || target.index(),
|
|
direction = this.direction(clearing, current, target),
|
|
dir = this.rtl ? 'right' : 'left',
|
|
left = parseInt(clearing.css('left'), 10),
|
|
width = target.outerWidth(),
|
|
skip_shift;
|
|
|
|
var dir_obj = {};
|
|
|
|
// we use jQuery animate instead of CSS transitions because we
|
|
// need a callback to unlock the next animation
|
|
// needs support for RTL **
|
|
if (target.index() !== old_index && !/skip/.test(direction)) {
|
|
if (/left/.test(direction)) {
|
|
this.lock();
|
|
dir_obj[dir] = left + width;
|
|
clearing.animate(dir_obj, 300, this.unlock());
|
|
} else if (/right/.test(direction)) {
|
|
this.lock();
|
|
dir_obj[dir] = left - width;
|
|
clearing.animate(dir_obj, 300, this.unlock());
|
|
}
|
|
} else if (/skip/.test(direction)) {
|
|
// the target image is not adjacent to the current image, so
|
|
// do we scroll right or not
|
|
skip_shift = target.index() - this.settings.up_count;
|
|
this.lock();
|
|
|
|
if (skip_shift > 0) {
|
|
dir_obj[dir] = -(skip_shift * width);
|
|
clearing.animate(dir_obj, 300, this.unlock());
|
|
} else {
|
|
dir_obj[dir] = 0;
|
|
clearing.animate(dir_obj, 300, this.unlock());
|
|
}
|
|
}
|
|
|
|
callback();
|
|
},
|
|
|
|
direction : function ($el, current, target) {
|
|
var lis = this.S('li', $el),
|
|
li_width = lis.outerWidth() + (lis.outerWidth() / 4),
|
|
up_count = Math.floor(this.S('.clearing-container').outerWidth() / li_width) - 1,
|
|
target_index = lis.index(target),
|
|
response;
|
|
|
|
this.settings.up_count = up_count;
|
|
|
|
if (this.adjacent(this.settings.prev_index, target_index)) {
|
|
if ((target_index > up_count) && target_index > this.settings.prev_index) {
|
|
response = 'right';
|
|
} else if ((target_index > up_count - 1) && target_index <= this.settings.prev_index) {
|
|
response = 'left';
|
|
} else {
|
|
response = false;
|
|
}
|
|
} else {
|
|
response = 'skip';
|
|
}
|
|
|
|
this.settings.prev_index = target_index;
|
|
|
|
return response;
|
|
},
|
|
|
|
adjacent : function (current_index, target_index) {
|
|
for (var i = target_index + 1; i >= target_index - 1; i--) {
|
|
if (i === current_index) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
},
|
|
|
|
// lock management
|
|
|
|
lock : function () {
|
|
this.settings.locked = true;
|
|
},
|
|
|
|
unlock : function () {
|
|
this.settings.locked = false;
|
|
},
|
|
|
|
locked : function () {
|
|
return this.settings.locked;
|
|
},
|
|
|
|
off : function () {
|
|
this.S(this.scope).off('.fndtn.clearing');
|
|
this.S(window).off('.fndtn.clearing');
|
|
},
|
|
|
|
reflow : function () {
|
|
this.init();
|
|
}
|
|
};
|
|
|
|
}(jQuery, window, window.document));
|
|
|
|
/*
|
|
_ _ _ _
|
|
___| (_) ___| | __ (_)___
|
|
/ __| | |/ __| |/ / | / __|
|
|
\__ \ | | (__| < _ | \__ \
|
|
|___/_|_|\___|_|\_(_)/ |___/
|
|
|__/
|
|
|
|
Version: 1.6.0
|
|
Author: Ken Wheeler
|
|
Website: http://kenwheeler.github.io
|
|
Docs: http://kenwheeler.github.io/slick
|
|
Repo: http://github.com/kenwheeler/slick
|
|
Issues: http://github.com/kenwheeler/slick/issues
|
|
|
|
*/
|
|
/* global window, document, define, jQuery, setInterval, clearInterval */
|
|
(function(factory) {
|
|
'use strict';
|
|
if (typeof define === 'function' && define.amd) {
|
|
define(['jquery'], factory);
|
|
} else if (typeof exports !== 'undefined') {
|
|
module.exports = factory(require('jquery'));
|
|
} else {
|
|
factory(jQuery);
|
|
}
|
|
|
|
}(function($) {
|
|
'use strict';
|
|
var Slick = window.Slick || {};
|
|
|
|
Slick = (function() {
|
|
|
|
var instanceUid = 0;
|
|
|
|
function Slick(element, settings) {
|
|
|
|
var _ = this, dataSettings;
|
|
|
|
_.defaults = {
|
|
accessibility: true,
|
|
adaptiveHeight: false,
|
|
appendArrows: $(element),
|
|
appendDots: $(element),
|
|
arrows: true,
|
|
asNavFor: null,
|
|
prevArrow: '<button type="button" data-role="none" class="slick-prev" aria-label="Previous" tabindex="0" role="button">Previous</button>',
|
|
nextArrow: '<button type="button" data-role="none" class="slick-next" aria-label="Next" tabindex="0" role="button">Next</button>',
|
|
autoplay: false,
|
|
autoplaySpeed: 3000,
|
|
centerMode: false,
|
|
centerPadding: '50px',
|
|
cssEase: 'ease',
|
|
customPaging: function(slider, i) {
|
|
return $('<button type="button" data-role="none" role="button" tabindex="0" />').text(i + 1);
|
|
},
|
|
dots: false,
|
|
dotsClass: 'slick-dots',
|
|
draggable: true,
|
|
easing: 'linear',
|
|
edgeFriction: 0.35,
|
|
fade: false,
|
|
focusOnSelect: false,
|
|
infinite: true,
|
|
initialSlide: 0,
|
|
lazyLoad: 'ondemand',
|
|
mobileFirst: false,
|
|
pauseOnHover: true,
|
|
pauseOnFocus: true,
|
|
pauseOnDotsHover: false,
|
|
respondTo: 'window',
|
|
responsive: null,
|
|
rows: 1,
|
|
rtl: false,
|
|
slide: '',
|
|
slidesPerRow: 1,
|
|
slidesToShow: 1,
|
|
slidesToScroll: 1,
|
|
speed: 500,
|
|
swipe: true,
|
|
swipeToSlide: false,
|
|
touchMove: true,
|
|
touchThreshold: 5,
|
|
useCSS: true,
|
|
useTransform: true,
|
|
variableWidth: false,
|
|
vertical: false,
|
|
verticalSwiping: false,
|
|
waitForAnimate: true,
|
|
zIndex: 1000
|
|
};
|
|
|
|
_.initials = {
|
|
animating: false,
|
|
dragging: false,
|
|
autoPlayTimer: null,
|
|
currentDirection: 0,
|
|
currentLeft: null,
|
|
currentSlide: 0,
|
|
direction: 1,
|
|
$dots: null,
|
|
listWidth: null,
|
|
listHeight: null,
|
|
loadIndex: 0,
|
|
$nextArrow: null,
|
|
$prevArrow: null,
|
|
slideCount: null,
|
|
slideWidth: null,
|
|
$slideTrack: null,
|
|
$slides: null,
|
|
sliding: false,
|
|
slideOffset: 0,
|
|
swipeLeft: null,
|
|
$list: null,
|
|
touchObject: {},
|
|
transformsEnabled: false,
|
|
unslicked: false
|
|
};
|
|
|
|
$.extend(_, _.initials);
|
|
|
|
_.activeBreakpoint = null;
|
|
_.animType = null;
|
|
_.animProp = null;
|
|
_.breakpoints = [];
|
|
_.breakpointSettings = [];
|
|
_.cssTransitions = false;
|
|
_.focussed = false;
|
|
_.interrupted = false;
|
|
_.hidden = 'hidden';
|
|
_.paused = true;
|
|
_.positionProp = null;
|
|
_.respondTo = null;
|
|
_.rowCount = 1;
|
|
_.shouldClick = true;
|
|
_.$slider = $(element);
|
|
_.$slidesCache = null;
|
|
_.transformType = null;
|
|
_.transitionType = null;
|
|
_.visibilityChange = 'visibilitychange';
|
|
_.windowWidth = 0;
|
|
_.windowTimer = null;
|
|
|
|
dataSettings = $(element).data('slick') || {};
|
|
|
|
_.options = $.extend({}, _.defaults, settings, dataSettings);
|
|
|
|
_.currentSlide = _.options.initialSlide;
|
|
|
|
_.originalSettings = _.options;
|
|
|
|
if (typeof document.mozHidden !== 'undefined') {
|
|
_.hidden = 'mozHidden';
|
|
_.visibilityChange = 'mozvisibilitychange';
|
|
} else if (typeof document.webkitHidden !== 'undefined') {
|
|
_.hidden = 'webkitHidden';
|
|
_.visibilityChange = 'webkitvisibilitychange';
|
|
}
|
|
|
|
_.autoPlay = $.proxy(_.autoPlay, _);
|
|
_.autoPlayClear = $.proxy(_.autoPlayClear, _);
|
|
_.autoPlayIterator = $.proxy(_.autoPlayIterator, _);
|
|
_.changeSlide = $.proxy(_.changeSlide, _);
|
|
_.clickHandler = $.proxy(_.clickHandler, _);
|
|
_.selectHandler = $.proxy(_.selectHandler, _);
|
|
_.setPosition = $.proxy(_.setPosition, _);
|
|
_.swipeHandler = $.proxy(_.swipeHandler, _);
|
|
_.dragHandler = $.proxy(_.dragHandler, _);
|
|
_.keyHandler = $.proxy(_.keyHandler, _);
|
|
|
|
_.instanceUid = instanceUid++;
|
|
|
|
// A simple way to check for HTML strings
|
|
// Strict HTML recognition (must start with <)
|
|
// Extracted from jQuery v1.11 source
|
|
_.htmlExpr = /^(?:\s*(<[\w\W]+>)[^>]*)$/;
|
|
|
|
|
|
_.registerBreakpoints();
|
|
_.init(true);
|
|
|
|
}
|
|
|
|
return Slick;
|
|
|
|
}());
|
|
|
|
Slick.prototype.activateADA = function() {
|
|
var _ = this;
|
|
|
|
_.$slideTrack.find('.slick-active').attr({
|
|
'aria-hidden': 'false'
|
|
}).find('a, input, button, select').attr({
|
|
'tabindex': '0'
|
|
});
|
|
|
|
};
|
|
|
|
Slick.prototype.addSlide = Slick.prototype.slickAdd = function(markup, index, addBefore) {
|
|
|
|
var _ = this;
|
|
|
|
if (typeof(index) === 'boolean') {
|
|
addBefore = index;
|
|
index = null;
|
|
} else if (index < 0 || (index >= _.slideCount)) {
|
|
return false;
|
|
}
|
|
|
|
_.unload();
|
|
|
|
if (typeof(index) === 'number') {
|
|
if (index === 0 && _.$slides.length === 0) {
|
|
$(markup).appendTo(_.$slideTrack);
|
|
} else if (addBefore) {
|
|
$(markup).insertBefore(_.$slides.eq(index));
|
|
} else {
|
|
$(markup).insertAfter(_.$slides.eq(index));
|
|
}
|
|
} else {
|
|
if (addBefore === true) {
|
|
$(markup).prependTo(_.$slideTrack);
|
|
} else {
|
|
$(markup).appendTo(_.$slideTrack);
|
|
}
|
|
}
|
|
|
|
_.$slides = _.$slideTrack.children(this.options.slide);
|
|
|
|
_.$slideTrack.children(this.options.slide).detach();
|
|
|
|
_.$slideTrack.append(_.$slides);
|
|
|
|
_.$slides.each(function(index, element) {
|
|
$(element).attr('data-slick-index', index);
|
|
});
|
|
|
|
_.$slidesCache = _.$slides;
|
|
|
|
_.reinit();
|
|
|
|
};
|
|
|
|
Slick.prototype.animateHeight = function() {
|
|
var _ = this;
|
|
if (_.options.slidesToShow === 1 && _.options.adaptiveHeight === true && _.options.vertical === false) {
|
|
var targetHeight = _.$slides.eq(_.currentSlide).outerHeight(true);
|
|
_.$list.animate({
|
|
height: targetHeight
|
|
}, _.options.speed);
|
|
}
|
|
};
|
|
|
|
Slick.prototype.animateSlide = function(targetLeft, callback) {
|
|
|
|
var animProps = {},
|
|
_ = this;
|
|
|
|
_.animateHeight();
|
|
|
|
if (_.options.rtl === true && _.options.vertical === false) {
|
|
targetLeft = -targetLeft;
|
|
}
|
|
if (_.transformsEnabled === false) {
|
|
if (_.options.vertical === false) {
|
|
_.$slideTrack.animate({
|
|
left: targetLeft
|
|
}, _.options.speed, _.options.easing, callback);
|
|
} else {
|
|
_.$slideTrack.animate({
|
|
top: targetLeft
|
|
}, _.options.speed, _.options.easing, callback);
|
|
}
|
|
|
|
} else {
|
|
|
|
if (_.cssTransitions === false) {
|
|
if (_.options.rtl === true) {
|
|
_.currentLeft = -(_.currentLeft);
|
|
}
|
|
$({
|
|
animStart: _.currentLeft
|
|
}).animate({
|
|
animStart: targetLeft
|
|
}, {
|
|
duration: _.options.speed,
|
|
easing: _.options.easing,
|
|
step: function(now) {
|
|
now = Math.ceil(now);
|
|
if (_.options.vertical === false) {
|
|
animProps[_.animType] = 'translate(' +
|
|
now + 'px, 0px)';
|
|
_.$slideTrack.css(animProps);
|
|
} else {
|
|
animProps[_.animType] = 'translate(0px,' +
|
|
now + 'px)';
|
|
_.$slideTrack.css(animProps);
|
|
}
|
|
},
|
|
complete: function() {
|
|
if (callback) {
|
|
callback.call();
|
|
}
|
|
}
|
|
});
|
|
|
|
} else {
|
|
|
|
_.applyTransition();
|
|
targetLeft = Math.ceil(targetLeft);
|
|
|
|
if (_.options.vertical === false) {
|
|
animProps[_.animType] = 'translate3d(' + targetLeft + 'px, 0px, 0px)';
|
|
} else {
|
|
animProps[_.animType] = 'translate3d(0px,' + targetLeft + 'px, 0px)';
|
|
}
|
|
_.$slideTrack.css(animProps);
|
|
|
|
if (callback) {
|
|
setTimeout(function() {
|
|
|
|
_.disableTransition();
|
|
|
|
callback.call();
|
|
}, _.options.speed);
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.getNavTarget = function() {
|
|
|
|
var _ = this,
|
|
asNavFor = _.options.asNavFor;
|
|
|
|
if ( asNavFor && asNavFor !== null ) {
|
|
asNavFor = $(asNavFor).not(_.$slider);
|
|
}
|
|
|
|
return asNavFor;
|
|
|
|
};
|
|
|
|
Slick.prototype.asNavFor = function(index) {
|
|
|
|
var _ = this,
|
|
asNavFor = _.getNavTarget();
|
|
|
|
if ( asNavFor !== null && typeof asNavFor === 'object' ) {
|
|
asNavFor.each(function() {
|
|
var target = $(this).slick('getSlick');
|
|
if(!target.unslicked) {
|
|
target.slideHandler(index, true);
|
|
}
|
|
});
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.applyTransition = function(slide) {
|
|
|
|
var _ = this,
|
|
transition = {};
|
|
|
|
if (_.options.fade === false) {
|
|
transition[_.transitionType] = _.transformType + ' ' + _.options.speed + 'ms ' + _.options.cssEase;
|
|
} else {
|
|
transition[_.transitionType] = 'opacity ' + _.options.speed + 'ms ' + _.options.cssEase;
|
|
}
|
|
|
|
if (_.options.fade === false) {
|
|
_.$slideTrack.css(transition);
|
|
} else {
|
|
_.$slides.eq(slide).css(transition);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.autoPlay = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.autoPlayClear();
|
|
|
|
if ( _.slideCount > _.options.slidesToShow ) {
|
|
_.autoPlayTimer = setInterval( _.autoPlayIterator, _.options.autoplaySpeed );
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.autoPlayClear = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.autoPlayTimer) {
|
|
clearInterval(_.autoPlayTimer);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.autoPlayIterator = function() {
|
|
|
|
var _ = this,
|
|
slideTo = _.currentSlide + _.options.slidesToScroll;
|
|
|
|
if ( !_.paused && !_.interrupted && !_.focussed ) {
|
|
|
|
if ( _.options.infinite === false ) {
|
|
|
|
if ( _.direction === 1 && ( _.currentSlide + 1 ) === ( _.slideCount - 1 )) {
|
|
_.direction = 0;
|
|
}
|
|
|
|
else if ( _.direction === 0 ) {
|
|
|
|
slideTo = _.currentSlide - _.options.slidesToScroll;
|
|
|
|
if ( _.currentSlide - 1 === 0 ) {
|
|
_.direction = 1;
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_.slideHandler( slideTo );
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.buildArrows = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.options.arrows === true ) {
|
|
|
|
_.$prevArrow = $(_.options.prevArrow).addClass('slick-arrow');
|
|
_.$nextArrow = $(_.options.nextArrow).addClass('slick-arrow');
|
|
|
|
if( _.slideCount > _.options.slidesToShow ) {
|
|
|
|
_.$prevArrow.removeClass('slick-hidden').removeAttr('aria-hidden tabindex');
|
|
_.$nextArrow.removeClass('slick-hidden').removeAttr('aria-hidden tabindex');
|
|
|
|
if (_.htmlExpr.test(_.options.prevArrow)) {
|
|
_.$prevArrow.prependTo(_.options.appendArrows);
|
|
}
|
|
|
|
if (_.htmlExpr.test(_.options.nextArrow)) {
|
|
_.$nextArrow.appendTo(_.options.appendArrows);
|
|
}
|
|
|
|
if (_.options.infinite !== true) {
|
|
_.$prevArrow
|
|
.addClass('slick-disabled')
|
|
.attr('aria-disabled', 'true');
|
|
}
|
|
|
|
} else {
|
|
|
|
_.$prevArrow.add( _.$nextArrow )
|
|
|
|
.addClass('slick-hidden')
|
|
.attr({
|
|
'aria-disabled': 'true',
|
|
'tabindex': '-1'
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.buildDots = function() {
|
|
|
|
var _ = this,
|
|
i, dot;
|
|
|
|
if (_.options.dots === true && _.slideCount > _.options.slidesToShow) {
|
|
|
|
_.$slider.addClass('slick-dotted');
|
|
|
|
dot = $('<ul />').addClass(_.options.dotsClass);
|
|
|
|
for (i = 0; i <= _.getDotCount(); i += 1) {
|
|
dot.append($('<li />').append(_.options.customPaging.call(this, _, i)));
|
|
}
|
|
|
|
_.$dots = dot.appendTo(_.options.appendDots);
|
|
|
|
_.$dots.find('li').first().addClass('slick-active').attr('aria-hidden', 'false');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.buildOut = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.$slides =
|
|
_.$slider
|
|
.children( _.options.slide + ':not(.slick-cloned)')
|
|
.addClass('slick-slide');
|
|
|
|
_.slideCount = _.$slides.length;
|
|
|
|
_.$slides.each(function(index, element) {
|
|
$(element)
|
|
.attr('data-slick-index', index)
|
|
.data('originalStyling', $(element).attr('style') || '');
|
|
});
|
|
|
|
_.$slider.addClass('slick-slider');
|
|
|
|
_.$slideTrack = (_.slideCount === 0) ?
|
|
$('<div class="slick-track"/>').appendTo(_.$slider) :
|
|
_.$slides.wrapAll('<div class="slick-track"/>').parent();
|
|
|
|
_.$list = _.$slideTrack.wrap(
|
|
'<div aria-live="polite" class="slick-list"/>').parent();
|
|
_.$slideTrack.css('opacity', 0);
|
|
|
|
if (_.options.centerMode === true || _.options.swipeToSlide === true) {
|
|
_.options.slidesToScroll = 1;
|
|
}
|
|
|
|
$('img[data-lazy]', _.$slider).not('[src]').addClass('slick-loading');
|
|
|
|
_.setupInfinite();
|
|
|
|
_.buildArrows();
|
|
|
|
_.buildDots();
|
|
|
|
_.updateDots();
|
|
|
|
|
|
_.setSlideClasses(typeof _.currentSlide === 'number' ? _.currentSlide : 0);
|
|
|
|
if (_.options.draggable === true) {
|
|
_.$list.addClass('draggable');
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.buildRows = function() {
|
|
|
|
var _ = this, a, b, c, newSlides, numOfSlides, originalSlides,slidesPerSection;
|
|
|
|
newSlides = document.createDocumentFragment();
|
|
originalSlides = _.$slider.children();
|
|
|
|
if(_.options.rows > 1) {
|
|
|
|
slidesPerSection = _.options.slidesPerRow * _.options.rows;
|
|
numOfSlides = Math.ceil(
|
|
originalSlides.length / slidesPerSection
|
|
);
|
|
|
|
for(a = 0; a < numOfSlides; a++){
|
|
var slide = document.createElement('div');
|
|
for(b = 0; b < _.options.rows; b++) {
|
|
var row = document.createElement('div');
|
|
for(c = 0; c < _.options.slidesPerRow; c++) {
|
|
var target = (a * slidesPerSection + ((b * _.options.slidesPerRow) + c));
|
|
if (originalSlides.get(target)) {
|
|
row.appendChild(originalSlides.get(target));
|
|
}
|
|
}
|
|
slide.appendChild(row);
|
|
}
|
|
newSlides.appendChild(slide);
|
|
}
|
|
|
|
_.$slider.empty().append(newSlides);
|
|
_.$slider.children().children().children()
|
|
.css({
|
|
'width':(100 / _.options.slidesPerRow) + '%',
|
|
'display': 'inline-block'
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.checkResponsive = function(initial, forceUpdate) {
|
|
|
|
var _ = this,
|
|
breakpoint, targetBreakpoint, respondToWidth, triggerBreakpoint = false;
|
|
var sliderWidth = _.$slider.width();
|
|
var windowWidth = window.innerWidth || $(window).width();
|
|
|
|
if (_.respondTo === 'window') {
|
|
respondToWidth = windowWidth;
|
|
} else if (_.respondTo === 'slider') {
|
|
respondToWidth = sliderWidth;
|
|
} else if (_.respondTo === 'min') {
|
|
respondToWidth = Math.min(windowWidth, sliderWidth);
|
|
}
|
|
|
|
if ( _.options.responsive &&
|
|
_.options.responsive.length &&
|
|
_.options.responsive !== null) {
|
|
|
|
targetBreakpoint = null;
|
|
|
|
for (breakpoint in _.breakpoints) {
|
|
if (_.breakpoints.hasOwnProperty(breakpoint)) {
|
|
if (_.originalSettings.mobileFirst === false) {
|
|
if (respondToWidth < _.breakpoints[breakpoint]) {
|
|
targetBreakpoint = _.breakpoints[breakpoint];
|
|
}
|
|
} else {
|
|
if (respondToWidth > _.breakpoints[breakpoint]) {
|
|
targetBreakpoint = _.breakpoints[breakpoint];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (targetBreakpoint !== null) {
|
|
if (_.activeBreakpoint !== null) {
|
|
if (targetBreakpoint !== _.activeBreakpoint || forceUpdate) {
|
|
_.activeBreakpoint =
|
|
targetBreakpoint;
|
|
if (_.breakpointSettings[targetBreakpoint] === 'unslick') {
|
|
_.unslick(targetBreakpoint);
|
|
} else {
|
|
_.options = $.extend({}, _.originalSettings,
|
|
_.breakpointSettings[
|
|
targetBreakpoint]);
|
|
if (initial === true) {
|
|
_.currentSlide = _.options.initialSlide;
|
|
}
|
|
_.refresh(initial);
|
|
}
|
|
triggerBreakpoint = targetBreakpoint;
|
|
}
|
|
} else {
|
|
_.activeBreakpoint = targetBreakpoint;
|
|
if (_.breakpointSettings[targetBreakpoint] === 'unslick') {
|
|
_.unslick(targetBreakpoint);
|
|
} else {
|
|
_.options = $.extend({}, _.originalSettings,
|
|
_.breakpointSettings[
|
|
targetBreakpoint]);
|
|
if (initial === true) {
|
|
_.currentSlide = _.options.initialSlide;
|
|
}
|
|
_.refresh(initial);
|
|
}
|
|
triggerBreakpoint = targetBreakpoint;
|
|
}
|
|
} else {
|
|
if (_.activeBreakpoint !== null) {
|
|
_.activeBreakpoint = null;
|
|
_.options = _.originalSettings;
|
|
if (initial === true) {
|
|
_.currentSlide = _.options.initialSlide;
|
|
}
|
|
_.refresh(initial);
|
|
triggerBreakpoint = targetBreakpoint;
|
|
}
|
|
}
|
|
|
|
// only trigger breakpoints during an actual break. not on initialize.
|
|
if( !initial && triggerBreakpoint !== false ) {
|
|
_.$slider.trigger('breakpoint', [_, triggerBreakpoint]);
|
|
}
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.changeSlide = function(event, dontAnimate) {
|
|
|
|
var _ = this,
|
|
$target = $(event.currentTarget),
|
|
indexOffset, slideOffset, unevenOffset;
|
|
|
|
// If target is a link, prevent default action.
|
|
if($target.is('a')) {
|
|
event.preventDefault();
|
|
}
|
|
|
|
// If target is not the <li> element (ie: a child), find the <li>.
|
|
if(!$target.is('li')) {
|
|
$target = $target.closest('li');
|
|
}
|
|
|
|
unevenOffset = (_.slideCount % _.options.slidesToScroll !== 0);
|
|
indexOffset = unevenOffset ? 0 : (_.slideCount - _.currentSlide) % _.options.slidesToScroll;
|
|
|
|
switch (event.data.message) {
|
|
|
|
case 'previous':
|
|
slideOffset = indexOffset === 0 ? _.options.slidesToScroll : _.options.slidesToShow - indexOffset;
|
|
if (_.slideCount > _.options.slidesToShow) {
|
|
_.slideHandler(_.currentSlide - slideOffset, false, dontAnimate);
|
|
}
|
|
break;
|
|
|
|
case 'next':
|
|
slideOffset = indexOffset === 0 ? _.options.slidesToScroll : indexOffset;
|
|
if (_.slideCount > _.options.slidesToShow) {
|
|
_.slideHandler(_.currentSlide + slideOffset, false, dontAnimate);
|
|
}
|
|
break;
|
|
|
|
case 'index':
|
|
var index = event.data.index === 0 ? 0 :
|
|
event.data.index || $target.index() * _.options.slidesToScroll;
|
|
|
|
_.slideHandler(_.checkNavigable(index), false, dontAnimate);
|
|
$target.children().trigger('focus');
|
|
break;
|
|
|
|
default:
|
|
return;
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.checkNavigable = function(index) {
|
|
|
|
var _ = this,
|
|
navigables, prevNavigable;
|
|
|
|
navigables = _.getNavigableIndexes();
|
|
prevNavigable = 0;
|
|
if (index > navigables[navigables.length - 1]) {
|
|
index = navigables[navigables.length - 1];
|
|
} else {
|
|
for (var n in navigables) {
|
|
if (index < navigables[n]) {
|
|
index = prevNavigable;
|
|
break;
|
|
}
|
|
prevNavigable = navigables[n];
|
|
}
|
|
}
|
|
|
|
return index;
|
|
};
|
|
|
|
Slick.prototype.cleanUpEvents = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.options.dots && _.$dots !== null) {
|
|
|
|
$('li', _.$dots)
|
|
.off('click.slick', _.changeSlide)
|
|
.off('mouseenter.slick', $.proxy(_.interrupt, _, true))
|
|
.off('mouseleave.slick', $.proxy(_.interrupt, _, false));
|
|
|
|
}
|
|
|
|
_.$slider.off('focus.slick blur.slick');
|
|
|
|
if (_.options.arrows === true && _.slideCount > _.options.slidesToShow) {
|
|
_.$prevArrow && _.$prevArrow.off('click.slick', _.changeSlide);
|
|
_.$nextArrow && _.$nextArrow.off('click.slick', _.changeSlide);
|
|
}
|
|
|
|
_.$list.off('touchstart.slick mousedown.slick', _.swipeHandler);
|
|
_.$list.off('touchmove.slick mousemove.slick', _.swipeHandler);
|
|
_.$list.off('touchend.slick mouseup.slick', _.swipeHandler);
|
|
_.$list.off('touchcancel.slick mouseleave.slick', _.swipeHandler);
|
|
|
|
_.$list.off('click.slick', _.clickHandler);
|
|
|
|
$(document).off(_.visibilityChange, _.visibility);
|
|
|
|
_.cleanUpSlideEvents();
|
|
|
|
if (_.options.accessibility === true) {
|
|
_.$list.off('keydown.slick', _.keyHandler);
|
|
}
|
|
|
|
if (_.options.focusOnSelect === true) {
|
|
$(_.$slideTrack).children().off('click.slick', _.selectHandler);
|
|
}
|
|
|
|
$(window).off('orientationchange.slick.slick-' + _.instanceUid, _.orientationChange);
|
|
|
|
$(window).off('resize.slick.slick-' + _.instanceUid, _.resize);
|
|
|
|
$('[draggable!=true]', _.$slideTrack).off('dragstart', _.preventDefault);
|
|
|
|
$(window).off('load.slick.slick-' + _.instanceUid, _.setPosition);
|
|
$(document).off('ready.slick.slick-' + _.instanceUid, _.setPosition);
|
|
|
|
};
|
|
|
|
Slick.prototype.cleanUpSlideEvents = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.$list.off('mouseenter.slick', $.proxy(_.interrupt, _, true));
|
|
_.$list.off('mouseleave.slick', $.proxy(_.interrupt, _, false));
|
|
|
|
};
|
|
|
|
Slick.prototype.cleanUpRows = function() {
|
|
|
|
var _ = this, originalSlides;
|
|
|
|
if(_.options.rows > 1) {
|
|
originalSlides = _.$slides.children().children();
|
|
originalSlides.removeAttr('style');
|
|
_.$slider.empty().append(originalSlides);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.clickHandler = function(event) {
|
|
|
|
var _ = this;
|
|
|
|
if (_.shouldClick === false) {
|
|
event.stopImmediatePropagation();
|
|
event.stopPropagation();
|
|
event.preventDefault();
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.destroy = function(refresh) {
|
|
|
|
var _ = this;
|
|
|
|
_.autoPlayClear();
|
|
|
|
_.touchObject = {};
|
|
|
|
_.cleanUpEvents();
|
|
|
|
$('.slick-cloned', _.$slider).detach();
|
|
|
|
if (_.$dots) {
|
|
_.$dots.remove();
|
|
}
|
|
|
|
|
|
if ( _.$prevArrow && _.$prevArrow.length ) {
|
|
|
|
_.$prevArrow
|
|
.removeClass('slick-disabled slick-arrow slick-hidden')
|
|
.removeAttr('aria-hidden aria-disabled tabindex')
|
|
.css('display','');
|
|
|
|
if ( _.htmlExpr.test( _.options.prevArrow )) {
|
|
_.$prevArrow.remove();
|
|
}
|
|
}
|
|
|
|
if ( _.$nextArrow && _.$nextArrow.length ) {
|
|
|
|
_.$nextArrow
|
|
.removeClass('slick-disabled slick-arrow slick-hidden')
|
|
.removeAttr('aria-hidden aria-disabled tabindex')
|
|
.css('display','');
|
|
|
|
if ( _.htmlExpr.test( _.options.nextArrow )) {
|
|
_.$nextArrow.remove();
|
|
}
|
|
|
|
}
|
|
|
|
|
|
if (_.$slides) {
|
|
|
|
_.$slides
|
|
.removeClass('slick-slide slick-active slick-center slick-visible slick-current')
|
|
.removeAttr('aria-hidden')
|
|
.removeAttr('data-slick-index')
|
|
.each(function(){
|
|
$(this).attr('style', $(this).data('originalStyling'));
|
|
});
|
|
|
|
_.$slideTrack.children(this.options.slide).detach();
|
|
|
|
_.$slideTrack.detach();
|
|
|
|
_.$list.detach();
|
|
|
|
_.$slider.append(_.$slides);
|
|
}
|
|
|
|
_.cleanUpRows();
|
|
|
|
_.$slider.removeClass('slick-slider');
|
|
_.$slider.removeClass('slick-initialized');
|
|
_.$slider.removeClass('slick-dotted');
|
|
|
|
_.unslicked = true;
|
|
|
|
if(!refresh) {
|
|
_.$slider.trigger('destroy', [_]);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.disableTransition = function(slide) {
|
|
|
|
var _ = this,
|
|
transition = {};
|
|
|
|
transition[_.transitionType] = '';
|
|
|
|
if (_.options.fade === false) {
|
|
_.$slideTrack.css(transition);
|
|
} else {
|
|
_.$slides.eq(slide).css(transition);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.fadeSlide = function(slideIndex, callback) {
|
|
|
|
var _ = this;
|
|
|
|
if (_.cssTransitions === false) {
|
|
|
|
_.$slides.eq(slideIndex).css({
|
|
zIndex: _.options.zIndex
|
|
});
|
|
|
|
_.$slides.eq(slideIndex).animate({
|
|
opacity: 1
|
|
}, _.options.speed, _.options.easing, callback);
|
|
|
|
} else {
|
|
|
|
_.applyTransition(slideIndex);
|
|
|
|
_.$slides.eq(slideIndex).css({
|
|
opacity: 1,
|
|
zIndex: _.options.zIndex
|
|
});
|
|
|
|
if (callback) {
|
|
setTimeout(function() {
|
|
|
|
_.disableTransition(slideIndex);
|
|
|
|
callback.call();
|
|
}, _.options.speed);
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.fadeSlideOut = function(slideIndex) {
|
|
|
|
var _ = this;
|
|
|
|
if (_.cssTransitions === false) {
|
|
|
|
_.$slides.eq(slideIndex).animate({
|
|
opacity: 0,
|
|
zIndex: _.options.zIndex - 2
|
|
}, _.options.speed, _.options.easing);
|
|
|
|
} else {
|
|
|
|
_.applyTransition(slideIndex);
|
|
|
|
_.$slides.eq(slideIndex).css({
|
|
opacity: 0,
|
|
zIndex: _.options.zIndex - 2
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.filterSlides = Slick.prototype.slickFilter = function(filter) {
|
|
|
|
var _ = this;
|
|
|
|
if (filter !== null) {
|
|
|
|
_.$slidesCache = _.$slides;
|
|
|
|
_.unload();
|
|
|
|
_.$slideTrack.children(this.options.slide).detach();
|
|
|
|
_.$slidesCache.filter(filter).appendTo(_.$slideTrack);
|
|
|
|
_.reinit();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.focusHandler = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.$slider
|
|
.off('focus.slick blur.slick')
|
|
.on('focus.slick blur.slick',
|
|
'*:not(.slick-arrow)', function(event) {
|
|
|
|
event.stopImmediatePropagation();
|
|
var $sf = $(this);
|
|
|
|
setTimeout(function() {
|
|
|
|
if( _.options.pauseOnFocus ) {
|
|
_.focussed = $sf.is(':focus');
|
|
_.autoPlay();
|
|
}
|
|
|
|
}, 0);
|
|
|
|
});
|
|
};
|
|
|
|
Slick.prototype.getCurrent = Slick.prototype.slickCurrentSlide = function() {
|
|
|
|
var _ = this;
|
|
return _.currentSlide;
|
|
|
|
};
|
|
|
|
Slick.prototype.getDotCount = function() {
|
|
|
|
var _ = this;
|
|
|
|
var breakPoint = 0;
|
|
var counter = 0;
|
|
var pagerQty = 0;
|
|
|
|
if (_.options.infinite === true) {
|
|
while (breakPoint < _.slideCount) {
|
|
++pagerQty;
|
|
breakPoint = counter + _.options.slidesToScroll;
|
|
counter += _.options.slidesToScroll <= _.options.slidesToShow ? _.options.slidesToScroll : _.options.slidesToShow;
|
|
}
|
|
} else if (_.options.centerMode === true) {
|
|
pagerQty = _.slideCount;
|
|
} else if(!_.options.asNavFor) {
|
|
pagerQty = 1 + Math.ceil((_.slideCount - _.options.slidesToShow) / _.options.slidesToScroll);
|
|
}else {
|
|
while (breakPoint < _.slideCount) {
|
|
++pagerQty;
|
|
breakPoint = counter + _.options.slidesToScroll;
|
|
counter += _.options.slidesToScroll <= _.options.slidesToShow ? _.options.slidesToScroll : _.options.slidesToShow;
|
|
}
|
|
}
|
|
|
|
return pagerQty - 1;
|
|
|
|
};
|
|
|
|
Slick.prototype.getLeft = function(slideIndex) {
|
|
|
|
var _ = this,
|
|
targetLeft,
|
|
verticalHeight,
|
|
verticalOffset = 0,
|
|
targetSlide;
|
|
|
|
_.slideOffset = 0;
|
|
verticalHeight = _.$slides.first().outerHeight(true);
|
|
|
|
if (_.options.infinite === true) {
|
|
if (_.slideCount > _.options.slidesToShow) {
|
|
_.slideOffset = (_.slideWidth * _.options.slidesToShow) * -1;
|
|
verticalOffset = (verticalHeight * _.options.slidesToShow) * -1;
|
|
}
|
|
if (_.slideCount % _.options.slidesToScroll !== 0) {
|
|
if (slideIndex + _.options.slidesToScroll > _.slideCount && _.slideCount > _.options.slidesToShow) {
|
|
if (slideIndex > _.slideCount) {
|
|
_.slideOffset = ((_.options.slidesToShow - (slideIndex - _.slideCount)) * _.slideWidth) * -1;
|
|
verticalOffset = ((_.options.slidesToShow - (slideIndex - _.slideCount)) * verticalHeight) * -1;
|
|
} else {
|
|
_.slideOffset = ((_.slideCount % _.options.slidesToScroll) * _.slideWidth) * -1;
|
|
verticalOffset = ((_.slideCount % _.options.slidesToScroll) * verticalHeight) * -1;
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
if (slideIndex + _.options.slidesToShow > _.slideCount) {
|
|
_.slideOffset = ((slideIndex + _.options.slidesToShow) - _.slideCount) * _.slideWidth;
|
|
verticalOffset = ((slideIndex + _.options.slidesToShow) - _.slideCount) * verticalHeight;
|
|
}
|
|
}
|
|
|
|
if (_.slideCount <= _.options.slidesToShow) {
|
|
_.slideOffset = 0;
|
|
verticalOffset = 0;
|
|
}
|
|
|
|
if (_.options.centerMode === true && _.options.infinite === true) {
|
|
_.slideOffset += _.slideWidth * Math.floor(_.options.slidesToShow / 2) - _.slideWidth;
|
|
} else if (_.options.centerMode === true) {
|
|
_.slideOffset = 0;
|
|
_.slideOffset += _.slideWidth * Math.floor(_.options.slidesToShow / 2);
|
|
}
|
|
|
|
if (_.options.vertical === false) {
|
|
targetLeft = ((slideIndex * _.slideWidth) * -1) + _.slideOffset;
|
|
} else {
|
|
targetLeft = ((slideIndex * verticalHeight) * -1) + verticalOffset;
|
|
}
|
|
|
|
if (_.options.variableWidth === true) {
|
|
|
|
if (_.slideCount <= _.options.slidesToShow || _.options.infinite === false) {
|
|
targetSlide = _.$slideTrack.children('.slick-slide').eq(slideIndex);
|
|
} else {
|
|
targetSlide = _.$slideTrack.children('.slick-slide').eq(slideIndex + _.options.slidesToShow);
|
|
}
|
|
|
|
if (_.options.rtl === true) {
|
|
if (targetSlide[0]) {
|
|
targetLeft = (_.$slideTrack.width() - targetSlide[0].offsetLeft - targetSlide.width()) * -1;
|
|
} else {
|
|
targetLeft = 0;
|
|
}
|
|
} else {
|
|
targetLeft = targetSlide[0] ? targetSlide[0].offsetLeft * -1 : 0;
|
|
}
|
|
|
|
if (_.options.centerMode === true) {
|
|
if (_.slideCount <= _.options.slidesToShow || _.options.infinite === false) {
|
|
targetSlide = _.$slideTrack.children('.slick-slide').eq(slideIndex);
|
|
} else {
|
|
targetSlide = _.$slideTrack.children('.slick-slide').eq(slideIndex + _.options.slidesToShow + 1);
|
|
}
|
|
|
|
if (_.options.rtl === true) {
|
|
if (targetSlide[0]) {
|
|
targetLeft = (_.$slideTrack.width() - targetSlide[0].offsetLeft - targetSlide.width()) * -1;
|
|
} else {
|
|
targetLeft = 0;
|
|
}
|
|
} else {
|
|
targetLeft = targetSlide[0] ? targetSlide[0].offsetLeft * -1 : 0;
|
|
}
|
|
|
|
targetLeft += (_.$list.width() - targetSlide.outerWidth()) / 2;
|
|
}
|
|
}
|
|
|
|
return targetLeft;
|
|
|
|
};
|
|
|
|
Slick.prototype.getOption = Slick.prototype.slickGetOption = function(option) {
|
|
|
|
var _ = this;
|
|
|
|
return _.options[option];
|
|
|
|
};
|
|
|
|
Slick.prototype.getNavigableIndexes = function() {
|
|
|
|
var _ = this,
|
|
breakPoint = 0,
|
|
counter = 0,
|
|
indexes = [],
|
|
max;
|
|
|
|
if (_.options.infinite === false) {
|
|
max = _.slideCount;
|
|
} else {
|
|
breakPoint = _.options.slidesToScroll * -1;
|
|
counter = _.options.slidesToScroll * -1;
|
|
max = _.slideCount * 2;
|
|
}
|
|
|
|
while (breakPoint < max) {
|
|
indexes.push(breakPoint);
|
|
breakPoint = counter + _.options.slidesToScroll;
|
|
counter += _.options.slidesToScroll <= _.options.slidesToShow ? _.options.slidesToScroll : _.options.slidesToShow;
|
|
}
|
|
|
|
return indexes;
|
|
|
|
};
|
|
|
|
Slick.prototype.getSlick = function() {
|
|
|
|
return this;
|
|
|
|
};
|
|
|
|
Slick.prototype.getSlideCount = function() {
|
|
|
|
var _ = this,
|
|
slidesTraversed, swipedSlide, centerOffset;
|
|
|
|
centerOffset = _.options.centerMode === true ? _.slideWidth * Math.floor(_.options.slidesToShow / 2) : 0;
|
|
|
|
if (_.options.swipeToSlide === true) {
|
|
_.$slideTrack.find('.slick-slide').each(function(index, slide) {
|
|
if (slide.offsetLeft - centerOffset + ($(slide).outerWidth() / 2) > (_.swipeLeft * -1)) {
|
|
swipedSlide = slide;
|
|
return false;
|
|
}
|
|
});
|
|
|
|
slidesTraversed = Math.abs($(swipedSlide).attr('data-slick-index') - _.currentSlide) || 1;
|
|
|
|
return slidesTraversed;
|
|
|
|
} else {
|
|
return _.options.slidesToScroll;
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.goTo = Slick.prototype.slickGoTo = function(slide, dontAnimate) {
|
|
|
|
var _ = this;
|
|
|
|
_.changeSlide({
|
|
data: {
|
|
message: 'index',
|
|
index: parseInt(slide)
|
|
}
|
|
}, dontAnimate);
|
|
|
|
};
|
|
|
|
Slick.prototype.init = function(creation) {
|
|
|
|
var _ = this;
|
|
|
|
if (!$(_.$slider).hasClass('slick-initialized')) {
|
|
|
|
$(_.$slider).addClass('slick-initialized');
|
|
|
|
_.buildRows();
|
|
_.buildOut();
|
|
_.setProps();
|
|
_.startLoad();
|
|
_.loadSlider();
|
|
_.initializeEvents();
|
|
_.updateArrows();
|
|
_.updateDots();
|
|
_.checkResponsive(true);
|
|
_.focusHandler();
|
|
|
|
}
|
|
|
|
if (creation) {
|
|
_.$slider.trigger('init', [_]);
|
|
}
|
|
|
|
if (_.options.accessibility === true) {
|
|
_.initADA();
|
|
}
|
|
|
|
if ( _.options.autoplay ) {
|
|
|
|
_.paused = false;
|
|
_.autoPlay();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.initADA = function() {
|
|
var _ = this;
|
|
_.$slides.add(_.$slideTrack.find('.slick-cloned')).attr({
|
|
'aria-hidden': 'true',
|
|
'tabindex': '-1'
|
|
}).find('a, input, button, select').attr({
|
|
'tabindex': '-1'
|
|
});
|
|
|
|
_.$slideTrack.attr('role', 'listbox');
|
|
|
|
_.$slides.not(_.$slideTrack.find('.slick-cloned')).each(function(i) {
|
|
$(this).attr({
|
|
'role': 'option',
|
|
'aria-describedby': 'slick-slide' + _.instanceUid + i + ''
|
|
});
|
|
});
|
|
|
|
if (_.$dots !== null) {
|
|
_.$dots.attr('role', 'tablist').find('li').each(function(i) {
|
|
$(this).attr({
|
|
'role': 'presentation',
|
|
'aria-selected': 'false',
|
|
'aria-controls': 'navigation' + _.instanceUid + i + '',
|
|
'id': 'slick-slide' + _.instanceUid + i + ''
|
|
});
|
|
})
|
|
.first().attr('aria-selected', 'true').end()
|
|
.find('button').attr('role', 'button').end()
|
|
.closest('div').attr('role', 'toolbar');
|
|
}
|
|
_.activateADA();
|
|
|
|
};
|
|
|
|
Slick.prototype.initArrowEvents = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.options.arrows === true && _.slideCount > _.options.slidesToShow) {
|
|
_.$prevArrow
|
|
.off('click.slick')
|
|
.on('click.slick', {
|
|
message: 'previous'
|
|
}, _.changeSlide);
|
|
_.$nextArrow
|
|
.off('click.slick')
|
|
.on('click.slick', {
|
|
message: 'next'
|
|
}, _.changeSlide);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.initDotEvents = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.options.dots === true && _.slideCount > _.options.slidesToShow) {
|
|
$('li', _.$dots).on('click.slick', {
|
|
message: 'index'
|
|
}, _.changeSlide);
|
|
}
|
|
|
|
if ( _.options.dots === true && _.options.pauseOnDotsHover === true ) {
|
|
|
|
$('li', _.$dots)
|
|
.on('mouseenter.slick', $.proxy(_.interrupt, _, true))
|
|
.on('mouseleave.slick', $.proxy(_.interrupt, _, false));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.initSlideEvents = function() {
|
|
|
|
var _ = this;
|
|
|
|
if ( _.options.pauseOnHover ) {
|
|
|
|
_.$list.on('mouseenter.slick', $.proxy(_.interrupt, _, true));
|
|
_.$list.on('mouseleave.slick', $.proxy(_.interrupt, _, false));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.initializeEvents = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.initArrowEvents();
|
|
|
|
_.initDotEvents();
|
|
_.initSlideEvents();
|
|
|
|
_.$list.on('touchstart.slick mousedown.slick', {
|
|
action: 'start'
|
|
}, _.swipeHandler);
|
|
_.$list.on('touchmove.slick mousemove.slick', {
|
|
action: 'move'
|
|
}, _.swipeHandler);
|
|
_.$list.on('touchend.slick mouseup.slick', {
|
|
action: 'end'
|
|
}, _.swipeHandler);
|
|
_.$list.on('touchcancel.slick mouseleave.slick', {
|
|
action: 'end'
|
|
}, _.swipeHandler);
|
|
|
|
_.$list.on('click.slick', _.clickHandler);
|
|
|
|
$(document).on(_.visibilityChange, $.proxy(_.visibility, _));
|
|
|
|
if (_.options.accessibility === true) {
|
|
_.$list.on('keydown.slick', _.keyHandler);
|
|
}
|
|
|
|
if (_.options.focusOnSelect === true) {
|
|
$(_.$slideTrack).children().on('click.slick', _.selectHandler);
|
|
}
|
|
|
|
$(window).on('orientationchange.slick.slick-' + _.instanceUid, $.proxy(_.orientationChange, _));
|
|
|
|
$(window).on('resize.slick.slick-' + _.instanceUid, $.proxy(_.resize, _));
|
|
|
|
$('[draggable!=true]', _.$slideTrack).on('dragstart', _.preventDefault);
|
|
|
|
$(window).on('load.slick.slick-' + _.instanceUid, _.setPosition);
|
|
$(document).on('ready.slick.slick-' + _.instanceUid, _.setPosition);
|
|
|
|
};
|
|
|
|
Slick.prototype.initUI = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.options.arrows === true && _.slideCount > _.options.slidesToShow) {
|
|
|
|
_.$prevArrow.show();
|
|
_.$nextArrow.show();
|
|
|
|
}
|
|
|
|
if (_.options.dots === true && _.slideCount > _.options.slidesToShow) {
|
|
|
|
_.$dots.show();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.keyHandler = function(event) {
|
|
|
|
var _ = this;
|
|
//Dont slide if the cursor is inside the form fields and arrow keys are pressed
|
|
if(!event.target.tagName.match('TEXTAREA|INPUT|SELECT')) {
|
|
if (event.keyCode === 37 && _.options.accessibility === true) {
|
|
_.changeSlide({
|
|
data: {
|
|
message: _.options.rtl === true ? 'next' : 'previous'
|
|
}
|
|
});
|
|
} else if (event.keyCode === 39 && _.options.accessibility === true) {
|
|
_.changeSlide({
|
|
data: {
|
|
message: _.options.rtl === true ? 'previous' : 'next'
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.lazyLoad = function() {
|
|
|
|
var _ = this,
|
|
loadRange, cloneRange, rangeStart, rangeEnd;
|
|
|
|
function loadImages(imagesScope) {
|
|
|
|
$('img[data-lazy]', imagesScope).each(function() {
|
|
|
|
var image = $(this),
|
|
imageSource = $(this).attr('data-lazy'),
|
|
imageToLoad = document.createElement('img');
|
|
|
|
imageToLoad.onload = function() {
|
|
|
|
image
|
|
.animate({ opacity: 0 }, 100, function() {
|
|
image
|
|
.attr('src', imageSource)
|
|
.animate({ opacity: 1 }, 200, function() {
|
|
image
|
|
.removeAttr('data-lazy')
|
|
.removeClass('slick-loading');
|
|
});
|
|
_.$slider.trigger('lazyLoaded', [_, image, imageSource]);
|
|
});
|
|
|
|
};
|
|
|
|
imageToLoad.onerror = function() {
|
|
|
|
image
|
|
.removeAttr( 'data-lazy' )
|
|
.removeClass( 'slick-loading' )
|
|
.addClass( 'slick-lazyload-error' );
|
|
|
|
_.$slider.trigger('lazyLoadError', [ _, image, imageSource ]);
|
|
|
|
};
|
|
|
|
imageToLoad.src = imageSource;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
if (_.options.centerMode === true) {
|
|
if (_.options.infinite === true) {
|
|
rangeStart = _.currentSlide + (_.options.slidesToShow / 2 + 1);
|
|
rangeEnd = rangeStart + _.options.slidesToShow + 2;
|
|
} else {
|
|
rangeStart = Math.max(0, _.currentSlide - (_.options.slidesToShow / 2 + 1));
|
|
rangeEnd = 2 + (_.options.slidesToShow / 2 + 1) + _.currentSlide;
|
|
}
|
|
} else {
|
|
rangeStart = _.options.infinite ? _.options.slidesToShow + _.currentSlide : _.currentSlide;
|
|
rangeEnd = Math.ceil(rangeStart + _.options.slidesToShow);
|
|
if (_.options.fade === true) {
|
|
if (rangeStart > 0) rangeStart--;
|
|
if (rangeEnd <= _.slideCount) rangeEnd++;
|
|
}
|
|
}
|
|
|
|
loadRange = _.$slider.find('.slick-slide').slice(rangeStart, rangeEnd);
|
|
loadImages(loadRange);
|
|
|
|
if (_.slideCount <= _.options.slidesToShow) {
|
|
cloneRange = _.$slider.find('.slick-slide');
|
|
loadImages(cloneRange);
|
|
} else
|
|
if (_.currentSlide >= _.slideCount - _.options.slidesToShow) {
|
|
cloneRange = _.$slider.find('.slick-cloned').slice(0, _.options.slidesToShow);
|
|
loadImages(cloneRange);
|
|
} else if (_.currentSlide === 0) {
|
|
cloneRange = _.$slider.find('.slick-cloned').slice(_.options.slidesToShow * -1);
|
|
loadImages(cloneRange);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.loadSlider = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.setPosition();
|
|
|
|
_.$slideTrack.css({
|
|
opacity: 1
|
|
});
|
|
|
|
_.$slider.removeClass('slick-loading');
|
|
|
|
_.initUI();
|
|
|
|
if (_.options.lazyLoad === 'progressive') {
|
|
_.progressiveLazyLoad();
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.next = Slick.prototype.slickNext = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.changeSlide({
|
|
data: {
|
|
message: 'next'
|
|
}
|
|
});
|
|
|
|
};
|
|
|
|
Slick.prototype.orientationChange = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.checkResponsive();
|
|
_.setPosition();
|
|
|
|
};
|
|
|
|
Slick.prototype.pause = Slick.prototype.slickPause = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.autoPlayClear();
|
|
_.paused = true;
|
|
|
|
};
|
|
|
|
Slick.prototype.play = Slick.prototype.slickPlay = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.autoPlay();
|
|
_.options.autoplay = true;
|
|
_.paused = false;
|
|
_.focussed = false;
|
|
_.interrupted = false;
|
|
|
|
};
|
|
|
|
Slick.prototype.postSlide = function(index) {
|
|
|
|
var _ = this;
|
|
|
|
if( !_.unslicked ) {
|
|
|
|
_.$slider.trigger('afterChange', [_, index]);
|
|
|
|
_.animating = false;
|
|
|
|
_.setPosition();
|
|
|
|
_.swipeLeft = null;
|
|
|
|
if ( _.options.autoplay ) {
|
|
_.autoPlay();
|
|
}
|
|
|
|
if (_.options.accessibility === true) {
|
|
_.initADA();
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.prev = Slick.prototype.slickPrev = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.changeSlide({
|
|
data: {
|
|
message: 'previous'
|
|
}
|
|
});
|
|
|
|
};
|
|
|
|
Slick.prototype.preventDefault = function(event) {
|
|
|
|
event.preventDefault();
|
|
|
|
};
|
|
|
|
Slick.prototype.progressiveLazyLoad = function( tryCount ) {
|
|
|
|
tryCount = tryCount || 1;
|
|
|
|
var _ = this,
|
|
$imgsToLoad = $( 'img[data-lazy]', _.$slider ),
|
|
image,
|
|
imageSource,
|
|
imageToLoad;
|
|
|
|
if ( $imgsToLoad.length ) {
|
|
|
|
image = $imgsToLoad.first();
|
|
imageSource = image.attr('data-lazy');
|
|
imageToLoad = document.createElement('img');
|
|
|
|
imageToLoad.onload = function() {
|
|
|
|
image
|
|
.attr( 'src', imageSource )
|
|
.removeAttr('data-lazy')
|
|
.removeClass('slick-loading');
|
|
|
|
if ( _.options.adaptiveHeight === true ) {
|
|
_.setPosition();
|
|
}
|
|
|
|
_.$slider.trigger('lazyLoaded', [ _, image, imageSource ]);
|
|
_.progressiveLazyLoad();
|
|
|
|
};
|
|
|
|
imageToLoad.onerror = function() {
|
|
|
|
if ( tryCount < 3 ) {
|
|
|
|
/**
|
|
* try to load the image 3 times,
|
|
* leave a slight delay so we don't get
|
|
* servers blocking the request.
|
|
*/
|
|
setTimeout( function() {
|
|
_.progressiveLazyLoad( tryCount + 1 );
|
|
}, 500 );
|
|
|
|
} else {
|
|
|
|
image
|
|
.removeAttr( 'data-lazy' )
|
|
.removeClass( 'slick-loading' )
|
|
.addClass( 'slick-lazyload-error' );
|
|
|
|
_.$slider.trigger('lazyLoadError', [ _, image, imageSource ]);
|
|
|
|
_.progressiveLazyLoad();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
imageToLoad.src = imageSource;
|
|
|
|
} else {
|
|
|
|
_.$slider.trigger('allImagesLoaded', [ _ ]);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.refresh = function( initializing ) {
|
|
|
|
var _ = this, currentSlide, lastVisibleIndex;
|
|
|
|
lastVisibleIndex = _.slideCount - _.options.slidesToShow;
|
|
|
|
// in non-infinite sliders, we don't want to go past the
|
|
// last visible index.
|
|
if( !_.options.infinite && ( _.currentSlide > lastVisibleIndex )) {
|
|
_.currentSlide = lastVisibleIndex;
|
|
}
|
|
|
|
// if less slides than to show, go to start.
|
|
if ( _.slideCount <= _.options.slidesToShow ) {
|
|
_.currentSlide = 0;
|
|
|
|
}
|
|
|
|
currentSlide = _.currentSlide;
|
|
|
|
_.destroy(true);
|
|
|
|
$.extend(_, _.initials, { currentSlide: currentSlide });
|
|
|
|
_.init();
|
|
|
|
if( !initializing ) {
|
|
|
|
_.changeSlide({
|
|
data: {
|
|
message: 'index',
|
|
index: currentSlide
|
|
}
|
|
}, false);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.registerBreakpoints = function() {
|
|
|
|
var _ = this, breakpoint, currentBreakpoint, l,
|
|
responsiveSettings = _.options.responsive || null;
|
|
|
|
if ( $.type(responsiveSettings) === 'array' && responsiveSettings.length ) {
|
|
|
|
_.respondTo = _.options.respondTo || 'window';
|
|
|
|
for ( breakpoint in responsiveSettings ) {
|
|
|
|
l = _.breakpoints.length-1;
|
|
currentBreakpoint = responsiveSettings[breakpoint].breakpoint;
|
|
|
|
if (responsiveSettings.hasOwnProperty(breakpoint)) {
|
|
|
|
// loop through the breakpoints and cut out any existing
|
|
// ones with the same breakpoint number, we don't want dupes.
|
|
while( l >= 0 ) {
|
|
if( _.breakpoints[l] && _.breakpoints[l] === currentBreakpoint ) {
|
|
_.breakpoints.splice(l,1);
|
|
}
|
|
l--;
|
|
}
|
|
|
|
_.breakpoints.push(currentBreakpoint);
|
|
_.breakpointSettings[currentBreakpoint] = responsiveSettings[breakpoint].settings;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_.breakpoints.sort(function(a, b) {
|
|
return ( _.options.mobileFirst ) ? a-b : b-a;
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.reinit = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.$slides =
|
|
_.$slideTrack
|
|
.children(_.options.slide)
|
|
.addClass('slick-slide');
|
|
|
|
_.slideCount = _.$slides.length;
|
|
|
|
if (_.currentSlide >= _.slideCount && _.currentSlide !== 0) {
|
|
_.currentSlide = _.currentSlide - _.options.slidesToScroll;
|
|
}
|
|
|
|
if (_.slideCount <= _.options.slidesToShow) {
|
|
_.currentSlide = 0;
|
|
}
|
|
|
|
_.registerBreakpoints();
|
|
|
|
_.setProps();
|
|
_.setupInfinite();
|
|
_.buildArrows();
|
|
_.updateArrows();
|
|
_.initArrowEvents();
|
|
_.buildDots();
|
|
_.updateDots();
|
|
_.initDotEvents();
|
|
_.cleanUpSlideEvents();
|
|
_.initSlideEvents();
|
|
|
|
_.checkResponsive(false, true);
|
|
|
|
if (_.options.focusOnSelect === true) {
|
|
$(_.$slideTrack).children().on('click.slick', _.selectHandler);
|
|
}
|
|
|
|
_.setSlideClasses(typeof _.currentSlide === 'number' ? _.currentSlide : 0);
|
|
|
|
_.setPosition();
|
|
_.focusHandler();
|
|
|
|
_.paused = !_.options.autoplay;
|
|
_.autoPlay();
|
|
|
|
_.$slider.trigger('reInit', [_]);
|
|
|
|
};
|
|
|
|
Slick.prototype.resize = function() {
|
|
|
|
var _ = this;
|
|
|
|
if ($(window).width() !== _.windowWidth) {
|
|
clearTimeout(_.windowDelay);
|
|
_.windowDelay = window.setTimeout(function() {
|
|
_.windowWidth = $(window).width();
|
|
_.checkResponsive();
|
|
if( !_.unslicked ) { _.setPosition(); }
|
|
}, 50);
|
|
}
|
|
};
|
|
|
|
Slick.prototype.removeSlide = Slick.prototype.slickRemove = function(index, removeBefore, removeAll) {
|
|
|
|
var _ = this;
|
|
|
|
if (typeof(index) === 'boolean') {
|
|
removeBefore = index;
|
|
index = removeBefore === true ? 0 : _.slideCount - 1;
|
|
} else {
|
|
index = removeBefore === true ? --index : index;
|
|
}
|
|
|
|
if (_.slideCount < 1 || index < 0 || index > _.slideCount - 1) {
|
|
return false;
|
|
}
|
|
|
|
_.unload();
|
|
|
|
if (removeAll === true) {
|
|
_.$slideTrack.children().remove();
|
|
} else {
|
|
_.$slideTrack.children(this.options.slide).eq(index).remove();
|
|
}
|
|
|
|
_.$slides = _.$slideTrack.children(this.options.slide);
|
|
|
|
_.$slideTrack.children(this.options.slide).detach();
|
|
|
|
_.$slideTrack.append(_.$slides);
|
|
|
|
_.$slidesCache = _.$slides;
|
|
|
|
_.reinit();
|
|
|
|
};
|
|
|
|
Slick.prototype.setCSS = function(position) {
|
|
|
|
var _ = this,
|
|
positionProps = {},
|
|
x, y;
|
|
|
|
if (_.options.rtl === true) {
|
|
position = -position;
|
|
}
|
|
x = _.positionProp == 'left' ? Math.ceil(position) + 'px' : '0px';
|
|
y = _.positionProp == 'top' ? Math.ceil(position) + 'px' : '0px';
|
|
|
|
positionProps[_.positionProp] = position;
|
|
|
|
if (_.transformsEnabled === false) {
|
|
_.$slideTrack.css(positionProps);
|
|
} else {
|
|
positionProps = {};
|
|
if (_.cssTransitions === false) {
|
|
positionProps[_.animType] = 'translate(' + x + ', ' + y + ')';
|
|
_.$slideTrack.css(positionProps);
|
|
} else {
|
|
positionProps[_.animType] = 'translate3d(' + x + ', ' + y + ', 0px)';
|
|
_.$slideTrack.css(positionProps);
|
|
}
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.setDimensions = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.options.vertical === false) {
|
|
if (_.options.centerMode === true) {
|
|
_.$list.css({
|
|
padding: ('0px ' + _.options.centerPadding)
|
|
});
|
|
}
|
|
} else {
|
|
_.$list.height(_.$slides.first().outerHeight(true) * _.options.slidesToShow);
|
|
if (_.options.centerMode === true) {
|
|
_.$list.css({
|
|
padding: (_.options.centerPadding + ' 0px')
|
|
});
|
|
}
|
|
}
|
|
|
|
_.listWidth = _.$list.width();
|
|
_.listHeight = _.$list.height();
|
|
|
|
|
|
if (_.options.vertical === false && _.options.variableWidth === false) {
|
|
_.slideWidth = Math.ceil(_.listWidth / _.options.slidesToShow);
|
|
_.$slideTrack.width(Math.ceil((_.slideWidth * _.$slideTrack.children('.slick-slide').length)));
|
|
|
|
} else if (_.options.variableWidth === true) {
|
|
_.$slideTrack.width(5000 * _.slideCount);
|
|
} else {
|
|
_.slideWidth = Math.ceil(_.listWidth);
|
|
_.$slideTrack.height(Math.ceil((_.$slides.first().outerHeight(true) * _.$slideTrack.children('.slick-slide').length)));
|
|
}
|
|
|
|
var offset = _.$slides.first().outerWidth(true) - _.$slides.first().width();
|
|
if (_.options.variableWidth === false) _.$slideTrack.children('.slick-slide').width(_.slideWidth - offset);
|
|
|
|
};
|
|
|
|
Slick.prototype.setFade = function() {
|
|
|
|
var _ = this,
|
|
targetLeft;
|
|
|
|
_.$slides.each(function(index, element) {
|
|
targetLeft = (_.slideWidth * index) * -1;
|
|
if (_.options.rtl === true) {
|
|
$(element).css({
|
|
position: 'relative',
|
|
right: targetLeft,
|
|
top: 0,
|
|
zIndex: _.options.zIndex - 2,
|
|
opacity: 0
|
|
});
|
|
} else {
|
|
$(element).css({
|
|
position: 'relative',
|
|
left: targetLeft,
|
|
top: 0,
|
|
zIndex: _.options.zIndex - 2,
|
|
opacity: 0
|
|
});
|
|
}
|
|
});
|
|
|
|
_.$slides.eq(_.currentSlide).css({
|
|
zIndex: _.options.zIndex - 1,
|
|
opacity: 1
|
|
});
|
|
|
|
};
|
|
|
|
Slick.prototype.setHeight = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.options.slidesToShow === 1 && _.options.adaptiveHeight === true && _.options.vertical === false) {
|
|
var targetHeight = _.$slides.eq(_.currentSlide).outerHeight(true);
|
|
_.$list.css('height', targetHeight);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.setOption =
|
|
Slick.prototype.slickSetOption = function() {
|
|
|
|
/**
|
|
* accepts arguments in format of:
|
|
*
|
|
* - for changing a single option's value:
|
|
* .slick("setOption", option, value, refresh )
|
|
*
|
|
* - for changing a set of responsive options:
|
|
* .slick("setOption", 'responsive', [{}, ...], refresh )
|
|
*
|
|
* - for updating multiple values at once (not responsive)
|
|
* .slick("setOption", { 'option': value, ... }, refresh )
|
|
*/
|
|
|
|
var _ = this, l, item, option, value, refresh = false, type;
|
|
|
|
if( $.type( arguments[0] ) === 'object' ) {
|
|
|
|
option = arguments[0];
|
|
refresh = arguments[1];
|
|
type = 'multiple';
|
|
|
|
} else if ( $.type( arguments[0] ) === 'string' ) {
|
|
|
|
option = arguments[0];
|
|
value = arguments[1];
|
|
refresh = arguments[2];
|
|
|
|
if ( arguments[0] === 'responsive' && $.type( arguments[1] ) === 'array' ) {
|
|
|
|
type = 'responsive';
|
|
|
|
} else if ( typeof arguments[1] !== 'undefined' ) {
|
|
|
|
type = 'single';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( type === 'single' ) {
|
|
|
|
_.options[option] = value;
|
|
|
|
|
|
} else if ( type === 'multiple' ) {
|
|
|
|
$.each( option , function( opt, val ) {
|
|
|
|
_.options[opt] = val;
|
|
|
|
});
|
|
|
|
|
|
} else if ( type === 'responsive' ) {
|
|
|
|
for ( item in value ) {
|
|
|
|
if( $.type( _.options.responsive ) !== 'array' ) {
|
|
|
|
_.options.responsive = [ value[item] ];
|
|
|
|
} else {
|
|
|
|
l = _.options.responsive.length-1;
|
|
|
|
// loop through the responsive object and splice out duplicates.
|
|
while( l >= 0 ) {
|
|
|
|
if( _.options.responsive[l].breakpoint === value[item].breakpoint ) {
|
|
|
|
_.options.responsive.splice(l,1);
|
|
|
|
}
|
|
|
|
l--;
|
|
|
|
}
|
|
|
|
_.options.responsive.push( value[item] );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( refresh ) {
|
|
|
|
_.unload();
|
|
_.reinit();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.setPosition = function() {
|
|
|
|
var _ = this;
|
|
|
|
_.setDimensions();
|
|
|
|
_.setHeight();
|
|
|
|
if (_.options.fade === false) {
|
|
_.setCSS(_.getLeft(_.currentSlide));
|
|
} else {
|
|
_.setFade();
|
|
}
|
|
|
|
_.$slider.trigger('setPosition', [_]);
|
|
|
|
};
|
|
|
|
Slick.prototype.setProps = function() {
|
|
|
|
var _ = this,
|
|
bodyStyle = document.body.style;
|
|
|
|
_.positionProp = _.options.vertical === true ? 'top' : 'left';
|
|
|
|
if (_.positionProp === 'top') {
|
|
_.$slider.addClass('slick-vertical');
|
|
} else {
|
|
_.$slider.removeClass('slick-vertical');
|
|
}
|
|
|
|
if (bodyStyle.WebkitTransition !== undefined ||
|
|
bodyStyle.MozTransition !== undefined ||
|
|
bodyStyle.msTransition !== undefined) {
|
|
if (_.options.useCSS === true) {
|
|
_.cssTransitions = true;
|
|
}
|
|
}
|
|
|
|
if ( _.options.fade ) {
|
|
if ( typeof _.options.zIndex === 'number' ) {
|
|
if( _.options.zIndex < 3 ) {
|
|
_.options.zIndex = 3;
|
|
}
|
|
} else {
|
|
_.options.zIndex = _.defaults.zIndex;
|
|
}
|
|
}
|
|
|
|
if (bodyStyle.OTransform !== undefined) {
|
|
_.animType = 'OTransform';
|
|
_.transformType = '-o-transform';
|
|
_.transitionType = 'OTransition';
|
|
if (bodyStyle.perspectiveProperty === undefined && bodyStyle.webkitPerspective === undefined) _.animType = false;
|
|
}
|
|
if (bodyStyle.MozTransform !== undefined) {
|
|
_.animType = 'MozTransform';
|
|
_.transformType = '-moz-transform';
|
|
_.transitionType = 'MozTransition';
|
|
if (bodyStyle.perspectiveProperty === undefined && bodyStyle.MozPerspective === undefined) _.animType = false;
|
|
}
|
|
if (bodyStyle.webkitTransform !== undefined) {
|
|
_.animType = 'webkitTransform';
|
|
_.transformType = '-webkit-transform';
|
|
_.transitionType = 'webkitTransition';
|
|
if (bodyStyle.perspectiveProperty === undefined && bodyStyle.webkitPerspective === undefined) _.animType = false;
|
|
}
|
|
if (bodyStyle.msTransform !== undefined) {
|
|
_.animType = 'msTransform';
|
|
_.transformType = '-ms-transform';
|
|
_.transitionType = 'msTransition';
|
|
if (bodyStyle.msTransform === undefined) _.animType = false;
|
|
}
|
|
if (bodyStyle.transform !== undefined && _.animType !== false) {
|
|
_.animType = 'transform';
|
|
_.transformType = 'transform';
|
|
_.transitionType = 'transition';
|
|
}
|
|
_.transformsEnabled = _.options.useTransform && (_.animType !== null && _.animType !== false);
|
|
};
|
|
|
|
|
|
Slick.prototype.setSlideClasses = function(index) {
|
|
|
|
var _ = this,
|
|
centerOffset, allSlides, indexOffset, remainder;
|
|
|
|
allSlides = _.$slider
|
|
.find('.slick-slide')
|
|
.removeClass('slick-active slick-center slick-current')
|
|
.attr('aria-hidden', 'true');
|
|
|
|
_.$slides
|
|
.eq(index)
|
|
.addClass('slick-current');
|
|
|
|
if (_.options.centerMode === true) {
|
|
|
|
centerOffset = Math.floor(_.options.slidesToShow / 2);
|
|
|
|
if (_.options.infinite === true) {
|
|
|
|
if (index >= centerOffset && index <= (_.slideCount - 1) - centerOffset) {
|
|
|
|
_.$slides
|
|
.slice(index - centerOffset, index + centerOffset + 1)
|
|
.addClass('slick-active')
|
|
.attr('aria-hidden', 'false');
|
|
|
|
} else {
|
|
|
|
indexOffset = _.options.slidesToShow + index;
|
|
allSlides
|
|
.slice(indexOffset - centerOffset + 1, indexOffset + centerOffset + 2)
|
|
.addClass('slick-active')
|
|
.attr('aria-hidden', 'false');
|
|
|
|
}
|
|
|
|
if (index === 0) {
|
|
|
|
allSlides
|
|
.eq(allSlides.length - 1 - _.options.slidesToShow)
|
|
.addClass('slick-center');
|
|
|
|
} else if (index === _.slideCount - 1) {
|
|
|
|
allSlides
|
|
.eq(_.options.slidesToShow)
|
|
.addClass('slick-center');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_.$slides
|
|
.eq(index)
|
|
.addClass('slick-center');
|
|
|
|
} else {
|
|
|
|
if (index >= 0 && index <= (_.slideCount - _.options.slidesToShow)) {
|
|
|
|
_.$slides
|
|
.slice(index, index + _.options.slidesToShow)
|
|
.addClass('slick-active')
|
|
.attr('aria-hidden', 'false');
|
|
|
|
} else if (allSlides.length <= _.options.slidesToShow) {
|
|
|
|
allSlides
|
|
.addClass('slick-active')
|
|
.attr('aria-hidden', 'false');
|
|
|
|
} else {
|
|
|
|
remainder = _.slideCount % _.options.slidesToShow;
|
|
indexOffset = _.options.infinite === true ? _.options.slidesToShow + index : index;
|
|
|
|
if (_.options.slidesToShow == _.options.slidesToScroll && (_.slideCount - index) < _.options.slidesToShow) {
|
|
|
|
allSlides
|
|
.slice(indexOffset - (_.options.slidesToShow - remainder), indexOffset + remainder)
|
|
.addClass('slick-active')
|
|
.attr('aria-hidden', 'false');
|
|
|
|
} else {
|
|
|
|
allSlides
|
|
.slice(indexOffset, indexOffset + _.options.slidesToShow)
|
|
.addClass('slick-active')
|
|
.attr('aria-hidden', 'false');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (_.options.lazyLoad === 'ondemand') {
|
|
_.lazyLoad();
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.setupInfinite = function() {
|
|
|
|
var _ = this,
|
|
i, slideIndex, infiniteCount;
|
|
|
|
if (_.options.fade === true) {
|
|
_.options.centerMode = false;
|
|
}
|
|
|
|
if (_.options.infinite === true && _.options.fade === false) {
|
|
|
|
slideIndex = null;
|
|
|
|
if (_.slideCount > _.options.slidesToShow) {
|
|
|
|
if (_.options.centerMode === true) {
|
|
infiniteCount = _.options.slidesToShow + 1;
|
|
} else {
|
|
infiniteCount = _.options.slidesToShow;
|
|
}
|
|
|
|
for (i = _.slideCount; i > (_.slideCount -
|
|
infiniteCount); i -= 1) {
|
|
slideIndex = i - 1;
|
|
$(_.$slides[slideIndex]).clone(true).attr('id', '')
|
|
.attr('data-slick-index', slideIndex - _.slideCount)
|
|
.prependTo(_.$slideTrack).addClass('slick-cloned');
|
|
}
|
|
for (i = 0; i < infiniteCount; i += 1) {
|
|
slideIndex = i;
|
|
$(_.$slides[slideIndex]).clone(true).attr('id', '')
|
|
.attr('data-slick-index', slideIndex + _.slideCount)
|
|
.appendTo(_.$slideTrack).addClass('slick-cloned');
|
|
}
|
|
_.$slideTrack.find('.slick-cloned').find('[id]').each(function() {
|
|
$(this).attr('id', '');
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.interrupt = function( toggle ) {
|
|
|
|
var _ = this;
|
|
|
|
if( !toggle ) {
|
|
_.autoPlay();
|
|
}
|
|
_.interrupted = toggle;
|
|
|
|
};
|
|
|
|
Slick.prototype.selectHandler = function(event) {
|
|
|
|
var _ = this;
|
|
|
|
var targetElement =
|
|
$(event.target).is('.slick-slide') ?
|
|
$(event.target) :
|
|
$(event.target).parents('.slick-slide');
|
|
|
|
var index = parseInt(targetElement.attr('data-slick-index'));
|
|
|
|
if (!index) index = 0;
|
|
|
|
if (_.slideCount <= _.options.slidesToShow) {
|
|
|
|
_.setSlideClasses(index);
|
|
_.asNavFor(index);
|
|
return;
|
|
|
|
}
|
|
|
|
_.slideHandler(index);
|
|
|
|
};
|
|
|
|
Slick.prototype.slideHandler = function(index, sync, dontAnimate) {
|
|
|
|
var targetSlide, animSlide, oldSlide, slideLeft, targetLeft = null,
|
|
_ = this, navTarget;
|
|
|
|
sync = sync || false;
|
|
|
|
if (_.animating === true && _.options.waitForAnimate === true) {
|
|
return;
|
|
}
|
|
|
|
if (_.options.fade === true && _.currentSlide === index) {
|
|
return;
|
|
}
|
|
|
|
if (_.slideCount <= _.options.slidesToShow) {
|
|
return;
|
|
}
|
|
|
|
if (sync === false) {
|
|
_.asNavFor(index);
|
|
}
|
|
|
|
targetSlide = index;
|
|
targetLeft = _.getLeft(targetSlide);
|
|
slideLeft = _.getLeft(_.currentSlide);
|
|
|
|
_.currentLeft = _.swipeLeft === null ? slideLeft : _.swipeLeft;
|
|
|
|
if (_.options.infinite === false && _.options.centerMode === false && (index < 0 || index > _.getDotCount() * _.options.slidesToScroll)) {
|
|
if (_.options.fade === false) {
|
|
targetSlide = _.currentSlide;
|
|
if (dontAnimate !== true) {
|
|
_.animateSlide(slideLeft, function() {
|
|
_.postSlide(targetSlide);
|
|
});
|
|
} else {
|
|
_.postSlide(targetSlide);
|
|
}
|
|
}
|
|
return;
|
|
} else if (_.options.infinite === false && _.options.centerMode === true && (index < 0 || index > (_.slideCount - _.options.slidesToScroll))) {
|
|
if (_.options.fade === false) {
|
|
targetSlide = _.currentSlide;
|
|
if (dontAnimate !== true) {
|
|
_.animateSlide(slideLeft, function() {
|
|
_.postSlide(targetSlide);
|
|
});
|
|
} else {
|
|
_.postSlide(targetSlide);
|
|
}
|
|
}
|
|
return;
|
|
}
|
|
|
|
if ( _.options.autoplay ) {
|
|
clearInterval(_.autoPlayTimer);
|
|
}
|
|
|
|
if (targetSlide < 0) {
|
|
if (_.slideCount % _.options.slidesToScroll !== 0) {
|
|
animSlide = _.slideCount - (_.slideCount % _.options.slidesToScroll);
|
|
} else {
|
|
animSlide = _.slideCount + targetSlide;
|
|
}
|
|
} else if (targetSlide >= _.slideCount) {
|
|
if (_.slideCount % _.options.slidesToScroll !== 0) {
|
|
animSlide = 0;
|
|
} else {
|
|
animSlide = targetSlide - _.slideCount;
|
|
}
|
|
} else {
|
|
animSlide = targetSlide;
|
|
}
|
|
|
|
_.animating = true;
|
|
|
|
_.$slider.trigger('beforeChange', [_, _.currentSlide, animSlide]);
|
|
|
|
oldSlide = _.currentSlide;
|
|
_.currentSlide = animSlide;
|
|
|
|
_.setSlideClasses(_.currentSlide);
|
|
|
|
if ( _.options.asNavFor ) {
|
|
|
|
navTarget = _.getNavTarget();
|
|
navTarget = navTarget.slick('getSlick');
|
|
|
|
if ( navTarget.slideCount <= navTarget.options.slidesToShow ) {
|
|
navTarget.setSlideClasses(_.currentSlide);
|
|
}
|
|
|
|
}
|
|
|
|
_.updateDots();
|
|
_.updateArrows();
|
|
|
|
if (_.options.fade === true) {
|
|
if (dontAnimate !== true) {
|
|
|
|
_.fadeSlideOut(oldSlide);
|
|
|
|
_.fadeSlide(animSlide, function() {
|
|
_.postSlide(animSlide);
|
|
});
|
|
|
|
} else {
|
|
_.postSlide(animSlide);
|
|
}
|
|
_.animateHeight();
|
|
return;
|
|
}
|
|
|
|
if (dontAnimate !== true) {
|
|
_.animateSlide(targetLeft, function() {
|
|
_.postSlide(animSlide);
|
|
});
|
|
} else {
|
|
_.postSlide(animSlide);
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.startLoad = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.options.arrows === true && _.slideCount > _.options.slidesToShow) {
|
|
|
|
_.$prevArrow.hide();
|
|
_.$nextArrow.hide();
|
|
|
|
}
|
|
|
|
if (_.options.dots === true && _.slideCount > _.options.slidesToShow) {
|
|
|
|
_.$dots.hide();
|
|
|
|
}
|
|
|
|
_.$slider.addClass('slick-loading');
|
|
|
|
};
|
|
|
|
Slick.prototype.swipeDirection = function() {
|
|
|
|
var xDist, yDist, r, swipeAngle, _ = this;
|
|
|
|
xDist = _.touchObject.startX - _.touchObject.curX;
|
|
yDist = _.touchObject.startY - _.touchObject.curY;
|
|
r = Math.atan2(yDist, xDist);
|
|
|
|
swipeAngle = Math.round(r * 180 / Math.PI);
|
|
if (swipeAngle < 0) {
|
|
swipeAngle = 360 - Math.abs(swipeAngle);
|
|
}
|
|
|
|
if ((swipeAngle <= 45) && (swipeAngle >= 0)) {
|
|
return (_.options.rtl === false ? 'left' : 'right');
|
|
}
|
|
if ((swipeAngle <= 360) && (swipeAngle >= 315)) {
|
|
return (_.options.rtl === false ? 'left' : 'right');
|
|
}
|
|
if ((swipeAngle >= 135) && (swipeAngle <= 225)) {
|
|
return (_.options.rtl === false ? 'right' : 'left');
|
|
}
|
|
if (_.options.verticalSwiping === true) {
|
|
if ((swipeAngle >= 35) && (swipeAngle <= 135)) {
|
|
return 'down';
|
|
} else {
|
|
return 'up';
|
|
}
|
|
}
|
|
|
|
return 'vertical';
|
|
|
|
};
|
|
|
|
Slick.prototype.swipeEnd = function(event) {
|
|
|
|
var _ = this,
|
|
slideCount,
|
|
direction;
|
|
|
|
_.dragging = false;
|
|
_.interrupted = false;
|
|
_.shouldClick = ( _.touchObject.swipeLength > 10 ) ? false : true;
|
|
|
|
if ( _.touchObject.curX === undefined ) {
|
|
return false;
|
|
}
|
|
|
|
if ( _.touchObject.edgeHit === true ) {
|
|
_.$slider.trigger('edge', [_, _.swipeDirection() ]);
|
|
}
|
|
|
|
if ( _.touchObject.swipeLength >= _.touchObject.minSwipe ) {
|
|
|
|
direction = _.swipeDirection();
|
|
|
|
switch ( direction ) {
|
|
|
|
case 'left':
|
|
case 'down':
|
|
|
|
slideCount =
|
|
_.options.swipeToSlide ?
|
|
_.checkNavigable( _.currentSlide + _.getSlideCount() ) :
|
|
_.currentSlide + _.getSlideCount();
|
|
|
|
_.currentDirection = 0;
|
|
|
|
break;
|
|
|
|
case 'right':
|
|
case 'up':
|
|
|
|
slideCount =
|
|
_.options.swipeToSlide ?
|
|
_.checkNavigable( _.currentSlide - _.getSlideCount() ) :
|
|
_.currentSlide - _.getSlideCount();
|
|
|
|
_.currentDirection = 1;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
|
|
}
|
|
|
|
if( direction != 'vertical' ) {
|
|
|
|
_.slideHandler( slideCount );
|
|
_.touchObject = {};
|
|
_.$slider.trigger('swipe', [_, direction ]);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ( _.touchObject.startX !== _.touchObject.curX ) {
|
|
|
|
_.slideHandler( _.currentSlide );
|
|
_.touchObject = {};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.swipeHandler = function(event) {
|
|
|
|
var _ = this;
|
|
|
|
if ((_.options.swipe === false) || ('ontouchend' in document && _.options.swipe === false)) {
|
|
return;
|
|
} else if (_.options.draggable === false && event.type.indexOf('mouse') !== -1) {
|
|
return;
|
|
}
|
|
|
|
_.touchObject.fingerCount = event.originalEvent && event.originalEvent.touches !== undefined ?
|
|
event.originalEvent.touches.length : 1;
|
|
|
|
_.touchObject.minSwipe = _.listWidth / _.options
|
|
.touchThreshold;
|
|
|
|
if (_.options.verticalSwiping === true) {
|
|
_.touchObject.minSwipe = _.listHeight / _.options
|
|
.touchThreshold;
|
|
}
|
|
|
|
switch (event.data.action) {
|
|
|
|
case 'start':
|
|
_.swipeStart(event);
|
|
break;
|
|
|
|
case 'move':
|
|
_.swipeMove(event);
|
|
break;
|
|
|
|
case 'end':
|
|
_.swipeEnd(event);
|
|
break;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.swipeMove = function(event) {
|
|
|
|
var _ = this,
|
|
edgeWasHit = false,
|
|
curLeft, swipeDirection, swipeLength, positionOffset, touches;
|
|
|
|
touches = event.originalEvent !== undefined ? event.originalEvent.touches : null;
|
|
|
|
if (!_.dragging || touches && touches.length !== 1) {
|
|
return false;
|
|
}
|
|
|
|
curLeft = _.getLeft(_.currentSlide);
|
|
|
|
_.touchObject.curX = touches !== undefined ? touches[0].pageX : event.clientX;
|
|
_.touchObject.curY = touches !== undefined ? touches[0].pageY : event.clientY;
|
|
|
|
_.touchObject.swipeLength = Math.round(Math.sqrt(
|
|
Math.pow(_.touchObject.curX - _.touchObject.startX, 2)));
|
|
|
|
if (_.options.verticalSwiping === true) {
|
|
_.touchObject.swipeLength = Math.round(Math.sqrt(
|
|
Math.pow(_.touchObject.curY - _.touchObject.startY, 2)));
|
|
}
|
|
|
|
swipeDirection = _.swipeDirection();
|
|
|
|
if (swipeDirection === 'vertical') {
|
|
return;
|
|
}
|
|
|
|
if (event.originalEvent !== undefined && _.touchObject.swipeLength > 4) {
|
|
event.preventDefault();
|
|
}
|
|
|
|
positionOffset = (_.options.rtl === false ? 1 : -1) * (_.touchObject.curX > _.touchObject.startX ? 1 : -1);
|
|
if (_.options.verticalSwiping === true) {
|
|
positionOffset = _.touchObject.curY > _.touchObject.startY ? 1 : -1;
|
|
}
|
|
|
|
|
|
swipeLength = _.touchObject.swipeLength;
|
|
|
|
_.touchObject.edgeHit = false;
|
|
|
|
if (_.options.infinite === false) {
|
|
if ((_.currentSlide === 0 && swipeDirection === 'right') || (_.currentSlide >= _.getDotCount() && swipeDirection === 'left')) {
|
|
swipeLength = _.touchObject.swipeLength * _.options.edgeFriction;
|
|
_.touchObject.edgeHit = true;
|
|
}
|
|
}
|
|
|
|
if (_.options.vertical === false) {
|
|
_.swipeLeft = curLeft + swipeLength * positionOffset;
|
|
} else {
|
|
_.swipeLeft = curLeft + (swipeLength * (_.$list.height() / _.listWidth)) * positionOffset;
|
|
}
|
|
if (_.options.verticalSwiping === true) {
|
|
_.swipeLeft = curLeft + swipeLength * positionOffset;
|
|
}
|
|
|
|
if (_.options.fade === true || _.options.touchMove === false) {
|
|
return false;
|
|
}
|
|
|
|
if (_.animating === true) {
|
|
_.swipeLeft = null;
|
|
return false;
|
|
}
|
|
|
|
_.setCSS(_.swipeLeft);
|
|
|
|
};
|
|
|
|
Slick.prototype.swipeStart = function(event) {
|
|
|
|
var _ = this,
|
|
touches;
|
|
|
|
_.interrupted = true;
|
|
|
|
if (_.touchObject.fingerCount !== 1 || _.slideCount <= _.options.slidesToShow) {
|
|
_.touchObject = {};
|
|
return false;
|
|
}
|
|
|
|
if (event.originalEvent !== undefined && event.originalEvent.touches !== undefined) {
|
|
touches = event.originalEvent.touches[0];
|
|
}
|
|
|
|
_.touchObject.startX = _.touchObject.curX = touches !== undefined ? touches.pageX : event.clientX;
|
|
_.touchObject.startY = _.touchObject.curY = touches !== undefined ? touches.pageY : event.clientY;
|
|
|
|
_.dragging = true;
|
|
|
|
};
|
|
|
|
Slick.prototype.unfilterSlides = Slick.prototype.slickUnfilter = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.$slidesCache !== null) {
|
|
|
|
_.unload();
|
|
|
|
_.$slideTrack.children(this.options.slide).detach();
|
|
|
|
_.$slidesCache.appendTo(_.$slideTrack);
|
|
|
|
_.reinit();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.unload = function() {
|
|
|
|
var _ = this;
|
|
|
|
$('.slick-cloned', _.$slider).remove();
|
|
|
|
if (_.$dots) {
|
|
_.$dots.remove();
|
|
}
|
|
|
|
if (_.$prevArrow && _.htmlExpr.test(_.options.prevArrow)) {
|
|
_.$prevArrow.remove();
|
|
}
|
|
|
|
if (_.$nextArrow && _.htmlExpr.test(_.options.nextArrow)) {
|
|
_.$nextArrow.remove();
|
|
}
|
|
|
|
_.$slides
|
|
.removeClass('slick-slide slick-active slick-visible slick-current')
|
|
.attr('aria-hidden', 'true')
|
|
.css('width', '');
|
|
|
|
};
|
|
|
|
Slick.prototype.unslick = function(fromBreakpoint) {
|
|
|
|
var _ = this;
|
|
_.$slider.trigger('unslick', [_, fromBreakpoint]);
|
|
_.destroy();
|
|
|
|
};
|
|
|
|
Slick.prototype.updateArrows = function() {
|
|
|
|
var _ = this,
|
|
centerOffset;
|
|
|
|
centerOffset = Math.floor(_.options.slidesToShow / 2);
|
|
|
|
if ( _.options.arrows === true &&
|
|
_.slideCount > _.options.slidesToShow &&
|
|
!_.options.infinite ) {
|
|
|
|
_.$prevArrow.removeClass('slick-disabled').attr('aria-disabled', 'false');
|
|
_.$nextArrow.removeClass('slick-disabled').attr('aria-disabled', 'false');
|
|
|
|
if (_.currentSlide === 0) {
|
|
|
|
_.$prevArrow.addClass('slick-disabled').attr('aria-disabled', 'true');
|
|
_.$nextArrow.removeClass('slick-disabled').attr('aria-disabled', 'false');
|
|
|
|
} else if (_.currentSlide >= _.slideCount - _.options.slidesToShow && _.options.centerMode === false) {
|
|
|
|
_.$nextArrow.addClass('slick-disabled').attr('aria-disabled', 'true');
|
|
_.$prevArrow.removeClass('slick-disabled').attr('aria-disabled', 'false');
|
|
|
|
} else if (_.currentSlide >= _.slideCount - 1 && _.options.centerMode === true) {
|
|
|
|
_.$nextArrow.addClass('slick-disabled').attr('aria-disabled', 'true');
|
|
_.$prevArrow.removeClass('slick-disabled').attr('aria-disabled', 'false');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.updateDots = function() {
|
|
|
|
var _ = this;
|
|
|
|
if (_.$dots !== null) {
|
|
|
|
_.$dots
|
|
.find('li')
|
|
.removeClass('slick-active')
|
|
.attr('aria-hidden', 'true');
|
|
|
|
_.$dots
|
|
.find('li')
|
|
.eq(Math.floor(_.currentSlide / _.options.slidesToScroll))
|
|
.addClass('slick-active')
|
|
.attr('aria-hidden', 'false');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
Slick.prototype.visibility = function() {
|
|
|
|
var _ = this;
|
|
|
|
if ( _.options.autoplay ) {
|
|
|
|
if ( document[_.hidden] ) {
|
|
|
|
_.interrupted = true;
|
|
|
|
} else {
|
|
|
|
_.interrupted = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
$.fn.slick = function() {
|
|
var _ = this,
|
|
opt = arguments[0],
|
|
args = Array.prototype.slice.call(arguments, 1),
|
|
l = _.length,
|
|
i,
|
|
ret;
|
|
for (i = 0; i < l; i++) {
|
|
if (typeof opt == 'object' || typeof opt == 'undefined')
|
|
_[i].slick = new Slick(_[i], opt);
|
|
else
|
|
ret = _[i].slick[opt].apply(_[i].slick, args);
|
|
if (typeof ret != 'undefined') return ret;
|
|
}
|
|
return _;
|
|
};
|
|
|
|
}));
|
|
|
|
// https://github.com/ghiculescu/jekyll-table-of-contents
|
|
(function ($) {
|
|
$.fn.toc = function (options) {
|
|
var defaults = {
|
|
noBackToTopLinks: false,
|
|
title: "<h2>Table of contents</h2>",
|
|
minimumHeaders: 3,
|
|
headers: "h1, h2, h3, h4, h5, h6",
|
|
listType: "ol", // values: [ol|ul]
|
|
showEffect: "show", // values: [show|slideDown|fadeIn|none]
|
|
showSpeed: "slow" // set to 0 to deactivate effect
|
|
},
|
|
settings = $.extend(defaults, options);
|
|
|
|
function fixedEncodeURIComponent(str) {
|
|
return encodeURIComponent(str).replace(/[!"()*]/g, function (c) {
|
|
return "%" + c.charCodeAt(0).toString(16);
|
|
});
|
|
}
|
|
|
|
var headers = $(settings.headers).filter(function () {
|
|
// get all headers with an ID
|
|
var previousSiblingName = $(this).prev().attr("name");
|
|
if (!this.id && previousSiblingName) {
|
|
this.id = $(this).attr("id", previousSiblingName.replace(/\./g, "-"));
|
|
}
|
|
return this.id;
|
|
}), output = $(this);
|
|
if (!headers.length || headers.length < settings.minimumHeaders || !output.length) {
|
|
return;
|
|
}
|
|
|
|
if (0 === settings.showSpeed) {
|
|
settings.showEffect = "none";
|
|
}
|
|
|
|
var render = {
|
|
show: function () {
|
|
output.hide().html(html).show(settings.showSpeed);
|
|
},
|
|
slideDown: function () {
|
|
output.hide().html(html).slideDown(settings.showSpeed);
|
|
},
|
|
fadeIn: function () {
|
|
output.hide().html(html).fadeIn(settings.showSpeed);
|
|
},
|
|
none: function () {
|
|
output.html(html);
|
|
}
|
|
};
|
|
|
|
var get_level = function (ele) {
|
|
return parseInt(ele.nodeName.replace("H", ""), 10);
|
|
}
|
|
var highest_level = headers.map(function (_, ele) {
|
|
return get_level(ele);
|
|
}).get().sort()[0];
|
|
var return_to_top = "<i class=\"fa fa-caret-up back-to-top\"> </i>";
|
|
|
|
var level = get_level(headers[0]),
|
|
this_level,
|
|
html = "<" + settings.listType + ">";
|
|
headers.on("click", function () {
|
|
if (!settings.noBackToTopLinks) {
|
|
window.location.hash = this.id;
|
|
}
|
|
})
|
|
.addClass("clickable-header")
|
|
.each(function (_, header) {
|
|
this_level = get_level(header);
|
|
if (!settings.noBackToTopLinks && this_level === highest_level) {
|
|
$(header).addClass("top-level-header").after(return_to_top);
|
|
}
|
|
if (this_level === level) // same level as before; same indenting
|
|
html += "<li><a href=\"#" + fixedEncodeURIComponent(header.id) + "\">" + header.innerHTML + "</a>";
|
|
else if (this_level <= level) { // higher level than before; end parent ol
|
|
for (i = this_level; i < level; i++) {
|
|
html += "</li></" + settings.listType + ">"
|
|
}
|
|
html += "<li><a href=\"#" + fixedEncodeURIComponent(header.id) + "\">" + header.innerHTML + "</a>";
|
|
}
|
|
else if (this_level > level) { // lower level than before; expand the previous to contain a ol
|
|
for (i = this_level; i > level; i--) {
|
|
html += "<" + settings.listType + "><li>"
|
|
}
|
|
html += "<a href=\"#" + fixedEncodeURIComponent(header.id) + "\">" + header.innerHTML + "</a>";
|
|
}
|
|
level = this_level; // update for the next one
|
|
});
|
|
html += "</" + settings.listType + ">";
|
|
if (!settings.noBackToTopLinks) {
|
|
$(document).on("click", ".back-to-top", function () {
|
|
$(window).scrollTop(0);
|
|
window.location.hash = "";
|
|
return false;
|
|
});
|
|
}
|
|
|
|
render[settings.showEffect]();
|
|
};
|
|
})(jQuery);
|
|
|
|
String.format = function () {
|
|
var myString = arguments[0];
|
|
for (var i = 1; i < arguments.length; i++) {
|
|
var regX = new RegExp("\\{" + (i - 1) + "\\}", "gm");
|
|
myString = myString.replace(regX, arguments[i]);
|
|
}
|
|
return myString;
|
|
};
|
|
|
|
Date.prototype.addHours = function (hours) {
|
|
return new Date(
|
|
this.getFullYear(),
|
|
this.getMonth(),
|
|
this.getDate(),
|
|
this.getHours() + hours,
|
|
this.getMinutes(),
|
|
this.getSeconds(),
|
|
this.getMilliseconds()
|
|
);
|
|
};
|
|
|
|
window.utils = window.utils || {};
|
|
utils.getQueryParam = function (name) {
|
|
"use strict";
|
|
name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
|
|
var regex = new RegExp("[\\?&]" + name + "=([^&#]*)"),
|
|
results = regex.exec(location.search);
|
|
return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " "));
|
|
};
|
|
|
|
utils.countOccurrences = function (text, searchTerm) {
|
|
text += "";
|
|
searchTerm += "";
|
|
if (searchTerm.length <= 0) return text.length + 1;
|
|
|
|
var n = 0, pos = 0;
|
|
var step = searchTerm.length;
|
|
|
|
while (true) {
|
|
pos = text.indexOf(searchTerm, pos);
|
|
if (pos >= 0) {
|
|
n++;
|
|
pos += step;
|
|
} else break;
|
|
}
|
|
return (n);
|
|
};
|
|
|
|
window.app = window.app || {};
|
|
window.app.analytics = (function () {
|
|
|
|
|
|
function sendEvent(category, action, label, value) {
|
|
|
|
if (!window.ga) {
|
|
return;
|
|
}
|
|
|
|
try {
|
|
ga("send", "event", category, action, label, value);
|
|
} catch(ex) {}
|
|
}
|
|
|
|
|
|
return {
|
|
sendEvent: sendEvent
|
|
};
|
|
})();
|
|
|
|
window.app = window.app || {};
|
|
window.app.storage = (function () {
|
|
|
|
var prefix = "ace3_";
|
|
var timeToInvalidateItem = 1; // 1h
|
|
|
|
// gets an item from sessionStorage and checks if the time to invalidate the item is over
|
|
function getItem (key) {
|
|
var currentItem = window.sessionStorage.getItem(prefix + key);
|
|
|
|
if (!currentItem) {
|
|
return null;
|
|
}
|
|
|
|
currentItem = JSON.parse(currentItem);
|
|
|
|
// item is valid
|
|
if (new Date(currentItem.date).addHours(timeToInvalidateItem) > new Date()) {
|
|
return currentItem.item;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
// saves an item in the sessionStorage and adds a timestamp
|
|
function setItem (key, value) {
|
|
|
|
var itemToSave = {
|
|
date: new Date(),
|
|
item: value
|
|
};
|
|
|
|
var currentItem = JSON.stringify(itemToSave);
|
|
|
|
window.sessionStorage.setItem(prefix + key, currentItem);
|
|
}
|
|
|
|
return {
|
|
getItem: getItem,
|
|
setItem: setItem
|
|
};
|
|
})();
|
|
|
|
window.app = window.app || {};
|
|
window.app.contentSearch = (function ($) {
|
|
|
|
var searchJsonUrl = "/js/search.json";
|
|
var storageKeyName = "searchResult";
|
|
|
|
var searchTermParamName = "searchTerm";
|
|
|
|
var _searchStartLength = 3;
|
|
var _maxEntriesLive = 10;
|
|
var _maxEntriesContent = 25;
|
|
var _maxDescriptionLengthLive = 80;
|
|
var _maxDescriptionLengthContent = 140;
|
|
|
|
var _searchTerm = "";
|
|
var _searchTermCombined = "";
|
|
var _timeOutID;
|
|
|
|
var $liveSearch = $("#liveSearch");
|
|
|
|
var $liveSearchField = $liveSearch.find(".liveSearch-field");
|
|
var $liveSearchResultList = $liveSearch.find(".liveSearch-result-list");
|
|
var $liveSearchButton = $liveSearch.find(".liveSearch-button");
|
|
|
|
|
|
var $contentSearchField = $liveSearch.find(".contentSearch-field");
|
|
var $contentSearchResultList = $(".searchPage-result-list");
|
|
|
|
function init() {
|
|
|
|
updateSearchFieldFromQueryParams();
|
|
|
|
$liveSearchField.on("keyup", handleLiveKeyDown);
|
|
$liveSearchField.on("blur", function () {
|
|
setTimeout(hideLiveResultList, 300);
|
|
});
|
|
$liveSearchButton.on("click", openSearchPage);
|
|
|
|
$contentSearchField.on("keyup", handleContentKeyDown);
|
|
|
|
}
|
|
|
|
|
|
/*
|
|
===
|
|
UTIL
|
|
===
|
|
*/
|
|
|
|
function findSearchTermInArray(response, maxEntries) {
|
|
var results = [],
|
|
i = 0,
|
|
j = 0,
|
|
length = response.length,
|
|
text = "",
|
|
multiplier = 0;
|
|
|
|
for (i; i < length; i++) {
|
|
|
|
var found = false;
|
|
|
|
if (results.length >= maxEntries) {
|
|
break;
|
|
}
|
|
|
|
var currentPage = response[i];
|
|
currentPage.value = 0;
|
|
|
|
var occurrences = 0;
|
|
|
|
for (j = 0; j < 4; j++) {
|
|
|
|
occurrences = 0;
|
|
|
|
switch (j) {
|
|
case 0:
|
|
text = currentPage.description.toLowerCase();
|
|
multiplier = 100;
|
|
break;
|
|
case 1:
|
|
text = currentPage.title.toLowerCase();
|
|
multiplier = 1000;
|
|
break;
|
|
case 2:
|
|
text = currentPage.group.toLowerCase();
|
|
multiplier = 10;
|
|
break;
|
|
case 3:
|
|
text = currentPage.content.toLowerCase();
|
|
multiplier = 1;
|
|
}
|
|
|
|
if (text.indexOf(_searchTerm) >= 0 || text.indexOf(_searchTermCombined) >= 0) {
|
|
found = true;
|
|
occurrences = utils.countOccurrences(text, _searchTerm);
|
|
|
|
if (_searchTermCombined !== _searchTerm) {
|
|
occurrences += utils.countOccurrences(text, _searchTermCombined);
|
|
}
|
|
|
|
if (occurrences > 0) {
|
|
currentPage.value += (occurrences * multiplier);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (found) {
|
|
results.push(currentPage);
|
|
}
|
|
|
|
}
|
|
|
|
results = results.sort(function(x,y) {
|
|
if (x.value > y.value) {
|
|
return -1;
|
|
} else if(y.value > x.value) {
|
|
return 1;
|
|
} else {
|
|
return 0;
|
|
}
|
|
});
|
|
|
|
return results;
|
|
}
|
|
|
|
function getSearchResults() {
|
|
return $.getJSON(searchJsonUrl);
|
|
}
|
|
|
|
function searchTermValid(searchTerm) {
|
|
if (searchTerm === "" || searchTerm.length < _searchStartLength) {
|
|
return false;
|
|
} else {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
===
|
|
LIVE SEARCH
|
|
===
|
|
*/
|
|
|
|
function handleLiveKeyDown(e) {
|
|
|
|
// arrow down, arrow up
|
|
if (e.keyCode === 38 || e.keyCode === 40) {
|
|
e.preventDefault();
|
|
return false;
|
|
}
|
|
|
|
// enter
|
|
if (e.keyCode === 13) {
|
|
e.preventDefault();
|
|
openSearchPage(e);
|
|
return false;
|
|
}
|
|
|
|
// delays input and makes sure that only a complete search is sent
|
|
clearTimeout(_timeOutID);
|
|
_timeOutID = setTimeout(search, 300);
|
|
}
|
|
|
|
function showLiveResultList(results) {
|
|
if (!results) {
|
|
$liveSearchResultList.removeClass("hidden");
|
|
return;
|
|
}
|
|
|
|
var i = 0,
|
|
length = results.length;
|
|
|
|
var html = "";
|
|
|
|
for (i; i < length; i++) {
|
|
var currentPage = results[i];
|
|
|
|
var description = currentPage.description;
|
|
if (description.length > _maxDescriptionLengthLive) {
|
|
description = description.substr(0, _maxDescriptionLengthLive) + "…"
|
|
}
|
|
|
|
html += String.format("<li><a href=\"{1}\">{0}<br><small>{2}</small></a></li>", currentPage.title, currentPage.url, description);
|
|
}
|
|
|
|
$liveSearchResultList.empty().append(html).removeClass("hidden");
|
|
}
|
|
|
|
function hideLiveResultList() {
|
|
$liveSearchResultList.addClass("hidden");
|
|
}
|
|
|
|
function search() {
|
|
var term = $liveSearchField.val();
|
|
|
|
_searchTerm = term.trim().toLowerCase();
|
|
_searchTermCombined = _searchTerm.replace(" ", "");
|
|
|
|
if (!searchTermValid(_searchTerm)) {
|
|
$liveSearchResultList.empty();
|
|
return false;
|
|
}
|
|
|
|
startLiveSearch();
|
|
}
|
|
|
|
function startLiveSearch() {
|
|
var cachedSearchResults = app.storage.getItem(storageKeyName);
|
|
if (!cachedSearchResults) {
|
|
getSearchResults().done(function (response) {
|
|
app.storage.setItem(storageKeyName, response);
|
|
handleLiveSearchResult(response);
|
|
});
|
|
} else {
|
|
handleLiveSearchResult(cachedSearchResults);
|
|
}
|
|
}
|
|
|
|
function handleLiveSearchResult(response) {
|
|
var results = findSearchTermInArray(response, _maxEntriesLive);
|
|
app.analytics.sendEvent("LiveSearch", "Search", _searchTerm);
|
|
showLiveResultList(results);
|
|
}
|
|
|
|
function openSearchPage(e) {
|
|
e.preventDefault();
|
|
var searchTerm = $liveSearchField.val().trim();
|
|
app.analytics.sendEvent("LiveSearch", "OpenSearchPage", searchTerm);
|
|
document.location.href = String.format("search.html?{0}={1}", searchTermParamName, encodeURIComponent(searchTerm));
|
|
return false;
|
|
}
|
|
|
|
|
|
/*
|
|
===
|
|
CONTENT SEARCH
|
|
===
|
|
*/
|
|
|
|
function handleContentKeyDown(e) {
|
|
|
|
// arrow down, arrow up
|
|
if (e.keyCode === 38 || e.keyCode === 40) {
|
|
e.preventDefault();
|
|
return false;
|
|
}
|
|
|
|
// enter
|
|
if (e.keyCode === 13) {
|
|
e.preventDefault();
|
|
contentSearch();
|
|
return false;
|
|
}
|
|
|
|
// delays input and makes sure that only a complete search is sent
|
|
clearTimeout(_timeOutID);
|
|
_timeOutID = setTimeout(contentSearch, 300);
|
|
}
|
|
|
|
function contentSearch() {
|
|
var term = $contentSearchField.val();
|
|
|
|
_searchTerm = term.trim().toLowerCase();
|
|
_searchTermCombined = _searchTerm.replace(" ", "");
|
|
|
|
if (!searchTermValid(_searchTerm)) {
|
|
return false;
|
|
}
|
|
startContentSearch();
|
|
}
|
|
|
|
function updateSearchFieldFromQueryParams() {
|
|
_searchTerm = utils.getQueryParam(searchTermParamName);
|
|
_searchTermCombined = _searchTerm.replace(" ", "");
|
|
$contentSearchField.val(_searchTerm);
|
|
if (searchTermValid(_searchTerm)) {
|
|
startContentSearch();
|
|
}
|
|
}
|
|
|
|
function startContentSearch() {
|
|
var cachedSearchResults = app.storage.getItem(storageKeyName);
|
|
if (!cachedSearchResults) {
|
|
getSearchResults().done(function (response) {
|
|
app.storage.setItem(storageKeyName, response);
|
|
handleContentSearchResult(response);
|
|
});
|
|
} else {
|
|
handleContentSearchResult(cachedSearchResults);
|
|
}
|
|
}
|
|
|
|
|
|
function handleContentSearchResult(response) {
|
|
var results = findSearchTermInArray(response, _maxEntriesContent);
|
|
app.analytics.sendEvent("ContentSearch", "Search", _searchTerm);
|
|
showContentResultList(results);
|
|
}
|
|
|
|
function showContentResultList(results) {
|
|
var i = 0,
|
|
length = results.length;
|
|
|
|
var html = "";
|
|
|
|
for (i; i < length; i++) {
|
|
var currentPage = results[i];
|
|
|
|
var description = currentPage.description;
|
|
if (description.length > _maxDescriptionLengthContent) {
|
|
description = description.substr(0, _maxDescriptionLengthContent) + "…"
|
|
}
|
|
|
|
html += String.format("<li><a href=\"{1}\">{0}</a><span class=\"additionalInfo\"><br><small><span class=\"url\">{3}</span><br><span class\"description\">{2}</small></small></span></li>", currentPage.title, currentPage.url, description, document.location.origin + currentPage.url);
|
|
}
|
|
|
|
$contentSearchResultList.empty().append(html);
|
|
}
|
|
|
|
return {
|
|
init: init
|
|
};
|
|
|
|
|
|
})(jQuery);
|
|
|
|
jQuery(document).foundation();
|
|
|
|
jQuery(document).ready(function(){
|
|
var $slider = jQuery(".slider");
|
|
if ($slider.length > 0) {
|
|
$slider.slick({
|
|
arrows: true,
|
|
dots: true,
|
|
slidesToShow: 1,
|
|
slidesToScroll: 1,
|
|
autoplay: true,
|
|
autoplaySpeed: 6000,
|
|
responsive: [
|
|
{
|
|
breakpoint: 640,
|
|
settings: {
|
|
arrows: false
|
|
}
|
|
}
|
|
]
|
|
});
|
|
}
|
|
|
|
|
|
var $toc = jQuery("#toc");
|
|
if ($toc.length > 0) {
|
|
$toc.toc({
|
|
headers: "#content h2, #content h3, #content h4, #content h5, #content h6",
|
|
showEffect: "none"
|
|
});
|
|
|
|
if ($toc.html() === "") {
|
|
jQuery(".js-expandToc").remove();
|
|
jQuery(".toc-header").remove();
|
|
}
|
|
}
|
|
|
|
|
|
var $tables = $("#content table");
|
|
$tables.each(function(index, item) {
|
|
var $table = $(item);
|
|
$table.wrap("<div class=\"table-wrapper\">")
|
|
});
|
|
});
|
|
|
|
window.app = window.app || {};
|
|
|
|
window.app.contentSearch.init();
|