diff --git a/lib/assets/scripts/bottles.js b/lib/assets/scripts/bottles.js deleted file mode 100644 index b2cf69c..0000000 --- a/lib/assets/scripts/bottles.js +++ /dev/null @@ -1,55 +0,0 @@ -function Bottles() { - const [bottles, setBottles] = React.useState(); - const [isLoading, setLoading] = React.useState(true); - React.useEffect(() => { - fetch("https://app.tea.xyz/api/bottles").then(res => res.json()).then(res => { - setBottles(res); - setLoading(false); - }); - }, []); - if (isLoading) return /*#__PURE__*/React.createElement("div", { - id: "bottle-preloader", - className: "flex" - }, /*#__PURE__*/React.createElement("div", { - id: "bottle-status", - className: "my-auto" - }, /*#__PURE__*/React.createElement("i", { - className: "icon-tea-logo-iconasset-1 grid-gray tea-icon lead mb-0" - }), /*#__PURE__*/React.createElement("div", { - id: "bottle-loading-text" - }, /*#__PURE__*/React.createElement("p", { - className: "grid-gray" - }, "steeping...")))); - if (!bottles) return null; - const names = [...new Set(bottles.map(b => b.name))]; - return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("p", null, "Showing ", names.length, " packages"), names.map(name => /*#__PURE__*/React.createElement(Bottle, { - key: name, - name: name - }))); - function Bottle({ - name - }) { - const [expanded, toggleExpanded] = React.useState(false); - const versions = [...new Set(bottles.filter(b => b.name === name).map(b => b.version))]; - return /*#__PURE__*/React.createElement("div", { - className: "expand", - onClick: () => toggleExpanded(!expanded) - }, /*#__PURE__*/React.createElement("div", { - className: "expand-text one-box-down" - }, /*#__PURE__*/React.createElement("h3", { - className: "display-3" - }, name), /*#__PURE__*/React.createElement("h4", { - className: "display-6" - }, versions.length, " version", versions.length === 1 ? "" : "s", " bottled")), expanded && /*#__PURE__*/React.createElement("table", { - className: "one-box-down" - }, /*#__PURE__*/React.createElement("thead", null, /*#__PURE__*/React.createElement("tr", null, /*#__PURE__*/React.createElement("th", null, "version"), /*#__PURE__*/React.createElement("th", null, "darwin-aarch64"), /*#__PURE__*/React.createElement("th", null, "darwin-x86-64"), /*#__PURE__*/React.createElement("th", null, "linux-aarch64"), /*#__PURE__*/React.createElement("th", null, "linux-x86-64"))), /*#__PURE__*/React.createElement("tbody", null, versions.map(v => { - const available = new Set(bottles.filter(b => b.name === name && b.version == v).map(b => `${b.platform}-${b.arch}`)); - return /*#__PURE__*/React.createElement("tr", { - key: v - }, /*#__PURE__*/React.createElement("th", null, v), /*#__PURE__*/React.createElement("td", null, available.has("darwin-aarch64") ? "✅" : "❌"), /*#__PURE__*/React.createElement("td", null, available.has("darwin-x86-64") ? "✅" : "❌"), /*#__PURE__*/React.createElement("td", null, available.has("linux-aarch64") ? "✅" : "❌"), /*#__PURE__*/React.createElement("td", null, available.has("linux-x86-64") ? "✅" : "❌")); - }))), /*#__PURE__*/React.createElement("div", { - className: "one-box-down" - }, /*#__PURE__*/React.createElement("hr", null))); - } -} -ReactDOM.render(React.createElement(Bottles), document.getElementById("app")); \ No newline at end of file diff --git a/lib/assets/scripts/package-bottles.js b/lib/assets/scripts/package-bottles.js deleted file mode 100644 index 0042751..0000000 --- a/lib/assets/scripts/package-bottles.js +++ /dev/null @@ -1,54 +0,0 @@ -function PackageBottles() { - const [bottles, setBottles] = React.useState(); - const [isLoading, setIsLoading] = React.useState(true); - React.useEffect(() => { - const url = window.location.pathname.replace('/+', 'https://app.tea.xyz/api/bottles/'); - fetch(url).then(res => res.json()).then(res => { - setBottles(res); - setIsLoading(false); - }); - }, []); - if (isLoading) return /*#__PURE__*/React.createElement("div", { - id: "bottle-preloader", - className: "flex one-box-down" - }, /*#__PURE__*/React.createElement("div", { - id: "bottle-status", - className: "flex justifit-content-center" - }, /*#__PURE__*/React.createElement("div", { - className: "mx-auto" - }, /*#__PURE__*/React.createElement("i", { - className: "icon-tea-logo-iconasset-1 grid-gray tea-icon lead mb-0" - }), /*#__PURE__*/React.createElement("div", { - id: "bottle-loading-text" - }, /*#__PURE__*/React.createElement("p", { - className: "grid-gray" - }, "steeping available versions..."))))); - if (!bottles) return null; - const names = [...new Set(bottles.map(b => b.name))]; - return /*#__PURE__*/React.createElement("div", null, names.map(name => /*#__PURE__*/React.createElement(Bottle, { - key: name, - name: name - }))); - function Bottle({ - name - }) { - const [expanded, toggleExpanded] = React.useState(false); - const versions = [...new Set(bottles.map(b => b.version))]; - return /*#__PURE__*/React.createElement("div", { - className: "expand", - onClick: () => toggleExpanded(!expanded) - }, /*#__PURE__*/React.createElement("div", { - className: "expand-text one-box-down" - }, /*#__PURE__*/React.createElement("h4", { - className: "display-6" - }, versions.length, " version", versions.length === 1 ? "" : "s", " bottled")), /*#__PURE__*/React.createElement("table", { - className: "one-box-down" - }, /*#__PURE__*/React.createElement("thead", null, /*#__PURE__*/React.createElement("tr", null, /*#__PURE__*/React.createElement("th", null, "version"), /*#__PURE__*/React.createElement("th", null, "darwin-aarch64"), /*#__PURE__*/React.createElement("th", null, "darwin-x86-64"), /*#__PURE__*/React.createElement("th", null, "linux-aarch64"), /*#__PURE__*/React.createElement("th", null, "linux-x86-64"))), /*#__PURE__*/React.createElement("tbody", null, versions.map(v => { - const available = new Set(bottles.filter(b => b.name === name && b.version == v).map(b => `${b.platform}-${b.arch}`)); - return /*#__PURE__*/React.createElement("tr", { - key: v - }, /*#__PURE__*/React.createElement("th", null, v), /*#__PURE__*/React.createElement("td", null, available.has("darwin-aarch64") ? "✅" : "❌"), /*#__PURE__*/React.createElement("td", null, available.has("darwin-x86-64") ? "✅" : "❌"), /*#__PURE__*/React.createElement("td", null, available.has("linux-aarch64") ? "✅" : "❌"), /*#__PURE__*/React.createElement("td", null, available.has("linux-x86-64") ? "✅" : "❌")); - })))); - } -} -ReactDOM.render(React.createElement(PackageBottles), document.getElementById("packageApp")); \ No newline at end of file diff --git a/lib/static/js/basic.js b/lib/static/js/basic.js deleted file mode 100644 index 80dd6fd..0000000 --- a/lib/static/js/basic.js +++ /dev/null @@ -1,80 +0,0 @@ -/* - * Basic sample -*/ - -function addPage(page, book) { - var id, - pages = book.turn('pages'); - - // Create a new element for this page - var element = $('
', {}); - - // Add the page to the flipbook - if (book.turn('addPage', element, page)) { - // Add the initial HTML - // It will contain a loader indicator and a gradient - element.html('
'); - - // Load the page - loadPage(page, element); - } -} -function loadPage(page, pageElement) { - // Create an image element - - var img = $(''); - img.mousedown(function (e) { - e.preventDefault(); - }); - img.load(function () { - // Set the size - $(this).css({ - width: '100%', - height: '100%' - }); - - // Add the image to the page after loaded - - $(this).appendTo(pageElement); - - // Remove the loader indicator - - pageElement.find('.loader').remove(); - }); - - // Load the page - - img.attr('src', 'pages/' + page + '.jpg'); -} -function loadLargePage(page, pageElement) { - var img = $(''); - img.load(function () { - var prevImg = pageElement.find('img'); - $(this).css({ - width: '100%', - height: '100%' - }); - $(this).appendTo(pageElement); - prevImg.remove(); - }); - - // Loadnew page - - img.attr('src', 'pages/' + page + '-large.jpg'); -} -function loadSmallPage(page, pageElement) { - var img = pageElement.find('img'); - img.css({ - width: '100%', - height: '100%' - }); - img.unbind('load'); - // Loadnew page - - img.attr('src', 'pages/' + page + '.jpg'); -} - -// http://code.google.com/p/chromium/issues/detail?id=128488 -function isChrome() { - return navigator.userAgent.indexOf('Chrome') != -1; -} \ No newline at end of file diff --git a/lib/static/js/jquery.min.1.7.js b/lib/static/js/jquery.min.1.7.js deleted file mode 100644 index 0f0c676..0000000 --- a/lib/static/js/jquery.min.1.7.js +++ /dev/null @@ -1,3831 +0,0 @@ -/*! jQuery v1.7 jquery.com | jquery.org/license */ -(function (a, b) { - function cA(a) { - return f.isWindow(a) ? a : a.nodeType === 9 ? a.defaultView || a.parentWindow : !1; - } - function cx(a) { - if (!cm[a]) { - var b = c.body, - d = f("<" + a + ">").appendTo(b), - e = d.css("display"); - d.remove(); - if (e === "none" || e === "") { - cn || (cn = c.createElement("iframe"), cn.frameBorder = cn.width = cn.height = 0), b.appendChild(cn); - if (!co || !cn.createElement) co = (cn.contentWindow || cn.contentDocument).document, co.write((c.compatMode === "CSS1Compat" ? "" : "") + ""), co.close(); - d = co.createElement(a), co.body.appendChild(d), e = f.css(d, "display"), b.removeChild(cn); - } - cm[a] = e; - } - return cm[a]; - } - function cw(a, b) { - var c = {}; - f.each(cs.concat.apply([], cs.slice(0, b)), function () { - c[this] = a; - }); - return c; - } - function cv() { - ct = b; - } - function cu() { - setTimeout(cv, 0); - return ct = f.now(); - } - function cl() { - try { - return new a.ActiveXObject("Microsoft.XMLHTTP"); - } catch (b) {} - } - function ck() { - try { - return new a.XMLHttpRequest(); - } catch (b) {} - } - function ce(a, c) { - a.dataFilter && (c = a.dataFilter(c, a.dataType)); - var d = a.dataTypes, - e = {}, - g, - h, - i = d.length, - j, - k = d[0], - l, - m, - n, - o, - p; - for (g = 1; g < i; g++) { - if (g === 1) for (h in a.converters) typeof h == "string" && (e[h.toLowerCase()] = a.converters[h]); - l = k, k = d[g]; - if (k === "*") k = l;else if (l !== "*" && l !== k) { - m = l + " " + k, n = e[m] || e["* " + k]; - if (!n) { - p = b; - for (o in e) { - j = o.split(" "); - if (j[0] === l || j[0] === "*") { - p = e[j[1] + " " + k]; - if (p) { - o = e[o], o === !0 ? n = p : p === !0 && (n = o); - break; - } - } - } - } - !n && !p && f.error("No conversion from " + m.replace(" ", " to ")), n !== !0 && (c = n ? n(c) : p(o(c))); - } - } - return c; - } - function cd(a, c, d) { - var e = a.contents, - f = a.dataTypes, - g = a.responseFields, - h, - i, - j, - k; - for (i in g) i in d && (c[g[i]] = d[i]); - while (f[0] === "*") f.shift(), h === b && (h = a.mimeType || c.getResponseHeader("content-type")); - if (h) for (i in e) if (e[i] && e[i].test(h)) { - f.unshift(i); - break; - } - if (f[0] in d) j = f[0];else { - for (i in d) { - if (!f[0] || a.converters[i + " " + f[0]]) { - j = i; - break; - } - k || (k = i); - } - j = j || k; - } - if (j) { - j !== f[0] && f.unshift(j); - return d[j]; - } - } - function cc(a, b, c, d) { - if (f.isArray(b)) f.each(b, function (b, e) { - c || bG.test(a) ? d(a, e) : cc(a + "[" + (typeof e == "object" || f.isArray(e) ? b : "") + "]", e, c, d); - });else if (!c && b != null && typeof b == "object") for (var e in b) cc(a + "[" + e + "]", b[e], c, d);else d(a, b); - } - function cb(a, c) { - var d, - e, - g = f.ajaxSettings.flatOptions || {}; - for (d in c) c[d] !== b && ((g[d] ? a : e || (e = {}))[d] = c[d]); - e && f.extend(!0, a, e); - } - function ca(a, c, d, e, f, g) { - f = f || c.dataTypes[0], g = g || {}, g[f] = !0; - var h = a[f], - i = 0, - j = h ? h.length : 0, - k = a === bV, - l; - for (; i < j && (k || !l); i++) l = h[i](c, d, e), typeof l == "string" && (!k || g[l] ? l = b : (c.dataTypes.unshift(l), l = ca(a, c, d, e, l, g))); - (k || !l) && !g["*"] && (l = ca(a, c, d, e, "*", g)); - return l; - } - function b_(a) { - return function (b, c) { - typeof b != "string" && (c = b, b = "*"); - if (f.isFunction(c)) { - var d = b.toLowerCase().split(bR), - e = 0, - g = d.length, - h, - i, - j; - for (; e < g; e++) h = d[e], j = /^\+/.test(h), j && (h = h.substr(1) || "*"), i = a[h] = a[h] || [], i[j ? "unshift" : "push"](c); - } - }; - } - function bE(a, b, c) { - var d = b === "width" ? a.offsetWidth : a.offsetHeight, - e = b === "width" ? bz : bA; - if (d > 0) { - c !== "border" && f.each(e, function () { - c || (d -= parseFloat(f.css(a, "padding" + this)) || 0), c === "margin" ? d += parseFloat(f.css(a, c + this)) || 0 : d -= parseFloat(f.css(a, "border" + this + "Width")) || 0; - }); - return d + "px"; - } - d = bB(a, b, b); - if (d < 0 || d == null) d = a.style[b] || 0; - d = parseFloat(d) || 0, c && f.each(e, function () { - d += parseFloat(f.css(a, "padding" + this)) || 0, c !== "padding" && (d += parseFloat(f.css(a, "border" + this + "Width")) || 0), c === "margin" && (d += parseFloat(f.css(a, c + this)) || 0); - }); - return d + "px"; - } - function br(a, b) { - b.src ? f.ajax({ - url: b.src, - async: !1, - dataType: "script" - }) : f.globalEval((b.text || b.textContent || b.innerHTML || "").replace(bi, "/*$0*/")), b.parentNode && b.parentNode.removeChild(b); - } - function bq(a) { - var b = (a.nodeName || "").toLowerCase(); - b === "input" ? bp(a) : b !== "script" && typeof a.getElementsByTagName != "undefined" && f.grep(a.getElementsByTagName("input"), bp); - } - function bp(a) { - if (a.type === "checkbox" || a.type === "radio") a.defaultChecked = a.checked; - } - function bo(a) { - return typeof a.getElementsByTagName != "undefined" ? a.getElementsByTagName("*") : typeof a.querySelectorAll != "undefined" ? a.querySelectorAll("*") : []; - } - function bn(a, b) { - var c; - if (b.nodeType === 1) { - b.clearAttributes && b.clearAttributes(), b.mergeAttributes && b.mergeAttributes(a), c = b.nodeName.toLowerCase(); - if (c === "object") b.outerHTML = a.outerHTML;else if (c !== "input" || a.type !== "checkbox" && a.type !== "radio") { - if (c === "option") b.selected = a.defaultSelected;else if (c === "input" || c === "textarea") b.defaultValue = a.defaultValue; - } else a.checked && (b.defaultChecked = b.checked = a.checked), b.value !== a.value && (b.value = a.value); - b.removeAttribute(f.expando); - } - } - function bm(a, b) { - if (b.nodeType === 1 && !!f.hasData(a)) { - var c, - d, - e, - g = f._data(a), - h = f._data(b, g), - i = g.events; - if (i) { - delete h.handle, h.events = {}; - for (c in i) for (d = 0, e = i[c].length; d < e; d++) f.event.add(b, c + (i[c][d].namespace ? "." : "") + i[c][d].namespace, i[c][d], i[c][d].data); - } - h.data && (h.data = f.extend({}, h.data)); - } - } - function bl(a, b) { - return f.nodeName(a, "table") ? a.getElementsByTagName("tbody")[0] || a.appendChild(a.ownerDocument.createElement("tbody")) : a; - } - function X(a) { - var b = Y.split(" "), - c = a.createDocumentFragment(); - if (c.createElement) while (b.length) c.createElement(b.pop()); - return c; - } - function W(a, b, c) { - b = b || 0; - if (f.isFunction(b)) return f.grep(a, function (a, d) { - var e = !!b.call(a, d, a); - return e === c; - }); - if (b.nodeType) return f.grep(a, function (a, d) { - return a === b === c; - }); - if (typeof b == "string") { - var d = f.grep(a, function (a) { - return a.nodeType === 1; - }); - if (R.test(b)) return f.filter(b, d, !c); - b = f.filter(b, d); - } - return f.grep(a, function (a, d) { - return f.inArray(a, b) >= 0 === c; - }); - } - function V(a) { - return !a || !a.parentNode || a.parentNode.nodeType === 11; - } - function N() { - return !0; - } - function M() { - return !1; - } - function n(a, b, c) { - var d = b + "defer", - e = b + "queue", - g = b + "mark", - h = f._data(a, d); - h && (c === "queue" || !f._data(a, e)) && (c === "mark" || !f._data(a, g)) && setTimeout(function () { - !f._data(a, e) && !f._data(a, g) && (f.removeData(a, d, !0), h.fire()); - }, 0); - } - function m(a) { - for (var b in a) { - if (b === "data" && f.isEmptyObject(a[b])) continue; - if (b !== "toJSON") return !1; - } - return !0; - } - function l(a, c, d) { - if (d === b && a.nodeType === 1) { - var e = "data-" + c.replace(k, "-$1").toLowerCase(); - d = a.getAttribute(e); - if (typeof d == "string") { - try { - d = d === "true" ? !0 : d === "false" ? !1 : d === "null" ? null : f.isNumeric(d) ? parseFloat(d) : j.test(d) ? f.parseJSON(d) : d; - } catch (g) {} - f.data(a, c, d); - } else d = b; - } - return d; - } - function h(a) { - var b = g[a] = {}, - c, - d; - a = a.split(/\s+/); - for (c = 0, d = a.length; c < d; c++) b[a[c]] = !0; - return b; - } - var c = a.document, - d = a.navigator, - e = a.location, - f = function () { - function K() { - if (!e.isReady) { - try { - c.documentElement.doScroll("left"); - } catch (a) { - setTimeout(K, 1); - return; - } - e.ready(); - } - } - var e = function (a, b) { - return new e.fn.init(a, b, h); - }, - f = a.jQuery, - g = a.$, - h, - i = /^(?:[^#<]*(<[\w\W]+>)[^>]*$|#([\w\-]*)$)/, - j = /\S/, - k = /^\s+/, - l = /\s+$/, - m = /\d/, - n = /^<(\w+)\s*\/?>(?:<\/\1>)?$/, - o = /^[\],:{}\s]*$/, - p = /\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, - q = /"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, - r = /(?:^|:|,)(?:\s*\[)+/g, - s = /(webkit)[ \/]([\w.]+)/, - t = /(opera)(?:.*version)?[ \/]([\w.]+)/, - u = /(msie) ([\w.]+)/, - v = /(mozilla)(?:.*? rv:([\w.]+))?/, - w = /-([a-z]|[0-9])/ig, - x = /^-ms-/, - y = function (a, b) { - return (b + "").toUpperCase(); - }, - z = d.userAgent, - A, - B, - C, - D = Object.prototype.toString, - E = Object.prototype.hasOwnProperty, - F = Array.prototype.push, - G = Array.prototype.slice, - H = String.prototype.trim, - I = Array.prototype.indexOf, - J = {}; - e.fn = e.prototype = { - constructor: e, - init: function (a, d, f) { - var g, h, j, k; - if (!a) return this; - if (a.nodeType) { - this.context = this[0] = a, this.length = 1; - return this; - } - if (a === "body" && !d && c.body) { - this.context = c, this[0] = c.body, this.selector = a, this.length = 1; - return this; - } - if (typeof a == "string") { - a.charAt(0) !== "<" || a.charAt(a.length - 1) !== ">" || a.length < 3 ? g = i.exec(a) : g = [null, a, null]; - if (g && (g[1] || !d)) { - if (g[1]) { - d = d instanceof e ? d[0] : d, k = d ? d.ownerDocument || d : c, j = n.exec(a), j ? e.isPlainObject(d) ? (a = [c.createElement(j[1])], e.fn.attr.call(a, d, !0)) : a = [k.createElement(j[1])] : (j = e.buildFragment([g[1]], [k]), a = (j.cacheable ? e.clone(j.fragment) : j.fragment).childNodes); - return e.merge(this, a); - } - h = c.getElementById(g[2]); - if (h && h.parentNode) { - if (h.id !== g[2]) return f.find(a); - this.length = 1, this[0] = h; - } - this.context = c, this.selector = a; - return this; - } - return !d || d.jquery ? (d || f).find(a) : this.constructor(d).find(a); - } - if (e.isFunction(a)) return f.ready(a); - a.selector !== b && (this.selector = a.selector, this.context = a.context); - return e.makeArray(a, this); - }, - selector: "", - jquery: "1.7", - length: 0, - size: function () { - return this.length; - }, - toArray: function () { - return G.call(this, 0); - }, - get: function (a) { - return a == null ? this.toArray() : a < 0 ? this[this.length + a] : this[a]; - }, - pushStack: function (a, b, c) { - var d = this.constructor(); - e.isArray(a) ? F.apply(d, a) : e.merge(d, a), d.prevObject = this, d.context = this.context, b === "find" ? d.selector = this.selector + (this.selector ? " " : "") + c : b && (d.selector = this.selector + "." + b + "(" + c + ")"); - return d; - }, - each: function (a, b) { - return e.each(this, a, b); - }, - ready: function (a) { - e.bindReady(), B.add(a); - return this; - }, - eq: function (a) { - return a === -1 ? this.slice(a) : this.slice(a, +a + 1); - }, - first: function () { - return this.eq(0); - }, - last: function () { - return this.eq(-1); - }, - slice: function () { - return this.pushStack(G.apply(this, arguments), "slice", G.call(arguments).join(",")); - }, - map: function (a) { - return this.pushStack(e.map(this, function (b, c) { - return a.call(b, c, b); - })); - }, - end: function () { - return this.prevObject || this.constructor(null); - }, - push: F, - sort: [].sort, - splice: [].splice - }, e.fn.init.prototype = e.fn, e.extend = e.fn.extend = function () { - var a, - c, - d, - f, - g, - h, - i = arguments[0] || {}, - j = 1, - k = arguments.length, - l = !1; - typeof i == "boolean" && (l = i, i = arguments[1] || {}, j = 2), typeof i != "object" && !e.isFunction(i) && (i = {}), k === j && (i = this, --j); - for (; j < k; j++) if ((a = arguments[j]) != null) for (c in a) { - d = i[c], f = a[c]; - if (i === f) continue; - l && f && (e.isPlainObject(f) || (g = e.isArray(f))) ? (g ? (g = !1, h = d && e.isArray(d) ? d : []) : h = d && e.isPlainObject(d) ? d : {}, i[c] = e.extend(l, h, f)) : f !== b && (i[c] = f); - } - return i; - }, e.extend({ - noConflict: function (b) { - a.$ === e && (a.$ = g), b && a.jQuery === e && (a.jQuery = f); - return e; - }, - isReady: !1, - readyWait: 1, - holdReady: function (a) { - a ? e.readyWait++ : e.ready(!0); - }, - ready: function (a) { - if (a === !0 && ! --e.readyWait || a !== !0 && !e.isReady) { - if (!c.body) return setTimeout(e.ready, 1); - e.isReady = !0; - if (a !== !0 && --e.readyWait > 0) return; - B.fireWith(c, [e]), e.fn.trigger && e(c).trigger("ready").unbind("ready"); - } - }, - bindReady: function () { - if (!B) { - B = e.Callbacks("once memory"); - if (c.readyState === "complete") return setTimeout(e.ready, 1); - if (c.addEventListener) c.addEventListener("DOMContentLoaded", C, !1), a.addEventListener("load", e.ready, !1);else if (c.attachEvent) { - c.attachEvent("onreadystatechange", C), a.attachEvent("onload", e.ready); - var b = !1; - try { - b = a.frameElement == null; - } catch (d) {} - c.documentElement.doScroll && b && K(); - } - } - }, - isFunction: function (a) { - return e.type(a) === "function"; - }, - isArray: Array.isArray || function (a) { - return e.type(a) === "array"; - }, - isWindow: function (a) { - return a && typeof a == "object" && "setInterval" in a; - }, - isNumeric: function (a) { - return a != null && m.test(a) && !isNaN(a); - }, - type: function (a) { - return a == null ? String(a) : J[D.call(a)] || "object"; - }, - isPlainObject: function (a) { - if (!a || e.type(a) !== "object" || a.nodeType || e.isWindow(a)) return !1; - try { - if (a.constructor && !E.call(a, "constructor") && !E.call(a.constructor.prototype, "isPrototypeOf")) return !1; - } catch (c) { - return !1; - } - var d; - for (d in a); - return d === b || E.call(a, d); - }, - isEmptyObject: function (a) { - for (var b in a) return !1; - return !0; - }, - error: function (a) { - throw a; - }, - parseJSON: function (b) { - if (typeof b != "string" || !b) return null; - b = e.trim(b); - if (a.JSON && a.JSON.parse) return a.JSON.parse(b); - if (o.test(b.replace(p, "@").replace(q, "]").replace(r, ""))) return new Function("return " + b)(); - e.error("Invalid JSON: " + b); - }, - parseXML: function (c) { - var d, f; - try { - a.DOMParser ? (f = new DOMParser(), d = f.parseFromString(c, "text/xml")) : (d = new ActiveXObject("Microsoft.XMLDOM"), d.async = "false", d.loadXML(c)); - } catch (g) { - d = b; - } - (!d || !d.documentElement || d.getElementsByTagName("parsererror").length) && e.error("Invalid XML: " + c); - return d; - }, - noop: function () {}, - globalEval: function (b) { - b && j.test(b) && (a.execScript || function (b) { - a.eval.call(a, b); - })(b); - }, - camelCase: function (a) { - return a.replace(x, "ms-").replace(w, y); - }, - nodeName: function (a, b) { - return a.nodeName && a.nodeName.toUpperCase() === b.toUpperCase(); - }, - each: function (a, c, d) { - var f, - g = 0, - h = a.length, - i = h === b || e.isFunction(a); - if (d) { - if (i) { - for (f in a) if (c.apply(a[f], d) === !1) break; - } else for (; g < h;) if (c.apply(a[g++], d) === !1) break; - } else if (i) { - for (f in a) if (c.call(a[f], f, a[f]) === !1) break; - } else for (; g < h;) if (c.call(a[g], g, a[g++]) === !1) break; - return a; - }, - trim: H ? function (a) { - return a == null ? "" : H.call(a); - } : function (a) { - return a == null ? "" : (a + "").replace(k, "").replace(l, ""); - }, - makeArray: function (a, b) { - var c = b || []; - if (a != null) { - var d = e.type(a); - a.length == null || d === "string" || d === "function" || d === "regexp" || e.isWindow(a) ? F.call(c, a) : e.merge(c, a); - } - return c; - }, - inArray: function (a, b, c) { - var d; - if (b) { - if (I) return I.call(b, a, c); - d = b.length, c = c ? c < 0 ? Math.max(0, d + c) : c : 0; - for (; c < d; c++) if (c in b && b[c] === a) return c; - } - return -1; - }, - merge: function (a, c) { - var d = a.length, - e = 0; - if (typeof c.length == "number") for (var f = c.length; e < f; e++) a[d++] = c[e];else while (c[e] !== b) a[d++] = c[e++]; - a.length = d; - return a; - }, - grep: function (a, b, c) { - var d = [], - e; - c = !!c; - for (var f = 0, g = a.length; f < g; f++) e = !!b(a[f], f), c !== e && d.push(a[f]); - return d; - }, - map: function (a, c, d) { - var f, - g, - h = [], - i = 0, - j = a.length, - k = a instanceof e || j !== b && typeof j == "number" && (j > 0 && a[0] && a[j - 1] || j === 0 || e.isArray(a)); - if (k) for (; i < j; i++) f = c(a[i], i, d), f != null && (h[h.length] = f);else for (g in a) f = c(a[g], g, d), f != null && (h[h.length] = f); - return h.concat.apply([], h); - }, - guid: 1, - proxy: function (a, c) { - if (typeof c == "string") { - var d = a[c]; - c = a, a = d; - } - if (!e.isFunction(a)) return b; - var f = G.call(arguments, 2), - g = function () { - return a.apply(c, f.concat(G.call(arguments))); - }; - g.guid = a.guid = a.guid || g.guid || e.guid++; - return g; - }, - access: function (a, c, d, f, g, h) { - var i = a.length; - if (typeof c == "object") { - for (var j in c) e.access(a, j, c[j], f, g, d); - return a; - } - if (d !== b) { - f = !h && f && e.isFunction(d); - for (var k = 0; k < i; k++) g(a[k], c, f ? d.call(a[k], k, g(a[k], c)) : d, h); - return a; - } - return i ? g(a[0], c) : b; - }, - now: function () { - return new Date().getTime(); - }, - uaMatch: function (a) { - a = a.toLowerCase(); - var b = s.exec(a) || t.exec(a) || u.exec(a) || a.indexOf("compatible") < 0 && v.exec(a) || []; - return { - browser: b[1] || "", - version: b[2] || "0" - }; - }, - sub: function () { - function a(b, c) { - return new a.fn.init(b, c); - } - e.extend(!0, a, this), a.superclass = this, a.fn = a.prototype = this(), a.fn.constructor = a, a.sub = this.sub, a.fn.init = function (d, f) { - f && f instanceof e && !(f instanceof a) && (f = a(f)); - return e.fn.init.call(this, d, f, b); - }, a.fn.init.prototype = a.fn; - var b = a(c); - return a; - }, - browser: {} - }), e.each("Boolean Number String Function Array Date RegExp Object".split(" "), function (a, b) { - J["[object " + b + "]"] = b.toLowerCase(); - }), A = e.uaMatch(z), A.browser && (e.browser[A.browser] = !0, e.browser.version = A.version), e.browser.webkit && (e.browser.safari = !0), j.test(" ") && (k = /^[\s\xA0]+/, l = /[\s\xA0]+$/), h = e(c), c.addEventListener ? C = function () { - c.removeEventListener("DOMContentLoaded", C, !1), e.ready(); - } : c.attachEvent && (C = function () { - c.readyState === "complete" && (c.detachEvent("onreadystatechange", C), e.ready()); - }), typeof define == "function" && define.amd && define.amd.jQuery && define("jquery", [], function () { - return e; - }); - return e; - }(), - g = {}; - f.Callbacks = function (a) { - a = a ? g[a] || h(a) : {}; - var c = [], - d = [], - e, - i, - j, - k, - l, - m = function (b) { - var d, e, g, h, i; - for (d = 0, e = b.length; d < e; d++) g = b[d], h = f.type(g), h === "array" ? m(g) : h === "function" && (!a.unique || !o.has(g)) && c.push(g); - }, - n = function (b, f) { - f = f || [], e = !a.memory || [b, f], i = !0, l = j || 0, j = 0, k = c.length; - for (; c && l < k; l++) if (c[l].apply(b, f) === !1 && a.stopOnFalse) { - e = !0; - break; - } - i = !1, c && (a.once ? e === !0 ? o.disable() : c = [] : d && d.length && (e = d.shift(), o.fireWith(e[0], e[1]))); - }, - o = { - add: function () { - if (c) { - var a = c.length; - m(arguments), i ? k = c.length : e && e !== !0 && (j = a, n(e[0], e[1])); - } - return this; - }, - remove: function () { - if (c) { - var b = arguments, - d = 0, - e = b.length; - for (; d < e; d++) for (var f = 0; f < c.length; f++) if (b[d] === c[f]) { - i && f <= k && (k--, f <= l && l--), c.splice(f--, 1); - if (a.unique) break; - } - } - return this; - }, - has: function (a) { - if (c) { - var b = 0, - d = c.length; - for (; b < d; b++) if (a === c[b]) return !0; - } - return !1; - }, - empty: function () { - c = []; - return this; - }, - disable: function () { - c = d = e = b; - return this; - }, - disabled: function () { - return !c; - }, - lock: function () { - d = b, (!e || e === !0) && o.disable(); - return this; - }, - locked: function () { - return !d; - }, - fireWith: function (b, c) { - d && (i ? a.once || d.push([b, c]) : (!a.once || !e) && n(b, c)); - return this; - }, - fire: function () { - o.fireWith(this, arguments); - return this; - }, - fired: function () { - return !!e; - } - }; - return o; - }; - var i = [].slice; - f.extend({ - Deferred: function (a) { - var b = f.Callbacks("once memory"), - c = f.Callbacks("once memory"), - d = f.Callbacks("memory"), - e = "pending", - g = { - resolve: b, - reject: c, - notify: d - }, - h = { - done: b.add, - fail: c.add, - progress: d.add, - state: function () { - return e; - }, - isResolved: b.fired, - isRejected: c.fired, - then: function (a, b, c) { - i.done(a).fail(b).progress(c); - return this; - }, - always: function () { - return i.done.apply(i, arguments).fail.apply(i, arguments); - }, - pipe: function (a, b, c) { - return f.Deferred(function (d) { - f.each({ - done: [a, "resolve"], - fail: [b, "reject"], - progress: [c, "notify"] - }, function (a, b) { - var c = b[0], - e = b[1], - g; - f.isFunction(c) ? i[a](function () { - g = c.apply(this, arguments), g && f.isFunction(g.promise) ? g.promise().then(d.resolve, d.reject, d.notify) : d[e + "With"](this === i ? d : this, [g]); - }) : i[a](d[e]); - }); - }).promise(); - }, - promise: function (a) { - if (a == null) a = h;else for (var b in h) a[b] = h[b]; - return a; - } - }, - i = h.promise({}), - j; - for (j in g) i[j] = g[j].fire, i[j + "With"] = g[j].fireWith; - i.done(function () { - e = "resolved"; - }, c.disable, d.lock).fail(function () { - e = "rejected"; - }, b.disable, d.lock), a && a.call(i, i); - return i; - }, - when: function (a) { - function m(a) { - return function (b) { - e[a] = arguments.length > 1 ? i.call(arguments, 0) : b, j.notifyWith(k, e); - }; - } - function l(a) { - return function (c) { - b[a] = arguments.length > 1 ? i.call(arguments, 0) : c, --g || j.resolveWith(j, b); - }; - } - var b = i.call(arguments, 0), - c = 0, - d = b.length, - e = Array(d), - g = d, - h = d, - j = d <= 1 && a && f.isFunction(a.promise) ? a : f.Deferred(), - k = j.promise(); - if (d > 1) { - for (; c < d; c++) b[c] && b[c].promise && f.isFunction(b[c].promise) ? b[c].promise().then(l(c), j.reject, m(c)) : --g; - g || j.resolveWith(j, b); - } else j !== a && j.resolveWith(j, d ? [a] : []); - return k; - } - }), f.support = function () { - var a = c.createElement("div"), - b = c.documentElement, - d, - e, - g, - h, - i, - j, - k, - l, - m, - n, - o, - p, - q, - r, - s, - t, - u; - a.setAttribute("className", "t"), a.innerHTML = "
a", d = a.getElementsByTagName("*"), e = a.getElementsByTagName("a")[0]; - if (!d || !d.length || !e) return {}; - g = c.createElement("select"), h = g.appendChild(c.createElement("option")), i = a.getElementsByTagName("input")[0], k = { - leadingWhitespace: a.firstChild.nodeType === 3, - tbody: !a.getElementsByTagName("tbody").length, - htmlSerialize: !!a.getElementsByTagName("link").length, - style: /top/.test(e.getAttribute("style")), - hrefNormalized: e.getAttribute("href") === "/a", - opacity: /^0.55/.test(e.style.opacity), - cssFloat: !!e.style.cssFloat, - unknownElems: !!a.getElementsByTagName("nav").length, - checkOn: i.value === "on", - optSelected: h.selected, - getSetAttribute: a.className !== "t", - enctype: !!c.createElement("form").enctype, - submitBubbles: !0, - changeBubbles: !0, - focusinBubbles: !1, - deleteExpando: !0, - noCloneEvent: !0, - inlineBlockNeedsLayout: !1, - shrinkWrapBlocks: !1, - reliableMarginRight: !0 - }, i.checked = !0, k.noCloneChecked = i.cloneNode(!0).checked, g.disabled = !0, k.optDisabled = !h.disabled; - try { - delete a.test; - } catch (v) { - k.deleteExpando = !1; - } - !a.addEventListener && a.attachEvent && a.fireEvent && (a.attachEvent("onclick", function () { - k.noCloneEvent = !1; - }), a.cloneNode(!0).fireEvent("onclick")), i = c.createElement("input"), i.value = "t", i.setAttribute("type", "radio"), k.radioValue = i.value === "t", i.setAttribute("checked", "checked"), a.appendChild(i), l = c.createDocumentFragment(), l.appendChild(a.lastChild), k.checkClone = l.cloneNode(!0).cloneNode(!0).lastChild.checked, a.innerHTML = "", a.style.width = a.style.paddingLeft = "1px", m = c.getElementsByTagName("body")[0], o = c.createElement(m ? "div" : "body"), p = { - visibility: "hidden", - width: 0, - height: 0, - border: 0, - margin: 0, - background: "none" - }, m && f.extend(p, { - position: "absolute", - left: "-999px", - top: "-999px" - }); - for (t in p) o.style[t] = p[t]; - o.appendChild(a), n = m || b, n.insertBefore(o, n.firstChild), k.appendChecked = i.checked, k.boxModel = a.offsetWidth === 2, "zoom" in a.style && (a.style.display = "inline", a.style.zoom = 1, k.inlineBlockNeedsLayout = a.offsetWidth === 2, a.style.display = "", a.innerHTML = "
", k.shrinkWrapBlocks = a.offsetWidth !== 2), a.innerHTML = "
t
", q = a.getElementsByTagName("td"), u = q[0].offsetHeight === 0, q[0].style.display = "", q[1].style.display = "none", k.reliableHiddenOffsets = u && q[0].offsetHeight === 0, a.innerHTML = "", c.defaultView && c.defaultView.getComputedStyle && (j = c.createElement("div"), j.style.width = "0", j.style.marginRight = "0", a.appendChild(j), k.reliableMarginRight = (parseInt((c.defaultView.getComputedStyle(j, null) || { - marginRight: 0 - }).marginRight, 10) || 0) === 0); - if (a.attachEvent) for (t in { - submit: 1, - change: 1, - focusin: 1 - }) s = "on" + t, u = s in a, u || (a.setAttribute(s, "return;"), u = typeof a[s] == "function"), k[t + "Bubbles"] = u; - f(function () { - var a, - b, - d, - e, - g, - h, - i = 1, - j = "position:absolute;top:0;left:0;width:1px;height:1px;margin:0;", - l = "visibility:hidden;border:0;", - n = "style='" + j + "border:5px solid #000;padding:0;'", - p = "
" + "" + "
"; - m = c.getElementsByTagName("body")[0]; - !m || (a = c.createElement("div"), a.style.cssText = l + "width:0;height:0;position:static;top:0;margin-top:" + i + "px", m.insertBefore(a, m.firstChild), o = c.createElement("div"), o.style.cssText = j + l, o.innerHTML = p, a.appendChild(o), b = o.firstChild, d = b.firstChild, g = b.nextSibling.firstChild.firstChild, h = { - doesNotAddBorder: d.offsetTop !== 5, - doesAddBorderForTableAndCells: g.offsetTop === 5 - }, d.style.position = "fixed", d.style.top = "20px", h.fixedPosition = d.offsetTop === 20 || d.offsetTop === 15, d.style.position = d.style.top = "", b.style.overflow = "hidden", b.style.position = "relative", h.subtractsBorderForOverflowNotVisible = d.offsetTop === -5, h.doesNotIncludeMarginInBodyOffset = m.offsetTop !== i, m.removeChild(a), o = a = null, f.extend(k, h)); - }), o.innerHTML = "", n.removeChild(o), o = l = g = h = m = j = a = i = null; - return k; - }(), f.boxModel = f.support.boxModel; - var j = /^(?:\{.*\}|\[.*\])$/, - k = /([A-Z])/g; - f.extend({ - cache: {}, - uuid: 0, - expando: "jQuery" + (f.fn.jquery + Math.random()).replace(/\D/g, ""), - noData: { - embed: !0, - object: "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000", - applet: !0 - }, - hasData: function (a) { - a = a.nodeType ? f.cache[a[f.expando]] : a[f.expando]; - return !!a && !m(a); - }, - data: function (a, c, d, e) { - if (!!f.acceptData(a)) { - var g, - h, - i, - j = f.expando, - k = typeof c == "string", - l = a.nodeType, - m = l ? f.cache : a, - n = l ? a[f.expando] : a[f.expando] && f.expando, - o = c === "events"; - if ((!n || !m[n] || !o && !e && !m[n].data) && k && d === b) return; - n || (l ? a[f.expando] = n = ++f.uuid : n = f.expando), m[n] || (m[n] = {}, l || (m[n].toJSON = f.noop)); - if (typeof c == "object" || typeof c == "function") e ? m[n] = f.extend(m[n], c) : m[n].data = f.extend(m[n].data, c); - g = h = m[n], e || (h.data || (h.data = {}), h = h.data), d !== b && (h[f.camelCase(c)] = d); - if (o && !h[c]) return g.events; - k ? (i = h[c], i == null && (i = h[f.camelCase(c)])) : i = h; - return i; - } - }, - removeData: function (a, b, c) { - if (!!f.acceptData(a)) { - var d, - e, - g, - h = f.expando, - i = a.nodeType, - j = i ? f.cache : a, - k = i ? a[f.expando] : f.expando; - if (!j[k]) return; - if (b) { - d = c ? j[k] : j[k].data; - if (d) { - f.isArray(b) ? b = b : b in d ? b = [b] : (b = f.camelCase(b), b in d ? b = [b] : b = b.split(" ")); - for (e = 0, g = b.length; e < g; e++) delete d[b[e]]; - if (!(c ? m : f.isEmptyObject)(d)) return; - } - } - if (!c) { - delete j[k].data; - if (!m(j[k])) return; - } - f.support.deleteExpando || !j.setInterval ? delete j[k] : j[k] = null, i && (f.support.deleteExpando ? delete a[f.expando] : a.removeAttribute ? a.removeAttribute(f.expando) : a[f.expando] = null); - } - }, - _data: function (a, b, c) { - return f.data(a, b, c, !0); - }, - acceptData: function (a) { - if (a.nodeName) { - var b = f.noData[a.nodeName.toLowerCase()]; - if (b) return b !== !0 && a.getAttribute("classid") === b; - } - return !0; - } - }), f.fn.extend({ - data: function (a, c) { - var d, - e, - g, - h = null; - if (typeof a == "undefined") { - if (this.length) { - h = f.data(this[0]); - if (this[0].nodeType === 1 && !f._data(this[0], "parsedAttrs")) { - e = this[0].attributes; - for (var i = 0, j = e.length; i < j; i++) g = e[i].name, g.indexOf("data-") === 0 && (g = f.camelCase(g.substring(5)), l(this[0], g, h[g])); - f._data(this[0], "parsedAttrs", !0); - } - } - return h; - } - if (typeof a == "object") return this.each(function () { - f.data(this, a); - }); - d = a.split("."), d[1] = d[1] ? "." + d[1] : ""; - if (c === b) { - h = this.triggerHandler("getData" + d[1] + "!", [d[0]]), h === b && this.length && (h = f.data(this[0], a), h = l(this[0], a, h)); - return h === b && d[1] ? this.data(d[0]) : h; - } - return this.each(function () { - var b = f(this), - e = [d[0], c]; - b.triggerHandler("setData" + d[1] + "!", e), f.data(this, a, c), b.triggerHandler("changeData" + d[1] + "!", e); - }); - }, - removeData: function (a) { - return this.each(function () { - f.removeData(this, a); - }); - } - }), f.extend({ - _mark: function (a, b) { - a && (b = (b || "fx") + "mark", f._data(a, b, (f._data(a, b) || 0) + 1)); - }, - _unmark: function (a, b, c) { - a !== !0 && (c = b, b = a, a = !1); - if (b) { - c = c || "fx"; - var d = c + "mark", - e = a ? 0 : (f._data(b, d) || 1) - 1; - e ? f._data(b, d, e) : (f.removeData(b, d, !0), n(b, c, "mark")); - } - }, - queue: function (a, b, c) { - var d; - if (a) { - b = (b || "fx") + "queue", d = f._data(a, b), c && (!d || f.isArray(c) ? d = f._data(a, b, f.makeArray(c)) : d.push(c)); - return d || []; - } - }, - dequeue: function (a, b) { - b = b || "fx"; - var c = f.queue(a, b), - d = c.shift(), - e = {}; - d === "inprogress" && (d = c.shift()), d && (b === "fx" && c.unshift("inprogress"), f._data(a, b + ".run", e), d.call(a, function () { - f.dequeue(a, b); - }, e)), c.length || (f.removeData(a, b + "queue " + b + ".run", !0), n(a, b, "queue")); - } - }), f.fn.extend({ - queue: function (a, c) { - typeof a != "string" && (c = a, a = "fx"); - if (c === b) return f.queue(this[0], a); - return this.each(function () { - var b = f.queue(this, a, c); - a === "fx" && b[0] !== "inprogress" && f.dequeue(this, a); - }); - }, - dequeue: function (a) { - return this.each(function () { - f.dequeue(this, a); - }); - }, - delay: function (a, b) { - a = f.fx ? f.fx.speeds[a] || a : a, b = b || "fx"; - return this.queue(b, function (b, c) { - var d = setTimeout(b, a); - c.stop = function () { - clearTimeout(d); - }; - }); - }, - clearQueue: function (a) { - return this.queue(a || "fx", []); - }, - promise: function (a, c) { - function m() { - --h || d.resolveWith(e, [e]); - } - typeof a != "string" && (c = a, a = b), a = a || "fx"; - var d = f.Deferred(), - e = this, - g = e.length, - h = 1, - i = a + "defer", - j = a + "queue", - k = a + "mark", - l; - while (g--) if (l = f.data(e[g], i, b, !0) || (f.data(e[g], j, b, !0) || f.data(e[g], k, b, !0)) && f.data(e[g], i, f.Callbacks("once memory"), !0)) h++, l.add(m); - m(); - return d.promise(); - } - }); - var o = /[\n\t\r]/g, - p = /\s+/, - q = /\r/g, - r = /^(?:button|input)$/i, - s = /^(?:button|input|object|select|textarea)$/i, - t = /^a(?:rea)?$/i, - u = /^(?:autofocus|autoplay|async|checked|controls|defer|disabled|hidden|loop|multiple|open|readonly|required|scoped|selected)$/i, - v = f.support.getSetAttribute, - w, - x, - y; - f.fn.extend({ - attr: function (a, b) { - return f.access(this, a, b, !0, f.attr); - }, - removeAttr: function (a) { - return this.each(function () { - f.removeAttr(this, a); - }); - }, - prop: function (a, b) { - return f.access(this, a, b, !0, f.prop); - }, - removeProp: function (a) { - a = f.propFix[a] || a; - return this.each(function () { - try { - this[a] = b, delete this[a]; - } catch (c) {} - }); - }, - addClass: function (a) { - var b, c, d, e, g, h, i; - if (f.isFunction(a)) return this.each(function (b) { - f(this).addClass(a.call(this, b, this.className)); - }); - if (a && typeof a == "string") { - b = a.split(p); - for (c = 0, d = this.length; c < d; c++) { - e = this[c]; - if (e.nodeType === 1) if (!e.className && b.length === 1) e.className = a;else { - g = " " + e.className + " "; - for (h = 0, i = b.length; h < i; h++) ~g.indexOf(" " + b[h] + " ") || (g += b[h] + " "); - e.className = f.trim(g); - } - } - } - return this; - }, - removeClass: function (a) { - var c, d, e, g, h, i, j; - if (f.isFunction(a)) return this.each(function (b) { - f(this).removeClass(a.call(this, b, this.className)); - }); - if (a && typeof a == "string" || a === b) { - c = (a || "").split(p); - for (d = 0, e = this.length; d < e; d++) { - g = this[d]; - if (g.nodeType === 1 && g.className) if (a) { - h = (" " + g.className + " ").replace(o, " "); - for (i = 0, j = c.length; i < j; i++) h = h.replace(" " + c[i] + " ", " "); - g.className = f.trim(h); - } else g.className = ""; - } - } - return this; - }, - toggleClass: function (a, b) { - var c = typeof a, - d = typeof b == "boolean"; - if (f.isFunction(a)) return this.each(function (c) { - f(this).toggleClass(a.call(this, c, this.className, b), b); - }); - return this.each(function () { - if (c === "string") { - var e, - g = 0, - h = f(this), - i = b, - j = a.split(p); - while (e = j[g++]) i = d ? i : !h.hasClass(e), h[i ? "addClass" : "removeClass"](e); - } else if (c === "undefined" || c === "boolean") this.className && f._data(this, "__className__", this.className), this.className = this.className || a === !1 ? "" : f._data(this, "__className__") || ""; - }); - }, - hasClass: function (a) { - var b = " " + a + " ", - c = 0, - d = this.length; - for (; c < d; c++) if (this[c].nodeType === 1 && (" " + this[c].className + " ").replace(o, " ").indexOf(b) > -1) return !0; - return !1; - }, - val: function (a) { - var c, - d, - e, - g = this[0]; - if (!arguments.length) { - if (g) { - c = f.valHooks[g.nodeName.toLowerCase()] || f.valHooks[g.type]; - if (c && "get" in c && (d = c.get(g, "value")) !== b) return d; - d = g.value; - return typeof d == "string" ? d.replace(q, "") : d == null ? "" : d; - } - return b; - } - e = f.isFunction(a); - return this.each(function (d) { - var g = f(this), - h; - if (this.nodeType === 1) { - e ? h = a.call(this, d, g.val()) : h = a, h == null ? h = "" : typeof h == "number" ? h += "" : f.isArray(h) && (h = f.map(h, function (a) { - return a == null ? "" : a + ""; - })), c = f.valHooks[this.nodeName.toLowerCase()] || f.valHooks[this.type]; - if (!c || !("set" in c) || c.set(this, h, "value") === b) this.value = h; - } - }); - } - }), f.extend({ - valHooks: { - option: { - get: function (a) { - var b = a.attributes.value; - return !b || b.specified ? a.value : a.text; - } - }, - select: { - get: function (a) { - var b, - c, - d, - e, - g = a.selectedIndex, - h = [], - i = a.options, - j = a.type === "select-one"; - if (g < 0) return null; - c = j ? g : 0, d = j ? g + 1 : i.length; - for (; c < d; c++) { - e = i[c]; - if (e.selected && (f.support.optDisabled ? !e.disabled : e.getAttribute("disabled") === null) && (!e.parentNode.disabled || !f.nodeName(e.parentNode, "optgroup"))) { - b = f(e).val(); - if (j) return b; - h.push(b); - } - } - if (j && !h.length && i.length) return f(i[g]).val(); - return h; - }, - set: function (a, b) { - var c = f.makeArray(b); - f(a).find("option").each(function () { - this.selected = f.inArray(f(this).val(), c) >= 0; - }), c.length || (a.selectedIndex = -1); - return c; - } - } - }, - attrFn: { - val: !0, - css: !0, - html: !0, - text: !0, - data: !0, - width: !0, - height: !0, - offset: !0 - }, - attr: function (a, c, d, e) { - var g, - h, - i, - j = a.nodeType; - if (!a || j === 3 || j === 8 || j === 2) return b; - if (e && c in f.attrFn) return f(a)[c](d); - if (!("getAttribute" in a)) return f.prop(a, c, d); - i = j !== 1 || !f.isXMLDoc(a), i && (c = c.toLowerCase(), h = f.attrHooks[c] || (u.test(c) ? x : w)); - if (d !== b) { - if (d === null) { - f.removeAttr(a, c); - return b; - } - if (h && "set" in h && i && (g = h.set(a, d, c)) !== b) return g; - a.setAttribute(c, "" + d); - return d; - } - if (h && "get" in h && i && (g = h.get(a, c)) !== null) return g; - g = a.getAttribute(c); - return g === null ? b : g; - }, - removeAttr: function (a, b) { - var c, - d, - e, - g, - h = 0; - if (a.nodeType === 1) { - d = (b || "").split(p), g = d.length; - for (; h < g; h++) e = d[h].toLowerCase(), c = f.propFix[e] || e, f.attr(a, e, ""), a.removeAttribute(v ? e : c), u.test(e) && c in a && (a[c] = !1); - } - }, - attrHooks: { - type: { - set: function (a, b) { - if (r.test(a.nodeName) && a.parentNode) f.error("type property can't be changed");else if (!f.support.radioValue && b === "radio" && f.nodeName(a, "input")) { - var c = a.value; - a.setAttribute("type", b), c && (a.value = c); - return b; - } - } - }, - value: { - get: function (a, b) { - if (w && f.nodeName(a, "button")) return w.get(a, b); - return b in a ? a.value : null; - }, - set: function (a, b, c) { - if (w && f.nodeName(a, "button")) return w.set(a, b, c); - a.value = b; - } - } - }, - propFix: { - tabindex: "tabIndex", - readonly: "readOnly", - "for": "htmlFor", - "class": "className", - maxlength: "maxLength", - cellspacing: "cellSpacing", - cellpadding: "cellPadding", - rowspan: "rowSpan", - colspan: "colSpan", - usemap: "useMap", - frameborder: "frameBorder", - contenteditable: "contentEditable" - }, - prop: function (a, c, d) { - var e, - g, - h, - i = a.nodeType; - if (!a || i === 3 || i === 8 || i === 2) return b; - h = i !== 1 || !f.isXMLDoc(a), h && (c = f.propFix[c] || c, g = f.propHooks[c]); - return d !== b ? g && "set" in g && (e = g.set(a, d, c)) !== b ? e : a[c] = d : g && "get" in g && (e = g.get(a, c)) !== null ? e : a[c]; - }, - propHooks: { - tabIndex: { - get: function (a) { - var c = a.getAttributeNode("tabindex"); - return c && c.specified ? parseInt(c.value, 10) : s.test(a.nodeName) || t.test(a.nodeName) && a.href ? 0 : b; - } - } - } - }), f.attrHooks.tabindex = f.propHooks.tabIndex, x = { - get: function (a, c) { - var d, - e = f.prop(a, c); - return e === !0 || typeof e != "boolean" && (d = a.getAttributeNode(c)) && d.nodeValue !== !1 ? c.toLowerCase() : b; - }, - set: function (a, b, c) { - var d; - b === !1 ? f.removeAttr(a, c) : (d = f.propFix[c] || c, d in a && (a[d] = !0), a.setAttribute(c, c.toLowerCase())); - return c; - } - }, v || (y = { - name: !0, - id: !0 - }, w = f.valHooks.button = { - get: function (a, c) { - var d; - d = a.getAttributeNode(c); - return d && (y[c] ? d.nodeValue !== "" : d.specified) ? d.nodeValue : b; - }, - set: function (a, b, d) { - var e = a.getAttributeNode(d); - e || (e = c.createAttribute(d), a.setAttributeNode(e)); - return e.nodeValue = b + ""; - } - }, f.attrHooks.tabindex.set = w.set, f.each(["width", "height"], function (a, b) { - f.attrHooks[b] = f.extend(f.attrHooks[b], { - set: function (a, c) { - if (c === "") { - a.setAttribute(b, "auto"); - return c; - } - } - }); - }), f.attrHooks.contenteditable = { - get: w.get, - set: function (a, b, c) { - b === "" && (b = "false"), w.set(a, b, c); - } - }), f.support.hrefNormalized || f.each(["href", "src", "width", "height"], function (a, c) { - f.attrHooks[c] = f.extend(f.attrHooks[c], { - get: function (a) { - var d = a.getAttribute(c, 2); - return d === null ? b : d; - } - }); - }), f.support.style || (f.attrHooks.style = { - get: function (a) { - return a.style.cssText.toLowerCase() || b; - }, - set: function (a, b) { - return a.style.cssText = "" + b; - } - }), f.support.optSelected || (f.propHooks.selected = f.extend(f.propHooks.selected, { - get: function (a) { - var b = a.parentNode; - b && (b.selectedIndex, b.parentNode && b.parentNode.selectedIndex); - return null; - } - })), f.support.enctype || (f.propFix.enctype = "encoding"), f.support.checkOn || f.each(["radio", "checkbox"], function () { - f.valHooks[this] = { - get: function (a) { - return a.getAttribute("value") === null ? "on" : a.value; - } - }; - }), f.each(["radio", "checkbox"], function () { - f.valHooks[this] = f.extend(f.valHooks[this], { - set: function (a, b) { - if (f.isArray(b)) return a.checked = f.inArray(f(a).val(), b) >= 0; - } - }); - }); - var z = /\.(.*)$/, - A = /^(?:textarea|input|select)$/i, - B = /\./g, - C = / /g, - D = /[^\w\s.|`]/g, - E = /^([^\.]*)?(?:\.(.+))?$/, - F = /\bhover(\.\S+)?/, - G = /^key/, - H = /^(?:mouse|contextmenu)|click/, - I = /^(\w*)(?:#([\w\-]+))?(?:\.([\w\-]+))?$/, - J = function (a) { - var b = I.exec(a); - b && (b[1] = (b[1] || "").toLowerCase(), b[3] = b[3] && new RegExp("(?:^|\\s)" + b[3] + "(?:\\s|$)")); - return b; - }, - K = function (a, b) { - return (!b[1] || a.nodeName.toLowerCase() === b[1]) && (!b[2] || a.id === b[2]) && (!b[3] || b[3].test(a.className)); - }, - L = function (a) { - return f.event.special.hover ? a : a.replace(F, "mouseenter$1 mouseleave$1"); - }; - f.event = { - add: function (a, c, d, e, g) { - var h, i, j, k, l, m, n, o, p, q, r, s; - if (!(a.nodeType === 3 || a.nodeType === 8 || !c || !d || !(h = f._data(a)))) { - d.handler && (p = d, d = p.handler), d.guid || (d.guid = f.guid++), j = h.events, j || (h.events = j = {}), i = h.handle, i || (h.handle = i = function (a) { - return typeof f != "undefined" && (!a || f.event.triggered !== a.type) ? f.event.dispatch.apply(i.elem, arguments) : b; - }, i.elem = a), c = L(c).split(" "); - for (k = 0; k < c.length; k++) { - l = E.exec(c[k]) || [], m = l[1], n = (l[2] || "").split(".").sort(), s = f.event.special[m] || {}, m = (g ? s.delegateType : s.bindType) || m, s = f.event.special[m] || {}, o = f.extend({ - type: m, - origType: l[1], - data: e, - handler: d, - guid: d.guid, - selector: g, - namespace: n.join(".") - }, p), g && (o.quick = J(g), !o.quick && f.expr.match.POS.test(g) && (o.isPositional = !0)), r = j[m]; - if (!r) { - r = j[m] = [], r.delegateCount = 0; - if (!s.setup || s.setup.call(a, e, n, i) === !1) a.addEventListener ? a.addEventListener(m, i, !1) : a.attachEvent && a.attachEvent("on" + m, i); - } - s.add && (s.add.call(a, o), o.handler.guid || (o.handler.guid = d.guid)), g ? r.splice(r.delegateCount++, 0, o) : r.push(o), f.event.global[m] = !0; - } - a = null; - } - }, - global: {}, - remove: function (a, b, c, d) { - var e = f.hasData(a) && f._data(a), - g, - h, - i, - j, - k, - l, - m, - n, - o, - p, - q; - if (!!e && !!(m = e.events)) { - b = L(b || "").split(" "); - for (g = 0; g < b.length; g++) { - h = E.exec(b[g]) || [], i = h[1], j = h[2]; - if (!i) { - j = j ? "." + j : ""; - for (l in m) f.event.remove(a, l + j, c, d); - return; - } - n = f.event.special[i] || {}, i = (d ? n.delegateType : n.bindType) || i, p = m[i] || [], k = p.length, j = j ? new RegExp("(^|\\.)" + j.split(".").sort().join("\\.(?:.*\\.)?") + "(\\.|$)") : null; - if (c || j || d || n.remove) for (l = 0; l < p.length; l++) { - q = p[l]; - if (!c || c.guid === q.guid) if (!j || j.test(q.namespace)) if (!d || d === q.selector || d === "**" && q.selector) p.splice(l--, 1), q.selector && p.delegateCount--, n.remove && n.remove.call(a, q); - } else p.length = 0; - p.length === 0 && k !== p.length && ((!n.teardown || n.teardown.call(a, j) === !1) && f.removeEvent(a, i, e.handle), delete m[i]); - } - f.isEmptyObject(m) && (o = e.handle, o && (o.elem = null), f.removeData(a, ["events", "handle"], !0)); - } - }, - customEvent: { - getData: !0, - setData: !0, - changeData: !0 - }, - trigger: function (c, d, e, g) { - if (!e || e.nodeType !== 3 && e.nodeType !== 8) { - var h = c.type || c, - i = [], - j, - k, - l, - m, - n, - o, - p, - q, - r, - s; - h.indexOf("!") >= 0 && (h = h.slice(0, -1), k = !0), h.indexOf(".") >= 0 && (i = h.split("."), h = i.shift(), i.sort()); - if ((!e || f.event.customEvent[h]) && !f.event.global[h]) return; - c = typeof c == "object" ? c[f.expando] ? c : new f.Event(h, c) : new f.Event(h), c.type = h, c.isTrigger = !0, c.exclusive = k, c.namespace = i.join("."), c.namespace_re = c.namespace ? new RegExp("(^|\\.)" + i.join("\\.(?:.*\\.)?") + "(\\.|$)") : null, o = h.indexOf(":") < 0 ? "on" + h : "", (g || !e) && c.preventDefault(); - if (!e) { - j = f.cache; - for (l in j) j[l].events && j[l].events[h] && f.event.trigger(c, d, j[l].handle.elem, !0); - return; - } - c.result = b, c.target || (c.target = e), d = d != null ? f.makeArray(d) : [], d.unshift(c), p = f.event.special[h] || {}; - if (p.trigger && p.trigger.apply(e, d) === !1) return; - r = [[e, p.bindType || h]]; - if (!g && !p.noBubble && !f.isWindow(e)) { - s = p.delegateType || h, n = null; - for (m = e.parentNode; m; m = m.parentNode) r.push([m, s]), n = m; - n && n === e.ownerDocument && r.push([n.defaultView || n.parentWindow || a, s]); - } - for (l = 0; l < r.length; l++) { - m = r[l][0], c.type = r[l][1], q = (f._data(m, "events") || {})[c.type] && f._data(m, "handle"), q && q.apply(m, d), q = o && m[o], q && f.acceptData(m) && q.apply(m, d); - if (c.isPropagationStopped()) break; - } - c.type = h, c.isDefaultPrevented() || (!p._default || p._default.apply(e.ownerDocument, d) === !1) && (h !== "click" || !f.nodeName(e, "a")) && f.acceptData(e) && o && e[h] && (h !== "focus" && h !== "blur" || c.target.offsetWidth !== 0) && !f.isWindow(e) && (n = e[o], n && (e[o] = null), f.event.triggered = h, e[h](), f.event.triggered = b, n && (e[o] = n)); - return c.result; - } - }, - dispatch: function (c) { - c = f.event.fix(c || a.event); - var d = (f._data(this, "events") || {})[c.type] || [], - e = d.delegateCount, - g = [].slice.call(arguments, 0), - h = !c.exclusive && !c.namespace, - i = (f.event.special[c.type] || {}).handle, - j = [], - k, - l, - m, - n, - o, - p, - q, - r, - s, - t, - u; - g[0] = c, c.delegateTarget = this; - if (e && !c.target.disabled && (!c.button || c.type !== "click")) for (m = c.target; m != this; m = m.parentNode || this) { - o = {}, q = []; - for (k = 0; k < e; k++) r = d[k], s = r.selector, t = o[s], r.isPositional ? t = (t || (o[s] = f(s))).index(m) >= 0 : t === b && (t = o[s] = r.quick ? K(m, r.quick) : f(m).is(s)), t && q.push(r); - q.length && j.push({ - elem: m, - matches: q - }); - } - d.length > e && j.push({ - elem: this, - matches: d.slice(e) - }); - for (k = 0; k < j.length && !c.isPropagationStopped(); k++) { - p = j[k], c.currentTarget = p.elem; - for (l = 0; l < p.matches.length && !c.isImmediatePropagationStopped(); l++) { - r = p.matches[l]; - if (h || !c.namespace && !r.namespace || c.namespace_re && c.namespace_re.test(r.namespace)) c.data = r.data, c.handleObj = r, n = (i || r.handler).apply(p.elem, g), n !== b && (c.result = n, n === !1 && (c.preventDefault(), c.stopPropagation())); - } - } - return c.result; - }, - props: "attrChange attrName relatedNode srcElement altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "), - fixHooks: {}, - keyHooks: { - props: "char charCode key keyCode".split(" "), - filter: function (a, b) { - a.which == null && (a.which = b.charCode != null ? b.charCode : b.keyCode); - return a; - } - }, - mouseHooks: { - props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement wheelDelta".split(" "), - filter: function (a, d) { - var e, - f, - g, - h = d.button, - i = d.fromElement; - a.pageX == null && d.clientX != null && (e = a.target.ownerDocument || c, f = e.documentElement, g = e.body, a.pageX = d.clientX + (f && f.scrollLeft || g && g.scrollLeft || 0) - (f && f.clientLeft || g && g.clientLeft || 0), a.pageY = d.clientY + (f && f.scrollTop || g && g.scrollTop || 0) - (f && f.clientTop || g && g.clientTop || 0)), !a.relatedTarget && i && (a.relatedTarget = i === a.target ? d.toElement : i), !a.which && h !== b && (a.which = h & 1 ? 1 : h & 2 ? 3 : h & 4 ? 2 : 0); - return a; - } - }, - fix: function (a) { - if (a[f.expando]) return a; - var d, - e, - g = a, - h = f.event.fixHooks[a.type] || {}, - i = h.props ? this.props.concat(h.props) : this.props; - a = f.Event(g); - for (d = i.length; d;) e = i[--d], a[e] = g[e]; - a.target || (a.target = g.srcElement || c), a.target.nodeType === 3 && (a.target = a.target.parentNode), a.metaKey === b && (a.metaKey = a.ctrlKey); - return h.filter ? h.filter(a, g) : a; - }, - special: { - ready: { - setup: f.bindReady - }, - focus: { - delegateType: "focusin", - noBubble: !0 - }, - blur: { - delegateType: "focusout", - noBubble: !0 - }, - beforeunload: { - setup: function (a, b, c) { - f.isWindow(this) && (this.onbeforeunload = c); - }, - teardown: function (a, b) { - this.onbeforeunload === b && (this.onbeforeunload = null); - } - } - }, - simulate: function (a, b, c, d) { - var e = f.extend(new f.Event(), c, { - type: a, - isSimulated: !0, - originalEvent: {} - }); - d ? f.event.trigger(e, null, b) : f.event.dispatch.call(b, e), e.isDefaultPrevented() && c.preventDefault(); - } - }, f.event.handle = f.event.dispatch, f.removeEvent = c.removeEventListener ? function (a, b, c) { - a.removeEventListener && a.removeEventListener(b, c, !1); - } : function (a, b, c) { - a.detachEvent && a.detachEvent("on" + b, c); - }, f.Event = function (a, b) { - if (!(this instanceof f.Event)) return new f.Event(a, b); - a && a.type ? (this.originalEvent = a, this.type = a.type, this.isDefaultPrevented = a.defaultPrevented || a.returnValue === !1 || a.getPreventDefault && a.getPreventDefault() ? N : M) : this.type = a, b && f.extend(this, b), this.timeStamp = a && a.timeStamp || f.now(), this[f.expando] = !0; - }, f.Event.prototype = { - preventDefault: function () { - this.isDefaultPrevented = N; - var a = this.originalEvent; - !a || (a.preventDefault ? a.preventDefault() : a.returnValue = !1); - }, - stopPropagation: function () { - this.isPropagationStopped = N; - var a = this.originalEvent; - !a || (a.stopPropagation && a.stopPropagation(), a.cancelBubble = !0); - }, - stopImmediatePropagation: function () { - this.isImmediatePropagationStopped = N, this.stopPropagation(); - }, - isDefaultPrevented: M, - isPropagationStopped: M, - isImmediatePropagationStopped: M - }, f.each({ - mouseenter: "mouseover", - mouseleave: "mouseout" - }, function (a, b) { - f.event.special[a] = f.event.special[b] = { - delegateType: b, - bindType: b, - handle: function (a) { - var b = this, - c = a.relatedTarget, - d = a.handleObj, - e = d.selector, - g, - h; - if (!c || d.origType === a.type || c !== b && !f.contains(b, c)) g = a.type, a.type = d.origType, h = d.handler.apply(this, arguments), a.type = g; - return h; - } - }; - }), f.support.submitBubbles || (f.event.special.submit = { - setup: function () { - if (f.nodeName(this, "form")) return !1; - f.event.add(this, "click._submit keypress._submit", function (a) { - var c = a.target, - d = f.nodeName(c, "input") || f.nodeName(c, "button") ? c.form : b; - d && !d._submit_attached && (f.event.add(d, "submit._submit", function (a) { - this.parentNode && f.event.simulate("submit", this.parentNode, a, !0); - }), d._submit_attached = !0); - }); - }, - teardown: function () { - if (f.nodeName(this, "form")) return !1; - f.event.remove(this, "._submit"); - } - }), f.support.changeBubbles || (f.event.special.change = { - setup: function () { - if (A.test(this.nodeName)) { - if (this.type === "checkbox" || this.type === "radio") f.event.add(this, "propertychange._change", function (a) { - a.originalEvent.propertyName === "checked" && (this._just_changed = !0); - }), f.event.add(this, "click._change", function (a) { - this._just_changed && (this._just_changed = !1, f.event.simulate("change", this, a, !0)); - }); - return !1; - } - f.event.add(this, "beforeactivate._change", function (a) { - var b = a.target; - A.test(b.nodeName) && !b._change_attached && (f.event.add(b, "change._change", function (a) { - this.parentNode && !a.isSimulated && f.event.simulate("change", this.parentNode, a, !0); - }), b._change_attached = !0); - }); - }, - handle: function (a) { - var b = a.target; - if (this !== b || a.isSimulated || a.isTrigger || b.type !== "radio" && b.type !== "checkbox") return a.handleObj.handler.apply(this, arguments); - }, - teardown: function () { - f.event.remove(this, "._change"); - return A.test(this.nodeName); - } - }), f.support.focusinBubbles || f.each({ - focus: "focusin", - blur: "focusout" - }, function (a, b) { - var d = 0, - e = function (a) { - f.event.simulate(b, a.target, f.event.fix(a), !0); - }; - f.event.special[b] = { - setup: function () { - d++ === 0 && c.addEventListener(a, e, !0); - }, - teardown: function () { - --d === 0 && c.removeEventListener(a, e, !0); - } - }; - }), f.fn.extend({ - on: function (a, c, d, e, g) { - var h, i; - if (typeof a == "object") { - typeof c != "string" && (d = c, c = b); - for (i in a) this.on(i, c, d, a[i], g); - return this; - } - d == null && e == null ? (e = c, d = c = b) : e == null && (typeof c == "string" ? (e = d, d = b) : (e = d, d = c, c = b)); - if (e === !1) e = M;else if (!e) return this; - g === 1 && (h = e, e = function (a) { - f().off(a); - return h.apply(this, arguments); - }, e.guid = h.guid || (h.guid = f.guid++)); - return this.each(function () { - f.event.add(this, a, e, d, c); - }); - }, - one: function (a, b, c, d) { - return this.on.call(this, a, b, c, d, 1); - }, - off: function (a, c, d) { - if (a && a.preventDefault && a.handleObj) { - var e = a.handleObj; - f(a.delegateTarget).off(e.namespace ? e.type + "." + e.namespace : e.type, e.selector, e.handler); - return this; - } - if (typeof a == "object") { - for (var g in a) this.off(g, c, a[g]); - return this; - } - if (c === !1 || typeof c == "function") d = c, c = b; - d === !1 && (d = M); - return this.each(function () { - f.event.remove(this, a, d, c); - }); - }, - bind: function (a, b, c) { - return this.on(a, null, b, c); - }, - unbind: function (a, b) { - return this.off(a, null, b); - }, - live: function (a, b, c) { - f(this.context).on(a, this.selector, b, c); - return this; - }, - die: function (a, b) { - f(this.context).off(a, this.selector || "**", b); - return this; - }, - delegate: function (a, b, c, d) { - return this.on(b, a, c, d); - }, - undelegate: function (a, b, c) { - return arguments.length == 1 ? this.off(a, "**") : this.off(b, a, c); - }, - trigger: function (a, b) { - return this.each(function () { - f.event.trigger(a, b, this); - }); - }, - triggerHandler: function (a, b) { - if (this[0]) return f.event.trigger(a, b, this[0], !0); - }, - toggle: function (a) { - var b = arguments, - c = a.guid || f.guid++, - d = 0, - e = function (c) { - var e = (f._data(this, "lastToggle" + a.guid) || 0) % d; - f._data(this, "lastToggle" + a.guid, e + 1), c.preventDefault(); - return b[e].apply(this, arguments) || !1; - }; - e.guid = c; - while (d < b.length) b[d++].guid = c; - return this.click(e); - }, - hover: function (a, b) { - return this.mouseenter(a).mouseleave(b || a); - } - }), f.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) { - f.fn[b] = function (a, c) { - c == null && (c = a, a = null); - return arguments.length > 0 ? this.bind(b, a, c) : this.trigger(b); - }, f.attrFn && (f.attrFn[b] = !0), G.test(b) && (f.event.fixHooks[b] = f.event.keyHooks), H.test(b) && (f.event.fixHooks[b] = f.event.mouseHooks); - }), function () { - function x(a, b, c, e, f, g) { - for (var h = 0, i = e.length; h < i; h++) { - var j = e[h]; - if (j) { - var k = !1; - j = j[a]; - while (j) { - if (j[d] === c) { - k = e[j.sizset]; - break; - } - if (j.nodeType === 1) { - g || (j[d] = c, j.sizset = h); - if (typeof b != "string") { - if (j === b) { - k = !0; - break; - } - } else if (m.filter(b, [j]).length > 0) { - k = j; - break; - } - } - j = j[a]; - } - e[h] = k; - } - } - } - function w(a, b, c, e, f, g) { - for (var h = 0, i = e.length; h < i; h++) { - var j = e[h]; - if (j) { - var k = !1; - j = j[a]; - while (j) { - if (j[d] === c) { - k = e[j.sizset]; - break; - } - j.nodeType === 1 && !g && (j[d] = c, j.sizset = h); - if (j.nodeName.toLowerCase() === b) { - k = j; - break; - } - j = j[a]; - } - e[h] = k; - } - } - } - var a = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^\[\]]*\]|['"][^'"]*['"]|[^\[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g, - d = "sizcache" + (Math.random() + "").replace(".", ""), - e = 0, - g = Object.prototype.toString, - h = !1, - i = !0, - j = /\\/g, - k = /\r\n/g, - l = /\W/; - [0, 0].sort(function () { - i = !1; - return 0; - }); - var m = function (b, d, e, f) { - e = e || [], d = d || c; - var h = d; - if (d.nodeType !== 1 && d.nodeType !== 9) return []; - if (!b || typeof b != "string") return e; - var i, - j, - k, - l, - n, - q, - r, - t, - u = !0, - v = m.isXML(d), - w = [], - x = b; - do { - a.exec(""), i = a.exec(x); - if (i) { - x = i[3], w.push(i[1]); - if (i[2]) { - l = i[3]; - break; - } - } - } while (i); - if (w.length > 1 && p.exec(b)) { - if (w.length === 2 && o.relative[w[0]]) j = y(w[0] + w[1], d, f);else { - j = o.relative[w[0]] ? [d] : m(w.shift(), d); - while (w.length) b = w.shift(), o.relative[b] && (b += w.shift()), j = y(b, j, f); - } - } else { - !f && w.length > 1 && d.nodeType === 9 && !v && o.match.ID.test(w[0]) && !o.match.ID.test(w[w.length - 1]) && (n = m.find(w.shift(), d, v), d = n.expr ? m.filter(n.expr, n.set)[0] : n.set[0]); - if (d) { - n = f ? { - expr: w.pop(), - set: s(f) - } : m.find(w.pop(), w.length === 1 && (w[0] === "~" || w[0] === "+") && d.parentNode ? d.parentNode : d, v), j = n.expr ? m.filter(n.expr, n.set) : n.set, w.length > 0 ? k = s(j) : u = !1; - while (w.length) q = w.pop(), r = q, o.relative[q] ? r = w.pop() : q = "", r == null && (r = d), o.relative[q](k, r, v); - } else k = w = []; - } - k || (k = j), k || m.error(q || b); - if (g.call(k) === "[object Array]") { - if (!u) e.push.apply(e, k);else if (d && d.nodeType === 1) for (t = 0; k[t] != null; t++) k[t] && (k[t] === !0 || k[t].nodeType === 1 && m.contains(d, k[t])) && e.push(j[t]);else for (t = 0; k[t] != null; t++) k[t] && k[t].nodeType === 1 && e.push(j[t]); - } else s(k, e); - l && (m(l, h, e, f), m.uniqueSort(e)); - return e; - }; - m.uniqueSort = function (a) { - if (u) { - h = i, a.sort(u); - if (h) for (var b = 1; b < a.length; b++) a[b] === a[b - 1] && a.splice(b--, 1); - } - return a; - }, m.matches = function (a, b) { - return m(a, null, null, b); - }, m.matchesSelector = function (a, b) { - return m(b, null, null, [a]).length > 0; - }, m.find = function (a, b, c) { - var d, e, f, g, h, i; - if (!a) return []; - for (e = 0, f = o.order.length; e < f; e++) { - h = o.order[e]; - if (g = o.leftMatch[h].exec(a)) { - i = g[1], g.splice(1, 1); - if (i.substr(i.length - 1) !== "\\") { - g[1] = (g[1] || "").replace(j, ""), d = o.find[h](g, b, c); - if (d != null) { - a = a.replace(o.match[h], ""); - break; - } - } - } - } - d || (d = typeof b.getElementsByTagName != "undefined" ? b.getElementsByTagName("*") : []); - return { - set: d, - expr: a - }; - }, m.filter = function (a, c, d, e) { - var f, - g, - h, - i, - j, - k, - l, - n, - p, - q = a, - r = [], - s = c, - t = c && c[0] && m.isXML(c[0]); - while (a && c.length) { - for (h in o.filter) if ((f = o.leftMatch[h].exec(a)) != null && f[2]) { - k = o.filter[h], l = f[1], g = !1, f.splice(1, 1); - if (l.substr(l.length - 1) === "\\") continue; - s === r && (r = []); - if (o.preFilter[h]) { - f = o.preFilter[h](f, s, d, r, e, t); - if (!f) g = i = !0;else if (f === !0) continue; - } - if (f) for (n = 0; (j = s[n]) != null; n++) j && (i = k(j, f, n, s), p = e ^ i, d && i != null ? p ? g = !0 : s[n] = !1 : p && (r.push(j), g = !0)); - if (i !== b) { - d || (s = r), a = a.replace(o.match[h], ""); - if (!g) return []; - break; - } - } - if (a === q) if (g == null) m.error(a);else break; - q = a; - } - return s; - }, m.error = function (a) { - throw "Syntax error, unrecognized expression: " + a; - }; - var n = m.getText = function (a) { - var b, - c, - d = a.nodeType, - e = ""; - if (d) { - if (d === 1) { - if (typeof a.textContent == "string") return a.textContent; - if (typeof a.innerText == "string") return a.innerText.replace(k, ""); - for (a = a.firstChild; a; a = a.nextSibling) e += n(a); - } else if (d === 3 || d === 4) return a.nodeValue; - } else for (b = 0; c = a[b]; b++) c.nodeType !== 8 && (e += n(c)); - return e; - }, - o = m.selectors = { - order: ["ID", "NAME", "TAG"], - match: { - ID: /#((?:[\w\u00c0-\uFFFF\-]|\\.)+)/, - CLASS: /\.((?:[\w\u00c0-\uFFFF\-]|\\.)+)/, - NAME: /\[name=['"]*((?:[\w\u00c0-\uFFFF\-]|\\.)+)['"]*\]/, - ATTR: /\[\s*((?:[\w\u00c0-\uFFFF\-]|\\.)+)\s*(?:(\S?=)\s*(?:(['"])(.*?)\3|(#?(?:[\w\u00c0-\uFFFF\-]|\\.)*)|)|)\s*\]/, - TAG: /^((?:[\w\u00c0-\uFFFF\*\-]|\\.)+)/, - CHILD: /:(only|nth|last|first)-child(?:\(\s*(even|odd|(?:[+\-]?\d+|(?:[+\-]?\d*)?n\s*(?:[+\-]\s*\d+)?))\s*\))?/, - POS: /:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^\-]|$)/, - PSEUDO: /:((?:[\w\u00c0-\uFFFF\-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/ - }, - leftMatch: {}, - attrMap: { - "class": "className", - "for": "htmlFor" - }, - attrHandle: { - href: function (a) { - return a.getAttribute("href"); - }, - type: function (a) { - return a.getAttribute("type"); - } - }, - relative: { - "+": function (a, b) { - var c = typeof b == "string", - d = c && !l.test(b), - e = c && !d; - d && (b = b.toLowerCase()); - for (var f = 0, g = a.length, h; f < g; f++) if (h = a[f]) { - while ((h = h.previousSibling) && h.nodeType !== 1); - a[f] = e || h && h.nodeName.toLowerCase() === b ? h || !1 : h === b; - } - e && m.filter(b, a, !0); - }, - ">": function (a, b) { - var c, - d = typeof b == "string", - e = 0, - f = a.length; - if (d && !l.test(b)) { - b = b.toLowerCase(); - for (; e < f; e++) { - c = a[e]; - if (c) { - var g = c.parentNode; - a[e] = g.nodeName.toLowerCase() === b ? g : !1; - } - } - } else { - for (; e < f; e++) c = a[e], c && (a[e] = d ? c.parentNode : c.parentNode === b); - d && m.filter(b, a, !0); - } - }, - "": function (a, b, c) { - var d, - f = e++, - g = x; - typeof b == "string" && !l.test(b) && (b = b.toLowerCase(), d = b, g = w), g("parentNode", b, f, a, d, c); - }, - "~": function (a, b, c) { - var d, - f = e++, - g = x; - typeof b == "string" && !l.test(b) && (b = b.toLowerCase(), d = b, g = w), g("previousSibling", b, f, a, d, c); - } - }, - find: { - ID: function (a, b, c) { - if (typeof b.getElementById != "undefined" && !c) { - var d = b.getElementById(a[1]); - return d && d.parentNode ? [d] : []; - } - }, - NAME: function (a, b) { - if (typeof b.getElementsByName != "undefined") { - var c = [], - d = b.getElementsByName(a[1]); - for (var e = 0, f = d.length; e < f; e++) d[e].getAttribute("name") === a[1] && c.push(d[e]); - return c.length === 0 ? null : c; - } - }, - TAG: function (a, b) { - if (typeof b.getElementsByTagName != "undefined") return b.getElementsByTagName(a[1]); - } - }, - preFilter: { - CLASS: function (a, b, c, d, e, f) { - a = " " + a[1].replace(j, "") + " "; - if (f) return a; - for (var g = 0, h; (h = b[g]) != null; g++) h && (e ^ (h.className && (" " + h.className + " ").replace(/[\t\n\r]/g, " ").indexOf(a) >= 0) ? c || d.push(h) : c && (b[g] = !1)); - return !1; - }, - ID: function (a) { - return a[1].replace(j, ""); - }, - TAG: function (a, b) { - return a[1].replace(j, "").toLowerCase(); - }, - CHILD: function (a) { - if (a[1] === "nth") { - a[2] || m.error(a[0]), a[2] = a[2].replace(/^\+|\s*/g, ""); - var b = /(-?)(\d*)(?:n([+\-]?\d*))?/.exec(a[2] === "even" && "2n" || a[2] === "odd" && "2n+1" || !/\D/.test(a[2]) && "0n+" + a[2] || a[2]); - a[2] = b[1] + (b[2] || 1) - 0, a[3] = b[3] - 0; - } else a[2] && m.error(a[0]); - a[0] = e++; - return a; - }, - ATTR: function (a, b, c, d, e, f) { - var g = a[1] = a[1].replace(j, ""); - !f && o.attrMap[g] && (a[1] = o.attrMap[g]), a[4] = (a[4] || a[5] || "").replace(j, ""), a[2] === "~=" && (a[4] = " " + a[4] + " "); - return a; - }, - PSEUDO: function (b, c, d, e, f) { - if (b[1] === "not") { - if ((a.exec(b[3]) || "").length > 1 || /^\w/.test(b[3])) b[3] = m(b[3], null, null, c);else { - var g = m.filter(b[3], c, d, !0 ^ f); - d || e.push.apply(e, g); - return !1; - } - } else if (o.match.POS.test(b[0]) || o.match.CHILD.test(b[0])) return !0; - return b; - }, - POS: function (a) { - a.unshift(!0); - return a; - } - }, - filters: { - enabled: function (a) { - return a.disabled === !1 && a.type !== "hidden"; - }, - disabled: function (a) { - return a.disabled === !0; - }, - checked: function (a) { - return a.checked === !0; - }, - selected: function (a) { - a.parentNode && a.parentNode.selectedIndex; - return a.selected === !0; - }, - parent: function (a) { - return !!a.firstChild; - }, - empty: function (a) { - return !a.firstChild; - }, - has: function (a, b, c) { - return !!m(c[3], a).length; - }, - header: function (a) { - return /h\d/i.test(a.nodeName); - }, - text: function (a) { - var b = a.getAttribute("type"), - c = a.type; - return a.nodeName.toLowerCase() === "input" && "text" === c && (b === c || b === null); - }, - radio: function (a) { - return a.nodeName.toLowerCase() === "input" && "radio" === a.type; - }, - checkbox: function (a) { - return a.nodeName.toLowerCase() === "input" && "checkbox" === a.type; - }, - file: function (a) { - return a.nodeName.toLowerCase() === "input" && "file" === a.type; - }, - password: function (a) { - return a.nodeName.toLowerCase() === "input" && "password" === a.type; - }, - submit: function (a) { - var b = a.nodeName.toLowerCase(); - return (b === "input" || b === "button") && "submit" === a.type; - }, - image: function (a) { - return a.nodeName.toLowerCase() === "input" && "image" === a.type; - }, - reset: function (a) { - var b = a.nodeName.toLowerCase(); - return (b === "input" || b === "button") && "reset" === a.type; - }, - button: function (a) { - var b = a.nodeName.toLowerCase(); - return b === "input" && "button" === a.type || b === "button"; - }, - input: function (a) { - return /input|select|textarea|button/i.test(a.nodeName); - }, - focus: function (a) { - return a === a.ownerDocument.activeElement; - } - }, - setFilters: { - first: function (a, b) { - return b === 0; - }, - last: function (a, b, c, d) { - return b === d.length - 1; - }, - even: function (a, b) { - return b % 2 === 0; - }, - odd: function (a, b) { - return b % 2 === 1; - }, - lt: function (a, b, c) { - return b < c[3] - 0; - }, - gt: function (a, b, c) { - return b > c[3] - 0; - }, - nth: function (a, b, c) { - return c[3] - 0 === b; - }, - eq: function (a, b, c) { - return c[3] - 0 === b; - } - }, - filter: { - PSEUDO: function (a, b, c, d) { - var e = b[1], - f = o.filters[e]; - if (f) return f(a, c, b, d); - if (e === "contains") return (a.textContent || a.innerText || n([a]) || "").indexOf(b[3]) >= 0; - if (e === "not") { - var g = b[3]; - for (var h = 0, i = g.length; h < i; h++) if (g[h] === a) return !1; - return !0; - } - m.error(e); - }, - CHILD: function (a, b) { - var c, - e, - f, - g, - h, - i, - j, - k = b[1], - l = a; - switch (k) { - case "only": - case "first": - while (l = l.previousSibling) if (l.nodeType === 1) return !1; - if (k === "first") return !0; - l = a; - case "last": - while (l = l.nextSibling) if (l.nodeType === 1) return !1; - return !0; - case "nth": - c = b[2], e = b[3]; - if (c === 1 && e === 0) return !0; - f = b[0], g = a.parentNode; - if (g && (g[d] !== f || !a.nodeIndex)) { - i = 0; - for (l = g.firstChild; l; l = l.nextSibling) l.nodeType === 1 && (l.nodeIndex = ++i); - g[d] = f; - } - j = a.nodeIndex - e; - return c === 0 ? j === 0 : j % c === 0 && j / c >= 0; - } - }, - ID: function (a, b) { - return a.nodeType === 1 && a.getAttribute("id") === b; - }, - TAG: function (a, b) { - return b === "*" && a.nodeType === 1 || !!a.nodeName && a.nodeName.toLowerCase() === b; - }, - CLASS: function (a, b) { - return (" " + (a.className || a.getAttribute("class")) + " ").indexOf(b) > -1; - }, - ATTR: function (a, b) { - var c = b[1], - d = m.attr ? m.attr(a, c) : o.attrHandle[c] ? o.attrHandle[c](a) : a[c] != null ? a[c] : a.getAttribute(c), - e = d + "", - f = b[2], - g = b[4]; - return d == null ? f === "!=" : !f && m.attr ? d != null : f === "=" ? e === g : f === "*=" ? e.indexOf(g) >= 0 : f === "~=" ? (" " + e + " ").indexOf(g) >= 0 : g ? f === "!=" ? e !== g : f === "^=" ? e.indexOf(g) === 0 : f === "$=" ? e.substr(e.length - g.length) === g : f === "|=" ? e === g || e.substr(0, g.length + 1) === g + "-" : !1 : e && d !== !1; - }, - POS: function (a, b, c, d) { - var e = b[2], - f = o.setFilters[e]; - if (f) return f(a, c, b, d); - } - } - }, - p = o.match.POS, - q = function (a, b) { - return "\\" + (b - 0 + 1); - }; - for (var r in o.match) o.match[r] = new RegExp(o.match[r].source + /(?![^\[]*\])(?![^\(]*\))/.source), o.leftMatch[r] = new RegExp(/(^(?:.|\r|\n)*?)/.source + o.match[r].source.replace(/\\(\d+)/g, q)); - var s = function (a, b) { - a = Array.prototype.slice.call(a, 0); - if (b) { - b.push.apply(b, a); - return b; - } - return a; - }; - try { - Array.prototype.slice.call(c.documentElement.childNodes, 0)[0].nodeType; - } catch (t) { - s = function (a, b) { - var c = 0, - d = b || []; - if (g.call(a) === "[object Array]") Array.prototype.push.apply(d, a);else if (typeof a.length == "number") for (var e = a.length; c < e; c++) d.push(a[c]);else for (; a[c]; c++) d.push(a[c]); - return d; - }; - } - var u, v; - c.documentElement.compareDocumentPosition ? u = function (a, b) { - if (a === b) { - h = !0; - return 0; - } - if (!a.compareDocumentPosition || !b.compareDocumentPosition) return a.compareDocumentPosition ? -1 : 1; - return a.compareDocumentPosition(b) & 4 ? -1 : 1; - } : (u = function (a, b) { - if (a === b) { - h = !0; - return 0; - } - if (a.sourceIndex && b.sourceIndex) return a.sourceIndex - b.sourceIndex; - var c, - d, - e = [], - f = [], - g = a.parentNode, - i = b.parentNode, - j = g; - if (g === i) return v(a, b); - if (!g) return -1; - if (!i) return 1; - while (j) e.unshift(j), j = j.parentNode; - j = i; - while (j) f.unshift(j), j = j.parentNode; - c = e.length, d = f.length; - for (var k = 0; k < c && k < d; k++) if (e[k] !== f[k]) return v(e[k], f[k]); - return k === c ? v(a, f[k], -1) : v(e[k], b, 1); - }, v = function (a, b, c) { - if (a === b) return c; - var d = a.nextSibling; - while (d) { - if (d === b) return -1; - d = d.nextSibling; - } - return 1; - }), function () { - var a = c.createElement("div"), - d = "script" + new Date().getTime(), - e = c.documentElement; - a.innerHTML = "", e.insertBefore(a, e.firstChild), c.getElementById(d) && (o.find.ID = function (a, c, d) { - if (typeof c.getElementById != "undefined" && !d) { - var e = c.getElementById(a[1]); - return e ? e.id === a[1] || typeof e.getAttributeNode != "undefined" && e.getAttributeNode("id").nodeValue === a[1] ? [e] : b : []; - } - }, o.filter.ID = function (a, b) { - var c = typeof a.getAttributeNode != "undefined" && a.getAttributeNode("id"); - return a.nodeType === 1 && c && c.nodeValue === b; - }), e.removeChild(a), e = a = null; - }(), function () { - var a = c.createElement("div"); - a.appendChild(c.createComment("")), a.getElementsByTagName("*").length > 0 && (o.find.TAG = function (a, b) { - var c = b.getElementsByTagName(a[1]); - if (a[1] === "*") { - var d = []; - for (var e = 0; c[e]; e++) c[e].nodeType === 1 && d.push(c[e]); - c = d; - } - return c; - }), a.innerHTML = "", a.firstChild && typeof a.firstChild.getAttribute != "undefined" && a.firstChild.getAttribute("href") !== "#" && (o.attrHandle.href = function (a) { - return a.getAttribute("href", 2); - }), a = null; - }(), c.querySelectorAll && function () { - var a = m, - b = c.createElement("div"), - d = "__sizzle__"; - b.innerHTML = "

"; - if (!b.querySelectorAll || b.querySelectorAll(".TEST").length !== 0) { - m = function (b, e, f, g) { - e = e || c; - if (!g && !m.isXML(e)) { - var h = /^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec(b); - if (h && (e.nodeType === 1 || e.nodeType === 9)) { - if (h[1]) return s(e.getElementsByTagName(b), f); - if (h[2] && o.find.CLASS && e.getElementsByClassName) return s(e.getElementsByClassName(h[2]), f); - } - if (e.nodeType === 9) { - if (b === "body" && e.body) return s([e.body], f); - if (h && h[3]) { - var i = e.getElementById(h[3]); - if (!i || !i.parentNode) return s([], f); - if (i.id === h[3]) return s([i], f); - } - try { - return s(e.querySelectorAll(b), f); - } catch (j) {} - } else if (e.nodeType === 1 && e.nodeName.toLowerCase() !== "object") { - var k = e, - l = e.getAttribute("id"), - n = l || d, - p = e.parentNode, - q = /^\s*[+~]/.test(b); - l ? n = n.replace(/'/g, "\\$&") : e.setAttribute("id", n), q && p && (e = e.parentNode); - try { - if (!q || p) return s(e.querySelectorAll("[id='" + n + "'] " + b), f); - } catch (r) {} finally { - l || k.removeAttribute("id"); - } - } - } - return a(b, e, f, g); - }; - for (var e in a) m[e] = a[e]; - b = null; - } - }(), function () { - var a = c.documentElement, - b = a.matchesSelector || a.mozMatchesSelector || a.webkitMatchesSelector || a.msMatchesSelector; - if (b) { - var d = !b.call(c.createElement("div"), "div"), - e = !1; - try { - b.call(c.documentElement, "[test!='']:sizzle"); - } catch (f) { - e = !0; - } - m.matchesSelector = function (a, c) { - c = c.replace(/\=\s*([^'"\]]*)\s*\]/g, "='$1']"); - if (!m.isXML(a)) try { - if (e || !o.match.PSEUDO.test(c) && !/!=/.test(c)) { - var f = b.call(a, c); - if (f || !d || a.document && a.document.nodeType !== 11) return f; - } - } catch (g) {} - return m(c, null, null, [a]).length > 0; - }; - } - }(), function () { - var a = c.createElement("div"); - a.innerHTML = "
"; - if (!!a.getElementsByClassName && a.getElementsByClassName("e").length !== 0) { - a.lastChild.className = "e"; - if (a.getElementsByClassName("e").length === 1) return; - o.order.splice(1, 0, "CLASS"), o.find.CLASS = function (a, b, c) { - if (typeof b.getElementsByClassName != "undefined" && !c) return b.getElementsByClassName(a[1]); - }, a = null; - } - }(), c.documentElement.contains ? m.contains = function (a, b) { - return a !== b && (a.contains ? a.contains(b) : !0); - } : c.documentElement.compareDocumentPosition ? m.contains = function (a, b) { - return !!(a.compareDocumentPosition(b) & 16); - } : m.contains = function () { - return !1; - }, m.isXML = function (a) { - var b = (a ? a.ownerDocument || a : 0).documentElement; - return b ? b.nodeName !== "HTML" : !1; - }; - var y = function (a, b, c) { - var d, - e = [], - f = "", - g = b.nodeType ? [b] : b; - while (d = o.match.PSEUDO.exec(a)) f += d[0], a = a.replace(o.match.PSEUDO, ""); - a = o.relative[a] ? a + "*" : a; - for (var h = 0, i = g.length; h < i; h++) m(a, g[h], e, c); - return m.filter(f, e); - }; - m.attr = f.attr, m.selectors.attrMap = {}, f.find = m, f.expr = m.selectors, f.expr[":"] = f.expr.filters, f.unique = m.uniqueSort, f.text = m.getText, f.isXMLDoc = m.isXML, f.contains = m.contains; - }(); - var O = /Until$/, - P = /^(?:parents|prevUntil|prevAll)/, - Q = /,/, - R = /^.[^:#\[\.,]*$/, - S = Array.prototype.slice, - T = f.expr.match.POS, - U = { - children: !0, - contents: !0, - next: !0, - prev: !0 - }; - f.fn.extend({ - find: function (a) { - var b = this, - c, - d; - if (typeof a != "string") return f(a).filter(function () { - for (c = 0, d = b.length; c < d; c++) if (f.contains(b[c], this)) return !0; - }); - var e = this.pushStack("", "find", a), - g, - h, - i; - for (c = 0, d = this.length; c < d; c++) { - g = e.length, f.find(a, this[c], e); - if (c > 0) for (h = g; h < e.length; h++) for (i = 0; i < g; i++) if (e[i] === e[h]) { - e.splice(h--, 1); - break; - } - } - return e; - }, - has: function (a) { - var b = f(a); - return this.filter(function () { - for (var a = 0, c = b.length; a < c; a++) if (f.contains(this, b[a])) return !0; - }); - }, - not: function (a) { - return this.pushStack(W(this, a, !1), "not", a); - }, - filter: function (a) { - return this.pushStack(W(this, a, !0), "filter", a); - }, - is: function (a) { - return !!a && (typeof a == "string" ? T.test(a) ? f(a, this.context).index(this[0]) >= 0 : f.filter(a, this).length > 0 : this.filter(a).length > 0); - }, - closest: function (a, b) { - var c = [], - d, - e, - g = this[0]; - if (f.isArray(a)) { - var h = 1; - while (g && g.ownerDocument && g !== b) { - for (d = 0; d < a.length; d++) f(g).is(a[d]) && c.push({ - selector: a[d], - elem: g, - level: h - }); - g = g.parentNode, h++; - } - return c; - } - var i = T.test(a) || typeof a != "string" ? f(a, b || this.context) : 0; - for (d = 0, e = this.length; d < e; d++) { - g = this[d]; - while (g) { - if (i ? i.index(g) > -1 : f.find.matchesSelector(g, a)) { - c.push(g); - break; - } - g = g.parentNode; - if (!g || !g.ownerDocument || g === b || g.nodeType === 11) break; - } - } - c = c.length > 1 ? f.unique(c) : c; - return this.pushStack(c, "closest", a); - }, - index: function (a) { - if (!a) return this[0] && this[0].parentNode ? this.prevAll().length : -1; - if (typeof a == "string") return f.inArray(this[0], f(a)); - return f.inArray(a.jquery ? a[0] : a, this); - }, - add: function (a, b) { - var c = typeof a == "string" ? f(a, b) : f.makeArray(a && a.nodeType ? [a] : a), - d = f.merge(this.get(), c); - return this.pushStack(V(c[0]) || V(d[0]) ? d : f.unique(d)); - }, - andSelf: function () { - return this.add(this.prevObject); - } - }), f.each({ - parent: function (a) { - var b = a.parentNode; - return b && b.nodeType !== 11 ? b : null; - }, - parents: function (a) { - return f.dir(a, "parentNode"); - }, - parentsUntil: function (a, b, c) { - return f.dir(a, "parentNode", c); - }, - next: function (a) { - return f.nth(a, 2, "nextSibling"); - }, - prev: function (a) { - return f.nth(a, 2, "previousSibling"); - }, - nextAll: function (a) { - return f.dir(a, "nextSibling"); - }, - prevAll: function (a) { - return f.dir(a, "previousSibling"); - }, - nextUntil: function (a, b, c) { - return f.dir(a, "nextSibling", c); - }, - prevUntil: function (a, b, c) { - return f.dir(a, "previousSibling", c); - }, - siblings: function (a) { - return f.sibling(a.parentNode.firstChild, a); - }, - children: function (a) { - return f.sibling(a.firstChild); - }, - contents: function (a) { - return f.nodeName(a, "iframe") ? a.contentDocument || a.contentWindow.document : f.makeArray(a.childNodes); - } - }, function (a, b) { - f.fn[a] = function (c, d) { - var e = f.map(this, b, c), - g = S.call(arguments); - O.test(a) || (d = c), d && typeof d == "string" && (e = f.filter(d, e)), e = this.length > 1 && !U[a] ? f.unique(e) : e, (this.length > 1 || Q.test(d)) && P.test(a) && (e = e.reverse()); - return this.pushStack(e, a, g.join(",")); - }; - }), f.extend({ - filter: function (a, b, c) { - c && (a = ":not(" + a + ")"); - return b.length === 1 ? f.find.matchesSelector(b[0], a) ? [b[0]] : [] : f.find.matches(a, b); - }, - dir: function (a, c, d) { - var e = [], - g = a[c]; - while (g && g.nodeType !== 9 && (d === b || g.nodeType !== 1 || !f(g).is(d))) g.nodeType === 1 && e.push(g), g = g[c]; - return e; - }, - nth: function (a, b, c, d) { - b = b || 1; - var e = 0; - for (; a; a = a[c]) if (a.nodeType === 1 && ++e === b) break; - return a; - }, - sibling: function (a, b) { - var c = []; - for (; a; a = a.nextSibling) a.nodeType === 1 && a !== b && c.push(a); - return c; - } - }); - var Y = "abbr article aside audio canvas datalist details figcaption figure footer header hgroup mark meter nav output progress section summary time video", - Z = / jQuery\d+="(?:\d+|null)"/g, - $ = /^\s+/, - _ = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig, - ba = /<([\w:]+)/, - bb = /", ""], - legend: [1, "
", "
"], - thead: [1, "", "
"], - tr: [2, "", "
"], - td: [3, "", "
"], - col: [2, "", "
"], - area: [1, "", ""], - _default: [0, "", ""] - }, - bk = X(c); - bj.optgroup = bj.option, bj.tbody = bj.tfoot = bj.colgroup = bj.caption = bj.thead, bj.th = bj.td, f.support.htmlSerialize || (bj._default = [1, "div
", "
"]), f.fn.extend({ - text: function (a) { - if (f.isFunction(a)) return this.each(function (b) { - var c = f(this); - c.text(a.call(this, b, c.text())); - }); - if (typeof a != "object" && a !== b) return this.empty().append((this[0] && this[0].ownerDocument || c).createTextNode(a)); - return f.text(this); - }, - wrapAll: function (a) { - if (f.isFunction(a)) return this.each(function (b) { - f(this).wrapAll(a.call(this, b)); - }); - if (this[0]) { - var b = f(a, this[0].ownerDocument).eq(0).clone(!0); - this[0].parentNode && b.insertBefore(this[0]), b.map(function () { - var a = this; - while (a.firstChild && a.firstChild.nodeType === 1) a = a.firstChild; - return a; - }).append(this); - } - return this; - }, - wrapInner: function (a) { - if (f.isFunction(a)) return this.each(function (b) { - f(this).wrapInner(a.call(this, b)); - }); - return this.each(function () { - var b = f(this), - c = b.contents(); - c.length ? c.wrapAll(a) : b.append(a); - }); - }, - wrap: function (a) { - return this.each(function () { - f(this).wrapAll(a); - }); - }, - unwrap: function () { - return this.parent().each(function () { - f.nodeName(this, "body") || f(this).replaceWith(this.childNodes); - }).end(); - }, - append: function () { - return this.domManip(arguments, !0, function (a) { - this.nodeType === 1 && this.appendChild(a); - }); - }, - prepend: function () { - return this.domManip(arguments, !0, function (a) { - this.nodeType === 1 && this.insertBefore(a, this.firstChild); - }); - }, - before: function () { - if (this[0] && this[0].parentNode) return this.domManip(arguments, !1, function (a) { - this.parentNode.insertBefore(a, this); - }); - if (arguments.length) { - var a = f(arguments[0]); - a.push.apply(a, this.toArray()); - return this.pushStack(a, "before", arguments); - } - }, - after: function () { - if (this[0] && this[0].parentNode) return this.domManip(arguments, !1, function (a) { - this.parentNode.insertBefore(a, this.nextSibling); - }); - if (arguments.length) { - var a = this.pushStack(this, "after", arguments); - a.push.apply(a, f(arguments[0]).toArray()); - return a; - } - }, - remove: function (a, b) { - for (var c = 0, d; (d = this[c]) != null; c++) if (!a || f.filter(a, [d]).length) !b && d.nodeType === 1 && (f.cleanData(d.getElementsByTagName("*")), f.cleanData([d])), d.parentNode && d.parentNode.removeChild(d); - return this; - }, - empty: function () { - for (var a = 0, b; (b = this[a]) != null; a++) { - b.nodeType === 1 && f.cleanData(b.getElementsByTagName("*")); - while (b.firstChild) b.removeChild(b.firstChild); - } - return this; - }, - clone: function (a, b) { - a = a == null ? !1 : a, b = b == null ? a : b; - return this.map(function () { - return f.clone(this, a, b); - }); - }, - html: function (a) { - if (a === b) return this[0] && this[0].nodeType === 1 ? this[0].innerHTML.replace(Z, "") : null; - if (typeof a == "string" && !bd.test(a) && (f.support.leadingWhitespace || !$.test(a)) && !bj[(ba.exec(a) || ["", ""])[1].toLowerCase()]) { - a = a.replace(_, "<$1>"); - try { - for (var c = 0, d = this.length; c < d; c++) this[c].nodeType === 1 && (f.cleanData(this[c].getElementsByTagName("*")), this[c].innerHTML = a); - } catch (e) { - this.empty().append(a); - } - } else f.isFunction(a) ? this.each(function (b) { - var c = f(this); - c.html(a.call(this, b, c.html())); - }) : this.empty().append(a); - return this; - }, - replaceWith: function (a) { - if (this[0] && this[0].parentNode) { - if (f.isFunction(a)) return this.each(function (b) { - var c = f(this), - d = c.html(); - c.replaceWith(a.call(this, b, d)); - }); - typeof a != "string" && (a = f(a).detach()); - return this.each(function () { - var b = this.nextSibling, - c = this.parentNode; - f(this).remove(), b ? f(b).before(a) : f(c).append(a); - }); - } - return this.length ? this.pushStack(f(f.isFunction(a) ? a() : a), "replaceWith", a) : this; - }, - detach: function (a) { - return this.remove(a, !0); - }, - domManip: function (a, c, d) { - var e, - g, - h, - i, - j = a[0], - k = []; - if (!f.support.checkClone && arguments.length === 3 && typeof j == "string" && bg.test(j)) return this.each(function () { - f(this).domManip(a, c, d, !0); - }); - if (f.isFunction(j)) return this.each(function (e) { - var g = f(this); - a[0] = j.call(this, e, c ? g.html() : b), g.domManip(a, c, d); - }); - if (this[0]) { - i = j && j.parentNode, f.support.parentNode && i && i.nodeType === 11 && i.childNodes.length === this.length ? e = { - fragment: i - } : e = f.buildFragment(a, this, k), h = e.fragment, h.childNodes.length === 1 ? g = h = h.firstChild : g = h.firstChild; - if (g) { - c = c && f.nodeName(g, "tr"); - for (var l = 0, m = this.length, n = m - 1; l < m; l++) d.call(c ? bl(this[l], g) : this[l], e.cacheable || m > 1 && l < n ? f.clone(h, !0, !0) : h); - } - k.length && f.each(k, br); - } - return this; - } - }), f.buildFragment = function (a, b, d) { - var e, - g, - h, - i, - j = a[0]; - b && b[0] && (i = b[0].ownerDocument || b[0]), i.createDocumentFragment || (i = c), a.length === 1 && typeof j == "string" && j.length < 512 && i === c && j.charAt(0) === "<" && !be.test(j) && (f.support.checkClone || !bg.test(j)) && !f.support.unknownElems && bf.test(j) && (g = !0, h = f.fragments[j], h && h !== 1 && (e = h)), e || (e = i.createDocumentFragment(), f.clean(a, i, e, d)), g && (f.fragments[j] = h ? e : 1); - return { - fragment: e, - cacheable: g - }; - }, f.fragments = {}, f.each({ - appendTo: "append", - prependTo: "prepend", - insertBefore: "before", - insertAfter: "after", - replaceAll: "replaceWith" - }, function (a, b) { - f.fn[a] = function (c) { - var d = [], - e = f(c), - g = this.length === 1 && this[0].parentNode; - if (g && g.nodeType === 11 && g.childNodes.length === 1 && e.length === 1) { - e[b](this[0]); - return this; - } - for (var h = 0, i = e.length; h < i; h++) { - var j = (h > 0 ? this.clone(!0) : this).get(); - f(e[h])[b](j), d = d.concat(j); - } - return this.pushStack(d, a, e.selector); - }; - }), f.extend({ - clone: function (a, b, c) { - var d = a.cloneNode(!0), - e, - g, - h; - if ((!f.support.noCloneEvent || !f.support.noCloneChecked) && (a.nodeType === 1 || a.nodeType === 11) && !f.isXMLDoc(a)) { - bn(a, d), e = bo(a), g = bo(d); - for (h = 0; e[h]; ++h) g[h] && bn(e[h], g[h]); - } - if (b) { - bm(a, d); - if (c) { - e = bo(a), g = bo(d); - for (h = 0; e[h]; ++h) bm(e[h], g[h]); - } - } - e = g = null; - return d; - }, - clean: function (a, b, d, e) { - var g; - b = b || c, typeof b.createElement == "undefined" && (b = b.ownerDocument || b[0] && b[0].ownerDocument || c); - var h = [], - i; - for (var j = 0, k; (k = a[j]) != null; j++) { - typeof k == "number" && (k += ""); - if (!k) continue; - if (typeof k == "string") if (!bc.test(k)) k = b.createTextNode(k);else { - k = k.replace(_, "<$1>"); - var l = (ba.exec(k) || ["", ""])[1].toLowerCase(), - m = bj[l] || bj._default, - n = m[0], - o = b.createElement("div"); - b === c ? bk.appendChild(o) : X(b).appendChild(o), o.innerHTML = m[1] + k + m[2]; - while (n--) o = o.lastChild; - if (!f.support.tbody) { - var p = bb.test(k), - q = l === "table" && !p ? o.firstChild && o.firstChild.childNodes : m[1] === "" && !p ? o.childNodes : []; - for (i = q.length - 1; i >= 0; --i) f.nodeName(q[i], "tbody") && !q[i].childNodes.length && q[i].parentNode.removeChild(q[i]); - } - !f.support.leadingWhitespace && $.test(k) && o.insertBefore(b.createTextNode($.exec(k)[0]), o.firstChild), k = o.childNodes; - } - var r; - if (!f.support.appendChecked) if (k[0] && typeof (r = k.length) == "number") for (i = 0; i < r; i++) bq(k[i]);else bq(k); - k.nodeType ? h.push(k) : h = f.merge(h, k); - } - if (d) { - g = function (a) { - return !a.type || bh.test(a.type); - }; - for (j = 0; h[j]; j++) if (e && f.nodeName(h[j], "script") && (!h[j].type || h[j].type.toLowerCase() === "text/javascript")) e.push(h[j].parentNode ? h[j].parentNode.removeChild(h[j]) : h[j]);else { - if (h[j].nodeType === 1) { - var s = f.grep(h[j].getElementsByTagName("script"), g); - h.splice.apply(h, [j + 1, 0].concat(s)); - } - d.appendChild(h[j]); - } - } - return h; - }, - cleanData: function (a) { - var b, - c, - d = f.cache, - e = f.event.special, - g = f.support.deleteExpando; - for (var h = 0, i; (i = a[h]) != null; h++) { - if (i.nodeName && f.noData[i.nodeName.toLowerCase()]) continue; - c = i[f.expando]; - if (c) { - b = d[c]; - if (b && b.events) { - for (var j in b.events) e[j] ? f.event.remove(i, j) : f.removeEvent(i, j, b.handle); - b.handle && (b.handle.elem = null); - } - g ? delete i[f.expando] : i.removeAttribute && i.removeAttribute(f.expando), delete d[c]; - } - } - } - }); - var bs = /alpha\([^)]*\)/i, - bt = /opacity=([^)]*)/, - bu = /([A-Z]|^ms)/g, - bv = /^-?\d+(?:px)?$/i, - bw = /^-?\d/, - bx = /^([\-+])=([\-+.\de]+)/, - by = { - position: "absolute", - visibility: "hidden", - display: "block" - }, - bz = ["Left", "Right"], - bA = ["Top", "Bottom"], - bB, - bC, - bD; - f.fn.css = function (a, c) { - if (arguments.length === 2 && c === b) return this; - return f.access(this, a, c, !0, function (a, c, d) { - return d !== b ? f.style(a, c, d) : f.css(a, c); - }); - }, f.extend({ - cssHooks: { - opacity: { - get: function (a, b) { - if (b) { - var c = bB(a, "opacity", "opacity"); - return c === "" ? "1" : c; - } - return a.style.opacity; - } - } - }, - cssNumber: { - fillOpacity: !0, - fontWeight: !0, - lineHeight: !0, - opacity: !0, - orphans: !0, - widows: !0, - zIndex: !0, - zoom: !0 - }, - cssProps: { - "float": f.support.cssFloat ? "cssFloat" : "styleFloat" - }, - style: function (a, c, d, e) { - if (!!a && a.nodeType !== 3 && a.nodeType !== 8 && !!a.style) { - var g, - h, - i = f.camelCase(c), - j = a.style, - k = f.cssHooks[i]; - c = f.cssProps[i] || i; - if (d === b) { - if (k && "get" in k && (g = k.get(a, !1, e)) !== b) return g; - return j[c]; - } - h = typeof d, h === "string" && (g = bx.exec(d)) && (d = +(g[1] + 1) * +g[2] + parseFloat(f.css(a, c)), h = "number"); - if (d == null || h === "number" && isNaN(d)) return; - h === "number" && !f.cssNumber[i] && (d += "px"); - if (!k || !("set" in k) || (d = k.set(a, d)) !== b) try { - j[c] = d; - } catch (l) {} - } - }, - css: function (a, c, d) { - var e, g; - c = f.camelCase(c), g = f.cssHooks[c], c = f.cssProps[c] || c, c === "cssFloat" && (c = "float"); - if (g && "get" in g && (e = g.get(a, !0, d)) !== b) return e; - if (bB) return bB(a, c); - }, - swap: function (a, b, c) { - var d = {}; - for (var e in b) d[e] = a.style[e], a.style[e] = b[e]; - c.call(a); - for (e in b) a.style[e] = d[e]; - } - }), f.curCSS = f.css, f.each(["height", "width"], function (a, b) { - f.cssHooks[b] = { - get: function (a, c, d) { - var e; - if (c) { - if (a.offsetWidth !== 0) return bE(a, b, d); - f.swap(a, by, function () { - e = bE(a, b, d); - }); - return e; - } - }, - set: function (a, b) { - if (!bv.test(b)) return b; - b = parseFloat(b); - if (b >= 0) return b + "px"; - } - }; - }), f.support.opacity || (f.cssHooks.opacity = { - get: function (a, b) { - return bt.test((b && a.currentStyle ? a.currentStyle.filter : a.style.filter) || "") ? parseFloat(RegExp.$1) / 100 + "" : b ? "1" : ""; - }, - set: function (a, b) { - var c = a.style, - d = a.currentStyle, - e = f.isNumeric(b) ? "alpha(opacity=" + b * 100 + ")" : "", - g = d && d.filter || c.filter || ""; - c.zoom = 1; - if (b >= 1 && f.trim(g.replace(bs, "")) === "") { - c.removeAttribute("filter"); - if (d && !d.filter) return; - } - c.filter = bs.test(g) ? g.replace(bs, e) : g + " " + e; - } - }), f(function () { - f.support.reliableMarginRight || (f.cssHooks.marginRight = { - get: function (a, b) { - var c; - f.swap(a, { - display: "inline-block" - }, function () { - b ? c = bB(a, "margin-right", "marginRight") : c = a.style.marginRight; - }); - return c; - } - }); - }), c.defaultView && c.defaultView.getComputedStyle && (bC = function (a, c) { - var d, e, g; - c = c.replace(bu, "-$1").toLowerCase(); - if (!(e = a.ownerDocument.defaultView)) return b; - if (g = e.getComputedStyle(a, null)) d = g.getPropertyValue(c), d === "" && !f.contains(a.ownerDocument.documentElement, a) && (d = f.style(a, c)); - return d; - }), c.documentElement.currentStyle && (bD = function (a, b) { - var c, - d, - e, - f = a.currentStyle && a.currentStyle[b], - g = a.style; - f === null && g && (e = g[b]) && (f = e), !bv.test(f) && bw.test(f) && (c = g.left, d = a.runtimeStyle && a.runtimeStyle.left, d && (a.runtimeStyle.left = a.currentStyle.left), g.left = b === "fontSize" ? "1em" : f || 0, f = g.pixelLeft + "px", g.left = c, d && (a.runtimeStyle.left = d)); - return f === "" ? "auto" : f; - }), bB = bC || bD, f.expr && f.expr.filters && (f.expr.filters.hidden = function (a) { - var b = a.offsetWidth, - c = a.offsetHeight; - return b === 0 && c === 0 || !f.support.reliableHiddenOffsets && (a.style && a.style.display || f.css(a, "display")) === "none"; - }, f.expr.filters.visible = function (a) { - return !f.expr.filters.hidden(a); - }); - var bF = /%20/g, - bG = /\[\]$/, - bH = /\r?\n/g, - bI = /#.*$/, - bJ = /^(.*?):[ \t]*([^\r\n]*)\r?$/mg, - bK = /^(?:color|date|datetime|datetime-local|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i, - bL = /^(?:about|app|app\-storage|.+\-extension|file|res|widget):$/, - bM = /^(?:GET|HEAD)$/, - bN = /^\/\//, - bO = /\?/, - bP = /)<[^<]*)*<\/script>/gi, - bQ = /^(?:select|textarea)/i, - bR = /\s+/, - bS = /([?&])_=[^&]*/, - bT = /^([\w\+\.\-]+:)(?:\/\/([^\/?#:]*)(?::(\d+))?)?/, - bU = f.fn.load, - bV = {}, - bW = {}, - bX, - bY, - bZ = ["*/"] + ["*"]; - try { - bX = e.href; - } catch (b$) { - bX = c.createElement("a"), bX.href = "", bX = bX.href; - } - bY = bT.exec(bX.toLowerCase()) || [], f.fn.extend({ - load: function (a, c, d) { - if (typeof a != "string" && bU) return bU.apply(this, arguments); - if (!this.length) return this; - var e = a.indexOf(" "); - if (e >= 0) { - var g = a.slice(e, a.length); - a = a.slice(0, e); - } - var h = "GET"; - c && (f.isFunction(c) ? (d = c, c = b) : typeof c == "object" && (c = f.param(c, f.ajaxSettings.traditional), h = "POST")); - var i = this; - f.ajax({ - url: a, - type: h, - dataType: "html", - data: c, - complete: function (a, b, c) { - c = a.responseText, a.isResolved() && (a.done(function (a) { - c = a; - }), i.html(g ? f("
").append(c.replace(bP, "")).find(g) : c)), d && i.each(d, [c, b, a]); - } - }); - return this; - }, - serialize: function () { - return f.param(this.serializeArray()); - }, - serializeArray: function () { - return this.map(function () { - return this.elements ? f.makeArray(this.elements) : this; - }).filter(function () { - return this.name && !this.disabled && (this.checked || bQ.test(this.nodeName) || bK.test(this.type)); - }).map(function (a, b) { - var c = f(this).val(); - return c == null ? null : f.isArray(c) ? f.map(c, function (a, c) { - return { - name: b.name, - value: a.replace(bH, "\r\n") - }; - }) : { - name: b.name, - value: c.replace(bH, "\r\n") - }; - }).get(); - } - }), f.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "), function (a, b) { - f.fn[b] = function (a) { - return this.bind(b, a); - }; - }), f.each(["get", "post"], function (a, c) { - f[c] = function (a, d, e, g) { - f.isFunction(d) && (g = g || e, e = d, d = b); - return f.ajax({ - type: c, - url: a, - data: d, - success: e, - dataType: g - }); - }; - }), f.extend({ - getScript: function (a, c) { - return f.get(a, b, c, "script"); - }, - getJSON: function (a, b, c) { - return f.get(a, b, c, "json"); - }, - ajaxSetup: function (a, b) { - b ? cb(a, f.ajaxSettings) : (b = a, a = f.ajaxSettings), cb(a, b); - return a; - }, - ajaxSettings: { - url: bX, - isLocal: bL.test(bY[1]), - global: !0, - type: "GET", - contentType: "application/x-www-form-urlencoded", - processData: !0, - async: !0, - accepts: { - xml: "application/xml, text/xml", - html: "text/html", - text: "text/plain", - json: "application/json, text/javascript", - "*": bZ - }, - contents: { - xml: /xml/, - html: /html/, - json: /json/ - }, - responseFields: { - xml: "responseXML", - text: "responseText" - }, - converters: { - "* text": a.String, - "text html": !0, - "text json": f.parseJSON, - "text xml": f.parseXML - }, - flatOptions: { - context: !0, - url: !0 - } - }, - ajaxPrefilter: b_(bV), - ajaxTransport: b_(bW), - ajax: function (a, c) { - function w(a, c, l, m) { - if (s !== 2) { - s = 2, q && clearTimeout(q), p = b, n = m || "", v.readyState = a > 0 ? 4 : 0; - var o, - r, - u, - w = c, - x = l ? cd(d, v, l) : b, - y, - z; - if (a >= 200 && a < 300 || a === 304) { - if (d.ifModified) { - if (y = v.getResponseHeader("Last-Modified")) f.lastModified[k] = y; - if (z = v.getResponseHeader("Etag")) f.etag[k] = z; - } - if (a === 304) w = "notmodified", o = !0;else try { - r = ce(d, x), w = "success", o = !0; - } catch (A) { - w = "parsererror", u = A; - } - } else { - u = w; - if (!w || a) w = "error", a < 0 && (a = 0); - } - v.status = a, v.statusText = "" + (c || w), o ? h.resolveWith(e, [r, w, v]) : h.rejectWith(e, [v, w, u]), v.statusCode(j), j = b, t && g.trigger("ajax" + (o ? "Success" : "Error"), [v, d, o ? r : u]), i.fireWith(e, [v, w]), t && (g.trigger("ajaxComplete", [v, d]), --f.active || f.event.trigger("ajaxStop")); - } - } - typeof a == "object" && (c = a, a = b), c = c || {}; - var d = f.ajaxSetup({}, c), - e = d.context || d, - g = e !== d && (e.nodeType || e instanceof f) ? f(e) : f.event, - h = f.Deferred(), - i = f.Callbacks("once memory"), - j = d.statusCode || {}, - k, - l = {}, - m = {}, - n, - o, - p, - q, - r, - s = 0, - t, - u, - v = { - readyState: 0, - setRequestHeader: function (a, b) { - if (!s) { - var c = a.toLowerCase(); - a = m[c] = m[c] || a, l[a] = b; - } - return this; - }, - getAllResponseHeaders: function () { - return s === 2 ? n : null; - }, - getResponseHeader: function (a) { - var c; - if (s === 2) { - if (!o) { - o = {}; - while (c = bJ.exec(n)) o[c[1].toLowerCase()] = c[2]; - } - c = o[a.toLowerCase()]; - } - return c === b ? null : c; - }, - overrideMimeType: function (a) { - s || (d.mimeType = a); - return this; - }, - abort: function (a) { - a = a || "abort", p && p.abort(a), w(0, a); - return this; - } - }; - h.promise(v), v.success = v.done, v.error = v.fail, v.complete = i.add, v.statusCode = function (a) { - if (a) { - var b; - if (s < 2) for (b in a) j[b] = [j[b], a[b]];else b = a[v.status], v.then(b, b); - } - return this; - }, d.url = ((a || d.url) + "").replace(bI, "").replace(bN, bY[1] + "//"), d.dataTypes = f.trim(d.dataType || "*").toLowerCase().split(bR), d.crossDomain == null && (r = bT.exec(d.url.toLowerCase()), d.crossDomain = !(!r || r[1] == bY[1] && r[2] == bY[2] && (r[3] || (r[1] === "http:" ? 80 : 443)) == (bY[3] || (bY[1] === "http:" ? 80 : 443)))), d.data && d.processData && typeof d.data != "string" && (d.data = f.param(d.data, d.traditional)), ca(bV, d, c, v); - if (s === 2) return !1; - t = d.global, d.type = d.type.toUpperCase(), d.hasContent = !bM.test(d.type), t && f.active++ === 0 && f.event.trigger("ajaxStart"); - if (!d.hasContent) { - d.data && (d.url += (bO.test(d.url) ? "&" : "?") + d.data, delete d.data), k = d.url; - if (d.cache === !1) { - var x = f.now(), - y = d.url.replace(bS, "$1_=" + x); - d.url = y + (y === d.url ? (bO.test(d.url) ? "&" : "?") + "_=" + x : ""); - } - } - (d.data && d.hasContent && d.contentType !== !1 || c.contentType) && v.setRequestHeader("Content-Type", d.contentType), d.ifModified && (k = k || d.url, f.lastModified[k] && v.setRequestHeader("If-Modified-Since", f.lastModified[k]), f.etag[k] && v.setRequestHeader("If-None-Match", f.etag[k])), v.setRequestHeader("Accept", d.dataTypes[0] && d.accepts[d.dataTypes[0]] ? d.accepts[d.dataTypes[0]] + (d.dataTypes[0] !== "*" ? ", " + bZ + "; q=0.01" : "") : d.accepts["*"]); - for (u in d.headers) v.setRequestHeader(u, d.headers[u]); - if (d.beforeSend && (d.beforeSend.call(e, v, d) === !1 || s === 2)) { - v.abort(); - return !1; - } - for (u in { - success: 1, - error: 1, - complete: 1 - }) v[u](d[u]); - p = ca(bW, d, c, v); - if (!p) w(-1, "No Transport");else { - v.readyState = 1, t && g.trigger("ajaxSend", [v, d]), d.async && d.timeout > 0 && (q = setTimeout(function () { - v.abort("timeout"); - }, d.timeout)); - try { - s = 1, p.send(l, w); - } catch (z) { - s < 2 ? w(-1, z) : f.error(z); - } - } - return v; - }, - param: function (a, c) { - var d = [], - e = function (a, b) { - b = f.isFunction(b) ? b() : b, d[d.length] = encodeURIComponent(a) + "=" + encodeURIComponent(b); - }; - c === b && (c = f.ajaxSettings.traditional); - if (f.isArray(a) || a.jquery && !f.isPlainObject(a)) f.each(a, function () { - e(this.name, this.value); - });else for (var g in a) cc(g, a[g], c, e); - return d.join("&").replace(bF, "+"); - } - }), f.extend({ - active: 0, - lastModified: {}, - etag: {} - }); - var cf = f.now(), - cg = /(\=)\?(&|$)|\?\?/i; - f.ajaxSetup({ - jsonp: "callback", - jsonpCallback: function () { - return f.expando + "_" + cf++; - } - }), f.ajaxPrefilter("json jsonp", function (b, c, d) { - var e = b.contentType === "application/x-www-form-urlencoded" && typeof b.data == "string"; - if (b.dataTypes[0] === "jsonp" || b.jsonp !== !1 && (cg.test(b.url) || e && cg.test(b.data))) { - var g, - h = b.jsonpCallback = f.isFunction(b.jsonpCallback) ? b.jsonpCallback() : b.jsonpCallback, - i = a[h], - j = b.url, - k = b.data, - l = "$1" + h + "$2"; - b.jsonp !== !1 && (j = j.replace(cg, l), b.url === j && (e && (k = k.replace(cg, l)), b.data === k && (j += (/\?/.test(j) ? "&" : "?") + b.jsonp + "=" + h))), b.url = j, b.data = k, a[h] = function (a) { - g = [a]; - }, d.always(function () { - a[h] = i, g && f.isFunction(i) && a[h](g[0]); - }), b.converters["script json"] = function () { - g || f.error(h + " was not called"); - return g[0]; - }, b.dataTypes[0] = "json"; - return "script"; - } - }), f.ajaxSetup({ - accepts: { - script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript" - }, - contents: { - script: /javascript|ecmascript/ - }, - converters: { - "text script": function (a) { - f.globalEval(a); - return a; - } - } - }), f.ajaxPrefilter("script", function (a) { - a.cache === b && (a.cache = !1), a.crossDomain && (a.type = "GET", a.global = !1); - }), f.ajaxTransport("script", function (a) { - if (a.crossDomain) { - var d, - e = c.head || c.getElementsByTagName("head")[0] || c.documentElement; - return { - send: function (f, g) { - d = c.createElement("script"), d.async = "async", a.scriptCharset && (d.charset = a.scriptCharset), d.src = a.url, d.onload = d.onreadystatechange = function (a, c) { - if (c || !d.readyState || /loaded|complete/.test(d.readyState)) d.onload = d.onreadystatechange = null, e && d.parentNode && e.removeChild(d), d = b, c || g(200, "success"); - }, e.insertBefore(d, e.firstChild); - }, - abort: function () { - d && d.onload(0, 1); - } - }; - } - }); - var ch = a.ActiveXObject ? function () { - for (var a in cj) cj[a](0, 1); - } : !1, - ci = 0, - cj; - f.ajaxSettings.xhr = a.ActiveXObject ? function () { - return !this.isLocal && ck() || cl(); - } : ck, function (a) { - f.extend(f.support, { - ajax: !!a, - cors: !!a && "withCredentials" in a - }); - }(f.ajaxSettings.xhr()), f.support.ajax && f.ajaxTransport(function (c) { - if (!c.crossDomain || f.support.cors) { - var d; - return { - send: function (e, g) { - var h = c.xhr(), - i, - j; - c.username ? h.open(c.type, c.url, c.async, c.username, c.password) : h.open(c.type, c.url, c.async); - if (c.xhrFields) for (j in c.xhrFields) h[j] = c.xhrFields[j]; - c.mimeType && h.overrideMimeType && h.overrideMimeType(c.mimeType), !c.crossDomain && !e["X-Requested-With"] && (e["X-Requested-With"] = "XMLHttpRequest"); - try { - for (j in e) h.setRequestHeader(j, e[j]); - } catch (k) {} - h.send(c.hasContent && c.data || null), d = function (a, e) { - var j, k, l, m, n; - try { - if (d && (e || h.readyState === 4)) { - d = b, i && (h.onreadystatechange = f.noop, ch && delete cj[i]); - if (e) h.readyState !== 4 && h.abort();else { - j = h.status, l = h.getAllResponseHeaders(), m = {}, n = h.responseXML, n && n.documentElement && (m.xml = n), m.text = h.responseText; - try { - k = h.statusText; - } catch (o) { - k = ""; - } - !j && c.isLocal && !c.crossDomain ? j = m.text ? 200 : 404 : j === 1223 && (j = 204); - } - } - } catch (p) { - e || g(-1, p); - } - m && g(j, k, m, l); - }, !c.async || h.readyState === 4 ? d() : (i = ++ci, ch && (cj || (cj = {}, f(a).unload(ch)), cj[i] = d), h.onreadystatechange = d); - }, - abort: function () { - d && d(0, 1); - } - }; - } - }); - var cm = {}, - cn, - co, - cp = /^(?:toggle|show|hide)$/, - cq = /^([+\-]=)?([\d+.\-]+)([a-z%]*)$/i, - cr, - cs = [["height", "marginTop", "marginBottom", "paddingTop", "paddingBottom"], ["width", "marginLeft", "marginRight", "paddingLeft", "paddingRight"], ["opacity"]], - ct; - f.fn.extend({ - show: function (a, b, c) { - var d, e; - if (a || a === 0) return this.animate(cw("show", 3), a, b, c); - for (var g = 0, h = this.length; g < h; g++) d = this[g], d.style && (e = d.style.display, !f._data(d, "olddisplay") && e === "none" && (e = d.style.display = ""), e === "" && f.css(d, "display") === "none" && f._data(d, "olddisplay", cx(d.nodeName))); - for (g = 0; g < h; g++) { - d = this[g]; - if (d.style) { - e = d.style.display; - if (e === "" || e === "none") d.style.display = f._data(d, "olddisplay") || ""; - } - } - return this; - }, - hide: function (a, b, c) { - if (a || a === 0) return this.animate(cw("hide", 3), a, b, c); - var d, - e, - g = 0, - h = this.length; - for (; g < h; g++) d = this[g], d.style && (e = f.css(d, "display"), e !== "none" && !f._data(d, "olddisplay") && f._data(d, "olddisplay", e)); - for (g = 0; g < h; g++) this[g].style && (this[g].style.display = "none"); - return this; - }, - _toggle: f.fn.toggle, - toggle: function (a, b, c) { - var d = typeof a == "boolean"; - f.isFunction(a) && f.isFunction(b) ? this._toggle.apply(this, arguments) : a == null || d ? this.each(function () { - var b = d ? a : f(this).is(":hidden"); - f(this)[b ? "show" : "hide"](); - }) : this.animate(cw("toggle", 3), a, b, c); - return this; - }, - fadeTo: function (a, b, c, d) { - return this.filter(":hidden").css("opacity", 0).show().end().animate({ - opacity: b - }, a, c, d); - }, - animate: function (a, b, c, d) { - function g() { - e.queue === !1 && f._mark(this); - var b = f.extend({}, e), - c = this.nodeType === 1, - d = c && f(this).is(":hidden"), - g, - h, - i, - j, - k, - l, - m, - n, - o; - b.animatedProperties = {}; - for (i in a) { - g = f.camelCase(i), i !== g && (a[g] = a[i], delete a[i]), h = a[g], f.isArray(h) ? (b.animatedProperties[g] = h[1], h = a[g] = h[0]) : b.animatedProperties[g] = b.specialEasing && b.specialEasing[g] || b.easing || "swing"; - if (h === "hide" && d || h === "show" && !d) return b.complete.call(this); - c && (g === "height" || g === "width") && (b.overflow = [this.style.overflow, this.style.overflowX, this.style.overflowY], f.css(this, "display") === "inline" && f.css(this, "float") === "none" && (!f.support.inlineBlockNeedsLayout || cx(this.nodeName) === "inline" ? this.style.display = "inline-block" : this.style.zoom = 1)); - } - b.overflow != null && (this.style.overflow = "hidden"); - for (i in a) j = new f.fx(this, b, i), h = a[i], cp.test(h) ? (o = f._data(this, "toggle" + i) || (h === "toggle" ? d ? "show" : "hide" : 0), o ? (f._data(this, "toggle" + i, o === "show" ? "hide" : "show"), j[o]()) : j[h]()) : (k = cq.exec(h), l = j.cur(), k ? (m = parseFloat(k[2]), n = k[3] || (f.cssNumber[i] ? "" : "px"), n !== "px" && (f.style(this, i, (m || 1) + n), l = (m || 1) / j.cur() * l, f.style(this, i, l + n)), k[1] && (m = (k[1] === "-=" ? -1 : 1) * m + l), j.custom(l, m, n)) : j.custom(l, h, "")); - return !0; - } - var e = f.speed(b, c, d); - if (f.isEmptyObject(a)) return this.each(e.complete, [!1]); - a = f.extend({}, a); - return e.queue === !1 ? this.each(g) : this.queue(e.queue, g); - }, - stop: function (a, c, d) { - typeof a != "string" && (d = c, c = a, a = b), c && a !== !1 && this.queue(a || "fx", []); - return this.each(function () { - function h(a, b, c) { - var e = b[c]; - f.removeData(a, c, !0), e.stop(d); - } - var b, - c = !1, - e = f.timers, - g = f._data(this); - d || f._unmark(!0, this); - if (a == null) for (b in g) g[b].stop && b.indexOf(".run") === b.length - 4 && h(this, g, b);else g[b = a + ".run"] && g[b].stop && h(this, g, b); - for (b = e.length; b--;) e[b].elem === this && (a == null || e[b].queue === a) && (d ? e[b](!0) : e[b].saveState(), c = !0, e.splice(b, 1)); - (!d || !c) && f.dequeue(this, a); - }); - } - }), f.each({ - slideDown: cw("show", 1), - slideUp: cw("hide", 1), - slideToggle: cw("toggle", 1), - fadeIn: { - opacity: "show" - }, - fadeOut: { - opacity: "hide" - }, - fadeToggle: { - opacity: "toggle" - } - }, function (a, b) { - f.fn[a] = function (a, c, d) { - return this.animate(b, a, c, d); - }; - }), f.extend({ - speed: function (a, b, c) { - var d = a && typeof a == "object" ? f.extend({}, a) : { - complete: c || !c && b || f.isFunction(a) && a, - duration: a, - easing: c && b || b && !f.isFunction(b) && b - }; - d.duration = f.fx.off ? 0 : typeof d.duration == "number" ? d.duration : d.duration in f.fx.speeds ? f.fx.speeds[d.duration] : f.fx.speeds._default; - if (d.queue == null || d.queue === !0) d.queue = "fx"; - d.old = d.complete, d.complete = function (a) { - f.isFunction(d.old) && d.old.call(this), d.queue ? f.dequeue(this, d.queue) : a !== !1 && f._unmark(this); - }; - return d; - }, - easing: { - linear: function (a, b, c, d) { - return c + d * a; - }, - swing: function (a, b, c, d) { - return (-Math.cos(a * Math.PI) / 2 + .5) * d + c; - } - }, - timers: [], - fx: function (a, b, c) { - this.options = b, this.elem = a, this.prop = c, b.orig = b.orig || {}; - } - }), f.fx.prototype = { - update: function () { - this.options.step && this.options.step.call(this.elem, this.now, this), (f.fx.step[this.prop] || f.fx.step._default)(this); - }, - cur: function () { - if (this.elem[this.prop] != null && (!this.elem.style || this.elem.style[this.prop] == null)) return this.elem[this.prop]; - var a, - b = f.css(this.elem, this.prop); - return isNaN(a = parseFloat(b)) ? !b || b === "auto" ? 0 : b : a; - }, - custom: function (a, c, d) { - function h(a) { - return e.step(a); - } - var e = this, - g = f.fx; - this.startTime = ct || cu(), this.end = c, this.now = this.start = a, this.pos = this.state = 0, this.unit = d || this.unit || (f.cssNumber[this.prop] ? "" : "px"), h.queue = this.options.queue, h.elem = this.elem, h.saveState = function () { - e.options.hide && f._data(e.elem, "fxshow" + e.prop) === b && f._data(e.elem, "fxshow" + e.prop, e.start); - }, h() && f.timers.push(h) && !cr && (cr = setInterval(g.tick, g.interval)); - }, - show: function () { - var a = f._data(this.elem, "fxshow" + this.prop); - this.options.orig[this.prop] = a || f.style(this.elem, this.prop), this.options.show = !0, a !== b ? this.custom(this.cur(), a) : this.custom(this.prop === "width" || this.prop === "height" ? 1 : 0, this.cur()), f(this.elem).show(); - }, - hide: function () { - this.options.orig[this.prop] = f._data(this.elem, "fxshow" + this.prop) || f.style(this.elem, this.prop), this.options.hide = !0, this.custom(this.cur(), 0); - }, - step: function (a) { - var b, - c, - d, - e = ct || cu(), - g = !0, - h = this.elem, - i = this.options; - if (a || e >= i.duration + this.startTime) { - this.now = this.end, this.pos = this.state = 1, this.update(), i.animatedProperties[this.prop] = !0; - for (b in i.animatedProperties) i.animatedProperties[b] !== !0 && (g = !1); - if (g) { - i.overflow != null && !f.support.shrinkWrapBlocks && f.each(["", "X", "Y"], function (a, b) { - h.style["overflow" + b] = i.overflow[a]; - }), i.hide && f(h).hide(); - if (i.hide || i.show) for (b in i.animatedProperties) f.style(h, b, i.orig[b]), f.removeData(h, "fxshow" + b, !0), f.removeData(h, "toggle" + b, !0); - d = i.complete, d && (i.complete = !1, d.call(h)); - } - return !1; - } - i.duration == Infinity ? this.now = e : (c = e - this.startTime, this.state = c / i.duration, this.pos = f.easing[i.animatedProperties[this.prop]](this.state, c, 0, 1, i.duration), this.now = this.start + (this.end - this.start) * this.pos), this.update(); - return !0; - } - }, f.extend(f.fx, { - tick: function () { - var a, - b = f.timers, - c = 0; - for (; c < b.length; c++) a = b[c], !a() && b[c] === a && b.splice(c--, 1); - b.length || f.fx.stop(); - }, - interval: 13, - stop: function () { - clearInterval(cr), cr = null; - }, - speeds: { - slow: 600, - fast: 200, - _default: 400 - }, - step: { - opacity: function (a) { - f.style(a.elem, "opacity", a.now); - }, - _default: function (a) { - a.elem.style && a.elem.style[a.prop] != null ? a.elem.style[a.prop] = a.now + a.unit : a.elem[a.prop] = a.now; - } - } - }), f.each(["width", "height"], function (a, b) { - f.fx.step[b] = function (a) { - f.style(a.elem, b, Math.max(0, a.now)); - }; - }), f.expr && f.expr.filters && (f.expr.filters.animated = function (a) { - return f.grep(f.timers, function (b) { - return a === b.elem; - }).length; - }); - var cy = /^t(?:able|d|h)$/i, - cz = /^(?:body|html)$/i; - "getBoundingClientRect" in c.documentElement ? f.fn.offset = function (a) { - var b = this[0], - c; - if (a) return this.each(function (b) { - f.offset.setOffset(this, a, b); - }); - if (!b || !b.ownerDocument) return null; - if (b === b.ownerDocument.body) return f.offset.bodyOffset(b); - try { - c = b.getBoundingClientRect(); - } catch (d) {} - var e = b.ownerDocument, - g = e.documentElement; - if (!c || !f.contains(g, b)) return c ? { - top: c.top, - left: c.left - } : { - top: 0, - left: 0 - }; - var h = e.body, - i = cA(e), - j = g.clientTop || h.clientTop || 0, - k = g.clientLeft || h.clientLeft || 0, - l = i.pageYOffset || f.support.boxModel && g.scrollTop || h.scrollTop, - m = i.pageXOffset || f.support.boxModel && g.scrollLeft || h.scrollLeft, - n = c.top + l - j, - o = c.left + m - k; - return { - top: n, - left: o - }; - } : f.fn.offset = function (a) { - var b = this[0]; - if (a) return this.each(function (b) { - f.offset.setOffset(this, a, b); - }); - if (!b || !b.ownerDocument) return null; - if (b === b.ownerDocument.body) return f.offset.bodyOffset(b); - var c, - d = b.offsetParent, - e = b, - g = b.ownerDocument, - h = g.documentElement, - i = g.body, - j = g.defaultView, - k = j ? j.getComputedStyle(b, null) : b.currentStyle, - l = b.offsetTop, - m = b.offsetLeft; - while ((b = b.parentNode) && b !== i && b !== h) { - if (f.support.fixedPosition && k.position === "fixed") break; - c = j ? j.getComputedStyle(b, null) : b.currentStyle, l -= b.scrollTop, m -= b.scrollLeft, b === d && (l += b.offsetTop, m += b.offsetLeft, f.support.doesNotAddBorder && (!f.support.doesAddBorderForTableAndCells || !cy.test(b.nodeName)) && (l += parseFloat(c.borderTopWidth) || 0, m += parseFloat(c.borderLeftWidth) || 0), e = d, d = b.offsetParent), f.support.subtractsBorderForOverflowNotVisible && c.overflow !== "visible" && (l += parseFloat(c.borderTopWidth) || 0, m += parseFloat(c.borderLeftWidth) || 0), k = c; - } - if (k.position === "relative" || k.position === "static") l += i.offsetTop, m += i.offsetLeft; - f.support.fixedPosition && k.position === "fixed" && (l += Math.max(h.scrollTop, i.scrollTop), m += Math.max(h.scrollLeft, i.scrollLeft)); - return { - top: l, - left: m - }; - }, f.offset = { - bodyOffset: function (a) { - var b = a.offsetTop, - c = a.offsetLeft; - f.support.doesNotIncludeMarginInBodyOffset && (b += parseFloat(f.css(a, "marginTop")) || 0, c += parseFloat(f.css(a, "marginLeft")) || 0); - return { - top: b, - left: c - }; - }, - setOffset: function (a, b, c) { - var d = f.css(a, "position"); - d === "static" && (a.style.position = "relative"); - var e = f(a), - g = e.offset(), - h = f.css(a, "top"), - i = f.css(a, "left"), - j = (d === "absolute" || d === "fixed") && f.inArray("auto", [h, i]) > -1, - k = {}, - l = {}, - m, - n; - j ? (l = e.position(), m = l.top, n = l.left) : (m = parseFloat(h) || 0, n = parseFloat(i) || 0), f.isFunction(b) && (b = b.call(a, c, g)), b.top != null && (k.top = b.top - g.top + m), b.left != null && (k.left = b.left - g.left + n), "using" in b ? b.using.call(a, k) : e.css(k); - } - }, f.fn.extend({ - position: function () { - if (!this[0]) return null; - var a = this[0], - b = this.offsetParent(), - c = this.offset(), - d = cz.test(b[0].nodeName) ? { - top: 0, - left: 0 - } : b.offset(); - c.top -= parseFloat(f.css(a, "marginTop")) || 0, c.left -= parseFloat(f.css(a, "marginLeft")) || 0, d.top += parseFloat(f.css(b[0], "borderTopWidth")) || 0, d.left += parseFloat(f.css(b[0], "borderLeftWidth")) || 0; - return { - top: c.top - d.top, - left: c.left - d.left - }; - }, - offsetParent: function () { - return this.map(function () { - var a = this.offsetParent || c.body; - while (a && !cz.test(a.nodeName) && f.css(a, "position") === "static") a = a.offsetParent; - return a; - }); - } - }), f.each(["Left", "Top"], function (a, c) { - var d = "scroll" + c; - f.fn[d] = function (c) { - var e, g; - if (c === b) { - e = this[0]; - if (!e) return null; - g = cA(e); - return g ? "pageXOffset" in g ? g[a ? "pageYOffset" : "pageXOffset"] : f.support.boxModel && g.document.documentElement[d] || g.document.body[d] : e[d]; - } - return this.each(function () { - g = cA(this), g ? g.scrollTo(a ? f(g).scrollLeft() : c, a ? c : f(g).scrollTop()) : this[d] = c; - }); - }; - }), f.each(["Height", "Width"], function (a, c) { - var d = c.toLowerCase(); - f.fn["inner" + c] = function () { - var a = this[0]; - return a ? a.style ? parseFloat(f.css(a, d, "padding")) : this[d]() : null; - }, f.fn["outer" + c] = function (a) { - var b = this[0]; - return b ? b.style ? parseFloat(f.css(b, d, a ? "margin" : "border")) : this[d]() : null; - }, f.fn[d] = function (a) { - var e = this[0]; - if (!e) return a == null ? null : this; - if (f.isFunction(a)) return this.each(function (b) { - var c = f(this); - c[d](a.call(this, b, c[d]())); - }); - if (f.isWindow(e)) { - var g = e.document.documentElement["client" + c], - h = e.document.body; - return e.document.compatMode === "CSS1Compat" && g || h && h["client" + c] || g; - } - if (e.nodeType === 9) return Math.max(e.documentElement["client" + c], e.body["scroll" + c], e.documentElement["scroll" + c], e.body["offset" + c], e.documentElement["offset" + c]); - if (a === b) { - var i = f.css(e, d), - j = parseFloat(i); - return f.isNumeric(j) ? j : i; - } - return this.css(d, typeof a == "string" ? a : a + "px"); - }; - }), a.jQuery = a.$ = f; -})(window); \ No newline at end of file diff --git a/lib/static/js/modernizr.2.5.3.min.js b/lib/static/js/modernizr.2.5.3.min.js deleted file mode 100644 index 682b8ea..0000000 --- a/lib/static/js/modernizr.2.5.3.min.js +++ /dev/null @@ -1,321 +0,0 @@ -/* Modernizr 2.5.3 (Custom Build) | MIT & BSD - * Build: http://www.modernizr.com/download/#-csstransforms-csstransforms3d-shiv-cssclasses-teststyles-testprop-testallprops-prefixes-domprefixes-load - */ -; -window.Modernizr = function (a, b, c) { - function z(a) { - j.cssText = a; - } - function A(a, b) { - return z(m.join(a + ";") + (b || "")); - } - function B(a, b) { - return typeof a === b; - } - function C(a, b) { - return !!~("" + a).indexOf(b); - } - function D(a, b) { - for (var d in a) if (j[a[d]] !== c) return b == "pfx" ? a[d] : !0; - return !1; - } - function E(a, b, d) { - for (var e in a) { - var f = b[a[e]]; - if (f !== c) return d === !1 ? a[e] : B(f, "function") ? f.bind(d || b) : f; - } - return !1; - } - function F(a, b, c) { - var d = a.charAt(0).toUpperCase() + a.substr(1), - e = (a + " " + o.join(d + " ") + d).split(" "); - return B(b, "string") || B(b, "undefined") ? D(e, b) : (e = (a + " " + p.join(d + " ") + d).split(" "), E(e, b, c)); - } - var d = "2.5.3", - e = {}, - f = !0, - g = b.documentElement, - h = "modernizr", - i = b.createElement(h), - j = i.style, - k, - l = {}.toString, - m = " -webkit- -moz- -o- -ms- ".split(" "), - n = "Webkit Moz O ms", - o = n.split(" "), - p = n.toLowerCase().split(" "), - q = {}, - r = {}, - s = {}, - t = [], - u = t.slice, - v, - w = function (a, c, d, e) { - var f, - i, - j, - k = b.createElement("div"), - l = b.body, - m = l ? l : b.createElement("body"); - if (parseInt(d, 10)) while (d--) j = b.createElement("div"), j.id = e ? e[d] : h + (d + 1), k.appendChild(j); - return f = ["­", ""].join(""), k.id = h, (l ? k : m).innerHTML += f, m.appendChild(k), l || (m.style.background = "", g.appendChild(m)), i = c(k, a), l ? k.parentNode.removeChild(k) : m.parentNode.removeChild(m), !!i; - }, - x = {}.hasOwnProperty, - y; - !B(x, "undefined") && !B(x.call, "undefined") ? y = function (a, b) { - return x.call(a, b); - } : y = function (a, b) { - return b in a && B(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 = u.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(u.call(arguments))); - return Object(g) === g ? g : f; - } - return c.apply(b, d.concat(u.call(arguments))); - }; - return e; - }); - var G = function (a, c) { - var d = a.join(""), - f = c.length; - w(d, function (a, c) { - var d = b.styleSheets[b.styleSheets.length - 1], - g = d ? d.cssRules && d.cssRules[0] ? d.cssRules[0].cssText : d.cssText || "" : "", - h = a.childNodes, - i = {}; - while (f--) i[h[f].id] = h[f]; - e.csstransforms3d = (i.csstransforms3d && i.csstransforms3d.offsetLeft) === 9 && i.csstransforms3d.offsetHeight === 3; - }, f, c); - }([, ["@media (", m.join("transform-3d),("), h, ")", "{#csstransforms3d{left:9px;position:absolute;height:3px;}}"].join("")], [, "csstransforms3d"]); - q.csstransforms = function () { - return !!F("transform"); - }, q.csstransforms3d = function () { - var a = !!F("perspective"); - return a && "webkitPerspective" in g.style && (a = e.csstransforms3d), a; - }; - for (var H in q) y(q, H) && (v = H.toLowerCase(), e[v] = q[H](), t.push((e[v] ? "" : "no-") + v)); - return z(""), i = k = null, function (a, b) { - function g(a, b) { - var c = a.createElement("p"), - d = a.getElementsByTagName("head")[0] || a.documentElement; - return c.innerHTML = "x", d.insertBefore(c.lastChild, d.firstChild); - } - function h() { - var a = k.elements; - return typeof a == "string" ? a.split(" ") : a; - } - function i(a) { - var b = {}, - c = a.createElement, - e = a.createDocumentFragment, - f = e(); - a.createElement = function (a) { - var e = (b[a] || (b[a] = c(a))).cloneNode(); - return k.shivMethods && e.canHaveChildren && !d.test(a) ? f.appendChild(e) : e; - }, a.createDocumentFragment = Function("h,f", "return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&(" + h().join().replace(/\w+/g, function (a) { - return b[a] = c(a), f.createElement(a), 'c("' + a + '")'; - }) + ");return n}")(k, f); - } - function j(a) { - var b; - return a.documentShived ? a : (k.shivCSS && !e && (b = !!g(a, "article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block}audio{display:none}canvas,video{display:inline-block;*display:inline;*zoom:1}[hidden]{display:none}audio[controls]{display:inline-block;*display:inline;*zoom:1}mark{background:#FF0;color:#000}")), f || (b = !i(a)), b && (a.documentShived = b), a); - } - var c = a.html5 || {}, - d = /^<|^(?:button|form|map|select|textarea)$/i, - e, - f; - (function () { - var a = b.createElement("a"); - a.innerHTML = "", e = "hidden" in a, f = a.childNodes.length == 1 || function () { - try { - b.createElement("a"); - } catch (a) { - return !0; - } - var c = b.createDocumentFragment(); - return typeof c.cloneNode == "undefined" || typeof c.createDocumentFragment == "undefined" || typeof c.createElement == "undefined"; - }(); - })(); - var k = { - elements: c.elements || "abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup mark meter nav output progress section summary time video", - shivCSS: c.shivCSS !== !1, - shivMethods: c.shivMethods !== !1, - type: "default", - shivDocument: j - }; - a.html5 = k, j(b); - }(this, b), e._version = d, e._prefixes = m, e._domPrefixes = p, e._cssomPrefixes = o, e.testProp = function (a) { - return D([a]); - }, e.testAllProps = F, e.testStyles = w, g.className = g.className.replace(/(^|\s)no-js(\s|$)/, "$1$2") + (f ? " js " + t.join(" ") : ""), e; -}(this, this.document), function (a, b, c) { - function d(a) { - return o.call(a) == "[object Function]"; - } - function e(a) { - return typeof a == "string"; - } - function f() {} - function g(a) { - return !a || a == "loaded" || a == "complete" || a == "uninitialized"; - } - function h() { - var a = p.shift(); - q = 1, a ? a.t ? m(function () { - (a.t == "c" ? 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)) { - a != "img" && 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 = {}, - o = 0, - r = 0, - u = { - t: d, - s: c, - e: f, - a: i, - x: j - }; - y[c] === 1 && (r = 1, y[c] = [], l = b.createElement(a)), a == "object" ? 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), a != "img" && (r || y[c] === 2 ? (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(b == "c" ? v : u, a, b, this.i++, c, d, f) : (p.splice(this.i++, 0, a), p.length == 1 && 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 && o.call(a.opera) == "[object Opera]", - l = !!b.attachEvent && !l, - u = r ? "object" : l ? "script" : "img", - v = l ? "script" : u, - w = Array.isArray || function (a) { - return o.call(a) == "[object Array]"; - }, - 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, i) { - var j = b(a), - l = j.autoCallback; - j.url.split(".").pop().split("?").shift(), j.bypass || (e && (e = d(e) ? e : e[a] || e[g] || e[a.split("/").pop().split("?")[0]] || h), j.instead ? j.instead(a, e, f, g, i) : (y[j.url] ? j.noexec = !0 : y[j.url] = 1, f.load(j.url, j.forceCSS || !j.forceJS && "css" == j.url.split(".").pop().split("?").shift() ? "c" : c, j.noexec, j.attrs, j.timeout), (d(e) || d(l)) && f.load(function () { - k(), e && e(j.origUrl, i, g), l && l(j.origUrl, i, g), y[j.url] = 2; - }))); - } - function i(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 j, - l, - m = this.yepnope.loader; - if (e(a)) g(a, 0, m, 0);else if (w(a)) for (j = 0; j < a.length; j++) l = a[j], e(l) ? g(l, 0, m, 0) : w(l) ? B(l) : Object(l) === l && i(l, m);else Object(a) === a && i(a, m); - }, B.addPrefix = function (a, b) { - z[a] = b; - }, B.addFilter = function (a) { - x.push(a); - }, B.errorTimeout = 1e4, b.readyState == null && 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)); -}; \ No newline at end of file diff --git a/lib/static/js/turn.html4.min.js b/lib/static/js/turn.html4.min.js deleted file mode 100644 index bcb2008..0000000 --- a/lib/static/js/turn.html4.min.js +++ /dev/null @@ -1,1013 +0,0 @@ -/* turn.js 4.1.0 | Copyright (c) 2012 Emmanuel Garcia | turnjs.com | turnjs.com/license.txt */ - -(function (f) { - function s(a, b, c) { - if (!c[0] || "object" == typeof c[0]) return b.init.apply(a, c); - if (b[c[0]]) return b[c[0]].apply(a, Array.prototype.slice.call(c, 1)); - throw k(c[0] + " is an invalid value"); - } - function q(a, b, c, d) { - return { - css: { - position: "absolute", - top: a, - left: b, - overflow: d || "hidden", - "z-index": c || "auto" - } - }; - } - function t(a, b, c, d, e) { - var g = 1 - e, - f = g * g * g, - l = e * e * e; - return m(Math.round(f * a.x + 3 * e * g * g * b.x + 3 * e * e * g * c.x + l * d.x), Math.round(f * a.y + 3 * e * g * g * b.y + 3 * e * e * g * c.y + l * d.y)); - } - function m(a, b) { - return { - x: a, - y: b - }; - } - function j(a, b) { - return Object.prototype.hasOwnProperty.call(b, a); - } - function k(a) { - function b(a) { - this.name = "TurnJsError"; - this.message = a; - } - b.prototype = Error(); - b.prototype.constructor = b; - return new b(a); - } - function v() { - return ""; - } - var r = "", - n = { - down: "mousedown", - move: "mousemove", - up: "mouseup", - over: "mouseover", - out: "mouseout" - }, - p = { - backward: ["l"], - forward: ["r"], - all: ["l", "r"] - }, - x = ["single", "double"], - y = ["ltr", "rtl"], - z = { - acceleration: !0, - display: "double", - duration: 600, - page: 1, - gradients: !0, - when: null - }, - A = { - acceleration: !0, - corners: "forward", - cornerSize: 100, - duration: 600, - gradients: !0 - }, - i = { - init: function (a) { - if (1 < this.length) throw k("This selector has more than 1 element"); - for (var b = ["Moz", "Webkit", "Khtml", "O", "ms"], c = b.length, d = ""; c--;) b[c] + "Transform" in document.body.style && (d = "-" + b[c].toLowerCase() + "-"); - r = d; - var e, - b = 0, - g = this.data(), - c = this.children(), - a = f.extend({ - width: this.width(), - height: this.height(), - direction: this.attr("dir") || this.css("direction") || "ltr" - }, z, a); - g.opts = a; - g.pageObjs = {}; - g.pages = {}; - g.pageWrap = {}; - g.pagePlace = {}; - g.pageMv = []; - g.zoom = 1; - g.totalPages = a.pages || 0; - g.docEvents = { - mouseStart: function (a) { - for (var b in g.pages) if (j(b, g.pages) && !1 === h._eventStart.call(g.pages[b], a)) return !1; - }, - mouseMove: function (a) { - for (var b in g.pages) j(b, g.pages) && h._eventMove.call(g.pages[b], a); - }, - mouseEnd: function (a) { - for (var b in g.pages) j(b, g.pages) && h._eventEnd.call(g.pages[b], a); - } - }; - if (a.when) for (e in a.when) j(e, a.when) && this.bind(e, a.when[e]); - this.css({ - position: "relative", - width: a.width, - height: a.height - }); - this.turn("display", a.display); - "" !== a.direction && this.turn("direction", a.direction); - for (e = 0; e < c.length; e++) "1" != f(c[e]).attr("ignore") && this.turn("addPage", c[e], ++b); - f(this).bind(n.down, g.docEvents.mouseStart).bind("start", i._start).bind("end", i._end).bind("pressed", i._pressed).bind("released", i._released).bind("flip", i._flip); - f(document).bind(n.move, g.docEvents.mouseMove).bind(n.up, g.docEvents.mouseEnd); - this.turn("page", a.page); - g.done = !0; - return this; - }, - addPage: function (a, b) { - var c, - d = !1, - e = this.data(), - g = e.totalPages + 1; - if (e.destroying) return !1; - if (c = /\bp([0-9]+)\b/.exec(f(a).attr("class"))) b = parseInt(c[1], 10); - if (b) { - if (b == g) d = !0;else { - if (b > g) throw k('Page "' + b + '" cannot be inserted'); - } - } else b = g, d = !0; - 1 <= b && b <= g && (c = "double" == e.display ? b % 2 ? " odd" : " even" : "", e.done && this.turn("stop"), b in e.pageObjs && i._movePages.call(this, b, 1), d && (e.totalPages = g), e.pageObjs[b] = f(a).css({ - "float": "left" - }).addClass("page p" + b + c), i._addPage.call(this, b), e.done && this.turn("update"), i._removeFromDOM.call(this)); - return this; - }, - _addPage: function (a) { - var b = this.data(), - c = b.pageObjs[a]; - if (c) if (i._necessPage.call(this, a)) { - if (!b.pageWrap[a]) { - var d = i._pageSize.call(this, a, !0); - c.css({ - width: d.width, - height: d.height - }); - b.pagePlace[a] = a; - b.pageWrap[a] = f("
", { - "class": "turn-page-wrapper", - page: a, - css: { - position: "absolute", - overflow: "hidden" - } - }).css(d); - this.append(b.pageWrap[a]); - b.pageWrap[a].prepend(b.pageObjs[a]); - } - (!a || 1 == i._setPageLoc.call(this, a)) && i._makeFlip.call(this, a); - } else b.pagePlace[a] = 0, b.pageObjs[a] && b.pageObjs[a].remove(); - }, - hasPage: function (a) { - return j(a, this.data().pageObjs); - }, - center: function (a) { - var b = this.data(), - c = f(this).turn("size"), - d = c.width / (2 * b.zoom) - c.width / 2; - "double" == b.display && (a = this.turn("view", a || b.tpage || b.page), "ltr" == b.direction ? a[0] ? a[1] || (d += c.width / 4) : d -= c.width / 4 : a[0] ? a[1] || (d -= c.width / 4) : d += c.width / 4); - f(this).css({ - marginLeft: d - }); - return this; - }, - destroy: function () { - var a = this.data(); - a.destroying = !0; - f(this).unbind(n.down).unbind("end").unbind("first").unbind("flip").unbind("last").unbind("pressed").unbind("released").unbind("start").unbind("turning").unbind("turned").unbind("zooming"); - for (f(document).unbind(n.move, a.docEvents.mouseMove).unbind(n.up, a.docEvents.mouseEnd); 0 !== a.totalPages;) this.turn("removePage", a.totalPages); - a.fparent && a.fparent.remove(); - a.shadow && a.shadow.remove(); - this.removeData(); - return this; - }, - is: function () { - return "object" == typeof this.data().pages; - }, - zoom: function (a) { - var b = this.data(); - if ("number" == typeof a) { - if (0.0010 > a || 100 < a) throw k(a + " is not a value for zoom"); - var c = f.Event("zooming"); - this.trigger(c, [a, b.zoom]); - if (c.isDefaultPrevented()) return this; - var c = f(this).turn("size"), - d = 1 / b.zoom, - e = Math.round(c.width * d * a), - g = Math.round(c.height * d * a); - b.zoom = a; - f(this).turn("stop").turn("size", e, g).css({ - marginTop: c.height * d / 2 - g / 2 - }); - b.opts.autoCenter ? this.turn("center") : f(this).css({ - marginLeft: c.width * d / 2 - e / 2 - }); - i._updateShadow.call(this); - return this; - } - return b.zoom; - }, - _pageSize: function (a, b) { - var c = this.data(), - d = {}; - if ("single" == c.display) d.width = this.width(), d.height = this.height(), b && (d.top = 0, d.left = 0, d.right = "auto");else { - var e = this.width() / 2, - g = this.height(); - c.pageObjs[a].hasClass("own-size") ? (d.width = c.pageObjs[a].width(), d.height = c.pageObjs[a].height()) : (d.width = e, d.height = g); - if (b) { - var f = a % 2; - d.top = (g - d.height) / 2; - "ltr" == c.direction ? (d[f ? "right" : "left"] = e - d.width, d[f ? "left" : "right"] = "auto") : (d[f ? "left" : "right"] = e - d.width, d[f ? "right" : "left"] = "auto"); - } - } - return d; - }, - _makeFlip: function (a) { - var b = this.data(); - if (!b.pages[a] && b.pagePlace[a] == a) { - var c = "single" == b.display, - d = a % 2; - b.pages[a] = b.pageObjs[a].css(i._pageSize.call(this, a)).flip({ - page: a, - next: d || c ? a + 1 : a - 1, - turn: this, - duration: b.opts.duration, - acceleration: b.opts.acceleration, - gradients: b.opts.gradients - }).flip("disable", b.disabled); - } - return b.pages[a]; - }, - _makeRange: function () { - var a, b; - if (!(1 > this.data().totalPages)) { - b = this.turn("range"); - for (a = b[0]; a <= b[1]; a++) i._addPage.call(this, a); - } - }, - range: function (a) { - var b, - c, - d, - e = this.data(), - a = a || e.tpage || e.page || 1; - d = i._view.call(this, a); - if (1 > a || a > e.totalPages) throw k('"' + a + '" is not a page for range'); - d[1] = d[1] || d[0]; - 1 <= d[0] && d[1] <= e.totalPages ? (a = Math.floor(2), e.totalPages - d[1] > d[0] ? (b = Math.min(d[0] - 1, a), c = 2 * a - b) : (c = Math.min(e.totalPages - d[1], a), b = 2 * a - c)) : c = b = 5; - return [Math.max(1, d[0] - b), Math.min(e.totalPages, d[1] + c)]; - }, - _necessPage: function (a) { - if (0 === a) return !0; - var b = this.data(), - c = this.turn("range"); - return b.pageObjs[a].hasClass("fixed") || a >= c[0] && a <= c[1]; - }, - _removeFromDOM: function () { - var a, - b = this.data(); - for (a in b.pageWrap) j(a, b.pageWrap) && !i._necessPage.call(this, a) && i._removePageFromDOM.call(this, a); - }, - _removePageFromDOM: function (a) { - var b = this.data(); - if (b.pages[a]) { - var c = b.pages[a].data(); - h._moveFoldingPage.call(b.pages[a], !1); - c.f && c.f.fwrapper && c.f.fwrapper.remove(); - b.pages[a].removeData(); - b.pages[a].remove(); - delete b.pages[a]; - } - b.pageObjs[a] && b.pageObjs[a].remove(); - b.pageWrap[a] && (b.pageWrap[a].remove(), delete b.pageWrap[a]); - delete b.pagePlace[a]; - }, - removePage: function (a) { - var b = this.data(); - if (1 > a || a > b.totalPages) throw k("The page " + a + " doesn't exist"); - b.pageObjs[a] && (this.turn("stop"), i._removePageFromDOM.call(this, a), delete b.pageObjs[a]); - i._movePages.call(this, a, -1); - b.totalPages -= 1; - b.page > b.totalPages ? this.turn("page", b.totalPages) : i._makeRange.call(this); - return this; - }, - _movePages: function (a, b) { - var c, - d = this, - e = this.data(), - g = "single" == e.display, - f = function (a) { - var c = a + b, - f = c % 2, - h = f ? " odd " : " even "; - e.pageObjs[a] && (e.pageObjs[c] = e.pageObjs[a].removeClass("p" + a + " odd even").addClass("p" + c + h)); - e.pagePlace[a] && e.pageWrap[a] && (e.pagePlace[c] = c, e.pageWrap[c] = e.pageObjs[c].hasClass("fixed") ? e.pageWrap[a].attr("page", c) : e.pageWrap[a].css(i._pageSize.call(d, c, !0)).attr("page", c), e.pages[a] && (e.pages[c] = e.pages[a].flip("options", { - page: c, - next: g || f ? c + 1 : c - 1, - corners: g ? "all" : f ? "forward" : "backward" - })), b && (delete e.pages[a], delete e.pagePlace[a], delete e.pageObjs[a], delete e.pageWrap[a], delete e.pageObjs[a])); - }; - if (0 < b) for (c = e.totalPages; c >= a; c--) f(c);else for (c = a; c <= e.totalPages; c++) f(c); - }, - display: function (a) { - var b = this.data(), - c = b.display; - if (a) { - if (-1 == f.inArray(a, x)) throw k('"' + a + '" is not a value for display'); - "single" == a ? b.pageObjs[0] || (this.turn("stop").css({ - overflow: "hidden" - }), b.pageObjs[0] = f("
", { - "class": "page p-temporal" - }).css({ - width: this.width(), - height: this.height() - }).appendTo(this)) : b.pageObjs[0] && (this.turn("stop").css({ - overflow: "" - }), b.pageObjs[0].remove(), delete b.pageObjs[0]); - b.display = a; - c && (a = this.turn("size"), i._movePages.call(this, 1, 0), this.turn("size", a.width, a.height).turn("update")); - return this; - } - return c; - }, - direction: function (a) { - var b = this.data(); - if ("undefined" == typeof a) return b.direction; - a = a.toLowerCase(); - if (-1 == f.inArray(a, y)) throw k('"' + a + '" is not a value for direction'); - "rtl" == a && f(this).attr("dir", "ltr").css({ - direction: "ltr" - }); - b.direction = a; - b.done && this.turn("size", f(this).width(), f(this).height()); - return this; - }, - animating: function () { - return 0 < this.data().pageMv.length; - }, - disable: function (a) { - var b, - c = this.data(), - d = this.turn("view"); - c.disabled = void 0 === a || !0 === a; - for (b in c.pages) j(b, c.pages) && c.pages[b].flip("disable", a ? f.inArray(b, d) : !1); - return this; - }, - disabled: function (a) { - return void 0 === a ? !0 === this.data().disabled : this.turn("disable", a); - }, - size: function (a, b) { - if (a && b) { - var c, - d, - e = this.data(); - d = "double" == e.display ? a / 2 : a; - this.css({ - width: a, - height: b - }); - e.pageObjs[0] && e.pageObjs[0].css({ - width: d, - height: b - }); - for (c in e.pageWrap) j(c, e.pageWrap) && (d = i._pageSize.call(this, c, !0), e.pageObjs[c].css({ - width: d.width, - height: d.height - }), e.pageWrap[c].css(d), e.pages[c] && e.pages[c].css({ - width: d.width, - height: d.height - })); - this.turn("resize"); - return this; - } - return { - width: this.width(), - height: this.height() - }; - }, - resize: function () { - var a, - b = this.data(); - b.pages[0] && (b.pageWrap[0].css({ - left: -this.width() - }), b.pages[0].flip("resize", !0)); - for (a = 1; a <= b.totalPages; a++) b.pages[a] && b.pages[a].flip("resize", !0); - }, - _removeMv: function (a) { - var b, - c = this.data(); - for (b = 0; b < c.pageMv.length; b++) if (c.pageMv[b] == a) return c.pageMv.splice(b, 1), !0; - return !1; - }, - _addMv: function (a) { - var b = this.data(); - i._removeMv.call(this, a); - b.pageMv.push(a); - }, - _view: function (a) { - var b = this.data(), - a = a || b.page; - return "double" == b.display ? a % 2 ? [a - 1, a] : [a, a + 1] : [a]; - }, - view: function (a) { - var b = this.data(), - a = i._view.call(this, a); - return "double" == b.display ? [0 < a[0] ? a[0] : 0, a[1] <= b.totalPages ? a[1] : 0] : [0 < a[0] && a[0] <= b.totalPages ? a[0] : 0]; - }, - stop: function () { - if (this.turn("animating")) { - var a, - b, - c, - d = this.data(), - e = d.pageMv; - d.pageMv = []; - d.tpage && (d.page = d.tpage, delete d.tpage); - for (a = 0; a < e.length; a++) c = d.pages[e[a]], b = c.data().f.opts, c.flip("hideFoldedPage", !1), h._moveFoldingPage.call(c, !1), d.pagePlace[b.next] = b.next, b.force && (b.next = 0 === b.page % 2 ? b.page - 1 : b.page + 1, delete b.force); - } - this.turn("update"); - return this; - }, - pages: function (a) { - var b = this.data(); - if (a) { - if (a < b.totalPages) { - for (var c = a + 1; c <= b.totalPages; c++) this.turn("removePage", c); - this.turn("page") > a && this.turn("page", a); - } - b.totalPages = a; - return this; - } - return b.totalPages; - }, - _missing: function (a) { - for (var b = this.data(), c = this.turn("range", a), d = [], a = c[0]; a <= c[1]; a++) b.pageObjs[a] || d.push(a); - 0 < d.length && this.trigger("missing", [d]); - }, - _fitPage: function (a) { - var b = this.data(), - c = this.turn("view", a); - i._missing.call(this, a); - b.pageObjs[a] && (b.page = a, this.turn("stop"), i._removeFromDOM.call(this), i._makeRange.call(this), i._updateShadow.call(this), this.trigger("turned", [a, c]), b.opts.autoCenter && this.turn("center")); - }, - _turnPage: function (a, b) { - var c, - d, - e = this.data(), - g = e.pagePlace[a], - h = this.turn("view"), - l = this.turn("view", a); - if (e.page != a) { - var w = f.Event("turning"); - this.trigger(w, [a, l]); - if (w.isDefaultPrevented()) return; - -1 != f.inArray(1, l) && this.trigger("first"); - -1 != f.inArray(e.totalPages, l) && this.trigger("last"); - } - if (b) this.turn("stop", g);else { - i._missing.call(this, a); - if (!e.pageObjs[a]) return; - this.turn("stop"); - e.page = a; - } - i._makeRange.call(this); - "single" == e.display ? (c = h[0], d = l[0]) : h[1] && a > h[1] ? (c = h[1], d = l[0]) : h[0] && a < h[0] && (c = h[0], d = l[1]); - e.pages[c] && (g = e.pages[c].data().f.opts, e.tpage = d, g.next != d && (g.next = d, e.pagePlace[d] = g.page, g.force = !0), "single" == e.display ? "ltr" == e.direction ? e.pages[c].flip("turnPage", l[0] > h[0] ? "r" : "l") : e.pages[c].flip("turnPage", l[0] > h[0] ? "l" : "r") : e.pages[c].flip("turnPage")); - }, - page: function (a) { - var a = parseInt(a, 10), - b = this.data(); - return 0 < a && a <= b.totalPages ? (!b.done || -1 != f.inArray(a, this.turn("view")) ? i._fitPage.call(this, a) : i._turnPage.call(this, a), this) : b.page; - }, - next: function () { - return this.turn("page", i._view.call(this, this.data().page).pop() + 1); - }, - previous: function () { - return this.turn("page", i._view.call(this, this.data().page).shift() - 1); - }, - peel: function () { - return this; - }, - _addMotionPage: function () { - var a = f(this).data().f.opts, - b = a.turn, - c = b.data(); - i._addMv.call(b, a.page); - c.pagePlace[a.next] = a.page; - b.turn("update"); - }, - _start: function (a, b, c) { - var d = b.turn.data(); - a.isDefaultPrevented() || ("single" == d.display && c && ("l" == c && "ltr" == d.direction || "r" == c && "rtl" == d.direction ? (b.next = b.next < b.page ? b.next : b.page - 1, b.force = !0) : b.next = b.next > b.page ? b.next : b.page + 1), i._addMotionPage.call(a.target)); - i._updateShadow.call(b.turn); - }, - _end: function (a, b, c) { - f(a.target).data(); - var a = b.turn, - d = a.data(); - if (c || d.tpage) { - if (d.tpage == b.next || d.tpage == b.page) delete d.tpage, i._fitPage.call(a, d.tpage || b.next, !0); - } else i._removeMv.call(a, b.page), i._updateShadow.call(a), a.turn("update"); - }, - _pressed: function (a) { - a.stopPropagation(); - var b, - a = f(a.target).data().f, - c = a.opts.turn.data().pages; - for (b in c) b != a.opts.page && c[b].flip("disable", !0); - return a.time = new Date().getTime(); - }, - _released: function (a, b) { - a.stopPropagation(); - var c, - d = f(a.target), - e = d.data().f, - g = e.opts.turn, - u = g.data(); - c = "single" == u.display ? "r" == b.corner ? b.x < d.width() / 2 : b.x > d.width() / 2 : 0 > b.x || b.x > d.width(); - if (200 > new Date().getTime() - e.time || c) a.preventDefault(), i._turnPage.call(g, e.opts.next, !1 === h._cornerActivated.call(d, b, 1)); - u.mouseAction = !1; - }, - _flip: function (a) { - a.stopPropagation(); - a = f(a.target).data().f.opts; - a.turn.trigger("turn", [a.next]); - a.turn.data().opts.autoCenter && a.turn.turn("center", a.next); - }, - calculateZ: function (a) { - var b, - c, - d, - e, - g = this, - f = this.data(); - b = this.turn("view"); - var h = b[0] || b[1], - i = { - pageZ: {}, - partZ: {}, - pageV: {} - }, - j = function (a) { - a = g.turn("view", a); - a[0] && (i.pageV[a[0]] = !0); - a[1] && (i.pageV[a[1]] = !0); - }; - for (b = 0; b < a.length; b++) c = a[b], d = f.pages[c].data().f.opts.next, e = f.pagePlace[c], j(c), j(d), c = f.pagePlace[d] == d ? d : c, i.pageZ[c] = f.totalPages - Math.abs(h - c), i.partZ[e] = 2 * f.totalPages + Math.abs(h - c); - return i; - }, - update: function () { - var a, - b = this.data(); - if (b.pageMv.length && 0 !== b.pageMv[0]) { - var c, - d = this.turn("calculateZ", b.pageMv); - this.turn("view", b.tpage); - for (a in b.pageWrap) if (j(a, b.pageWrap) && (c = b.pageObjs[a].hasClass("fixed"), b.pageWrap[a].css({ - display: d.pageV[a] || c ? "" : "none", - "z-index": d.pageZ[a] || (c ? -1 : 0) - }), c = b.pages[a])) c.flip("z", d.partZ[a] || null), d.pageV[a] && c.flip("resize"), b.tpage && c.flip("disable", !0); - } else for (a in b.pageWrap) j(a, b.pageWrap) && (d = i._setPageLoc.call(this, a), b.pages[a] && b.pages[a].flip("disable", b.disabled || 1 != d).flip("z", null)); - }, - _updateShadow: function () { - var a, - b, - c = this.data(), - d = this.width(), - e = this.height(), - g = "single" == c.display ? d : d / 2; - a = this.turn("view"); - c.shadow || (c.shadow = f("
", { - "class": "shadow", - css: q(0, 0, 0).css - }).appendTo(this)); - for (var h = 0; h < c.pageMv.length && a[0] && a[1]; h++) a = this.turn("view", c.pages[c.pageMv[h]].data().f.opts.next), b = this.turn("view", c.pageMv[h]), a[0] = a[0] && b[0], a[1] = a[1] && b[1]; - switch (a[0] ? a[1] ? 3 : "ltr" == c.direction ? 2 : 1 : "ltr" == c.direction ? 1 : 2) { - case 1: - c.shadow.css({ - width: g, - height: e, - top: 0, - left: g - }); - break; - case 2: - c.shadow.css({ - width: g, - height: e, - top: 0, - left: 0 - }); - break; - case 3: - c.shadow.css({ - width: d, - height: e, - top: 0, - left: 0 - }); - } - }, - _setPageLoc: function (a) { - var b = this.data(), - c = this.turn("view"); - if (a == c[0] || a == c[1]) return b.pageWrap[a].css({ - zIndex: b.totalPages, - display: "" - }), 1; - if ("single" == b.display && a == c[0] + 1 || "double" == b.display && a == c[0] - 2 || a == c[1] + 2) return b.pageWrap[a].css({ - zIndex: b.totalPages - 1, - display: "" - }), 2; - b.pageWrap[a].css({ - zIndex: 0, - display: b.pageObjs[a].hasClass("fixed") ? "" : "none" - }); - return 0; - }, - options: function (a) { - if (void 0 === a) return this.data().opts; - var b = this.data(); - f.extend(b.opts, a); - a.pages && this.turn("pages", a.pages); - a.page && this.turn("page", a.page); - a.display && this.turn("display", a.display); - a.direction && this.turn("direction", a.direction); - a.width && a.height && this.turn("size", a.width, a.height); - if (a.when) for (var c in a.when) j(c, a.when) && this.unbind(c).bind(c, a.when[c]); - return this; - }, - version: function () { - return "4.1.0"; - } - }, - h = { - init: function (a) { - this.data({ - f: { - effect: "r" == a.corners || "l" == a.corners ? "hard" : "sheet" - } - }); - this.flip("options", a); - h._addPageWrapper.call(this); - return this; - }, - setData: function (a) { - var b = this.data(); - b.f = f.extend(b.f, a); - return this; - }, - options: function (a) { - var b = this.data().f; - return a ? (h.setData.call(this, { - opts: f.extend({}, b.opts || A, a) - }), this) : b.opts; - }, - z: function (a) { - var b = this.data().f; - b.fwrapper && (b.opts["z-index"] = a, b.fwrapper.css({ - "z-index": a || parseInt(b.parent.css("z-index"), 10) || 0 - })); - return this; - }, - _cAllowed: function () { - var a = this.data().f, - b = a.opts.turn.data(), - a = a.opts.page, - c = a % 2; - return "single" == b.display ? 1 == a ? "ltr" == b.direction ? p.forward : p.backward : a == b.totalPages ? "ltr" == b.direction ? p.backward : p.forward : p.all : "ltr" == b.direction ? p[c ? "forward" : "backward"] : p[c ? "backward" : "forward"]; - }, - _cornerActivated: function (a) { - var b = this.data().f, - c = b.parent.offset(), - d = this.width(), - e = this.height(), - a = { - x: Math.max(0, a.pageX - c.left), - y: Math.max(0, a.pageY - c.top) - }, - b = b.opts.cornerSize; - if (0 >= a.x || 0 >= a.y || a.x >= d || a.y >= e) return !1; - e = h._cAllowed.call(this); - if (a.x > d - b) a.corner = "r";else if (a.x < b) a.corner = "l";else return !1; - return -1 == f.inArray(a.corner, e) ? !1 : a; - }, - _c: function (a, b) { - b = b || 0; - switch (a) { - case "l": - return m(b, 0); - case "r": - return m(this.width() - b, 0); - } - }, - _c2: function (a) { - switch (a) { - case "l": - return m(2 * this.width(), 0); - case "r": - return m(-this.width(), 0); - } - }, - _foldingPage: function () { - var a = this.data().f, - b = a.opts; - if (a.folding) return a.folding; - if (b.turn) return a = b.turn.data(), "single" == a.display ? a.pageObjs[b.next] ? a.pageObjs[0] : null : a.pageObjs[b.next]; - }, - _backGradient: function () { - var a = this.data().f, - b = a.opts.turn; - return a.opts.gradients && (!b || "single" == b.data().display || 2 != a.opts.page && a.opts.page != b.data().totalPages - 1); - }, - resize: function (a) { - var b = this.data().f, - c = this.width(), - d = this.height(); - a && (b.wrapper.css({ - width: c, - height: d - }), b.fpage.css({ - width: c, - height: d - })); - }, - _addPageWrapper: function () { - var a = this.data().f, - b = this.parent(); - a.parent = b; - if (!a.wrapper) { - var c = {}; - a.wrapper = f("
", q(0, 0, 2)).css(c).appendTo(b).prepend(this); - a.fpage = f("
", q(0, 0, 1)).css(c).appendTo(b); - } - h.resize.call(this, !0); - }, - _fold: function (a) { - var b = this.data().f, - c = h._c.call(this, a.corner), - c = c.x ? c.x - a.x : a.x, - d = this.width(); - this.height(); - c = Math.min(2 * d, Math.max(0, c)); - switch (a.corner) { - case "r": - b.wrapper.css({ - width: Math.max(0, d - c) - }); - this.css({ - position: "relative", - left: -c - }); - b.fpage.css({ - left: -c + d, - width: Math.max(0, c - d) - }); - break; - case "l": - b.wrapper.css({ - width: d - }), this.css({ - position: "relative", - left: c - }), b.fpage.css({ - left: d, - width: Math.max(0, c - d) - }), b.folding && b.folding.css({ - position: "relative", - left: 2 * -d + c - }); - } - b.parent.css({ - overflow: "visible" - }); - b.point = a; - }, - _moveFoldingPage: function (a) { - var b = this.data().f; - if (a) { - var a = h._foldingPage.call(this), - c = b.opts.turn; - if (a) { - if (b.folding) { - if (b.folding === a) return; - h._moveFoldingPage.call(this, !1); - } - h.setData.call(this, { - backParent: a.parent(), - folding: a - }); - b.fpage.prepend(a); - } - c.turn("update"); - } else b.backParent && (b.backParent.prepend(b.folding), delete b.backParent, delete b.folding); - }, - _showFoldedPage: function (a, b) { - var c = h._foldingPage.call(this), - d = this.data(), - e = d.f, - g = e.visible; - if (!g || !e.point || e.point.corner != a.corner) { - e.opts.turn.data(); - var i = f.Event("start"); - this.trigger(i, [e.opts, a.corner]); - g = !1; - if (i.isDefaultPrevented()) return !1; - } - if (c) { - if (b) { - var l = this, - c = e.point && e.point.corner == a.corner ? e.point : h._c.call(this, a.corner, 1); - this.animatef({ - from: [c.x, c.y], - to: [a.x, a.y], - duration: 500, - frame: function (b) { - a.x = Math.round(b[0]); - a.y = Math.round(b[1]); - h._fold.call(l, a); - } - }); - } else h._fold.call(this, a), d.effect && !d.effect.turning && this.animatef(!1); - g || (e.visible = !0, h._moveFoldingPage.call(this, !0), e.fpage.show()); - return !0; - } - return !1; - }, - hide: function () { - var a = this.data().f; - h._foldingPage.call(this); - this.css({ - position: "", - left: "auto" - }); - a.wrapper.css({ - width: this.width() - }); - a.fpage.css({ - width: this.width() - }); - a.folding && a.folding.css({ - position: "", - left: "auto" - }); - a.fpage.hide(); - a.visible = !1; - return this; - }, - hideFoldedPage: function (a) { - var b = this.data().f; - if (b.point) { - var c = this, - d = b.point, - e = function () { - b.point = null; - c.flip("hide"); - c.trigger("end", [b.opts, !1]); - }; - if (a) { - var g = h._c.call(this, d.corner), - a = "t" == d.corner.substr(0, 1) ? Math.min(0, d.y - g.y) / 2 : Math.max(0, d.y - g.y) / 2, - f = m(d.x, d.y + a), - i = m(g.x, g.y - a); - this.animatef({ - from: 0, - to: 1, - frame: function (a) { - a = t(d, f, i, g, a); - d.x = a.x; - d.y = a.y; - h._fold.call(c, d); - }, - complete: e, - duration: 800, - hiding: !0 - }); - } else this.animatef(!1), e(); - } - }, - turnPage: function (a) { - var b = this, - c = this.data().f, - a = { - corner: c.corner ? c.corner.corner : a || h._cAllowed.call(this)[0] - }, - d = c.point || h._c.call(this, a.corner, c.opts.turn ? c.opts.turn.data().opts.elevation : 0), - e = h._c2.call(this, a.corner); - this.trigger("flip").animatef({ - from: 0, - to: 1, - frame: function (c) { - c = t(d, d, e, e, c); - a.x = c.x; - a.y = c.y; - h._showFoldedPage.call(b, a); - }, - complete: function () { - b.trigger("end", [c.opts, !0]); - }, - duration: c.opts.duration, - turning: !0 - }); - c.corner = null; - }, - moving: function () { - return "effect" in this.data(); - }, - isTurning: function () { - return this.flip("moving") && this.data().effect.turning; - }, - _eventStart: function (a) { - var b = this.data().f; - if (!b.disabled && !this.flip("isTurning")) { - b.corner = h._cornerActivated.call(this, a); - if (b.corner && h._foldingPage.call(this, b.corner)) return h._showFoldedPage.call(this, b.corner) && this.trigger("pressed", [b.point]), !1; - b.corner = null; - } - }, - _eventMove: function (a) { - var b = this.data().f; - if (!b.disabled) if (a = [a], b.corner) { - var c = b.parent.offset(); - b.corner.x = a[0].pageX - c.left; - b.corner.y = a[0].pageY - c.top; - h._showFoldedPage.call(this, b.corner); - } else !this.data().effect && this.is(":visible") && ((a = h._cornerActivated.call(this, a[0])) ? (b = h._c.call(this, a.corner, b.opts.cornerSize / 2), a.x = b.x, a.y = b.y, h._showFoldedPage.call(this, a, !0)) : h.hideFoldedPage.call(this, !0)); - }, - _eventEnd: function () { - var a = this.data().f; - if (!a.disabled && a.point) { - var b = f.Event("released"); - this.trigger(b, [a.point]); - b.isDefaultPrevented() || h.hideFoldedPage.call(this, !0); - } - a.corner = null; - }, - disable: function (a) { - h.setData.call(this, { - disabled: a - }); - return this; - } - }; - window.requestAnim = function (a) { - window.setTimeout(a, 1E3 / 60); - }; - f.extend(f.fn, { - flip: function (a, b) { - return s(this, h, arguments); - }, - turn: function (a) { - return s(this, i, arguments); - }, - transform: function (a, b) { - var c = {}; - b && (c[r + "transform-origin"] = b); - c[r + "transform"] = a; - return this.css(c); - }, - animatef: function (a) { - var b = this.data(); - b.effect && b.effect.stop(); - if (a) { - a.to.length || (a.to = [a.to]); - a.from.length || (a.from = [a.from]); - for (var c = [], d = a.to.length, e = !0, g = this, h = new Date().getTime(), i = function () { - if (b.effect && e) { - for (var f = [], j = Math.min(a.duration, new Date().getTime() - h), k = 0; k < d; k++) f.push(b.effect.easing(1, j, a.from[k], c[k], a.duration)); - a.frame(1 == d ? f[0] : f); - j == a.duration ? (delete b.effect, g.data(b), a.complete && a.complete()) : window.requestAnim(i); - } - }, j = 0; j < d; j++) c.push(a.to[j] - a.from[j]); - b.effect = f.extend({ - stop: function () { - e = !1; - }, - easing: function (a, b, c, d, e) { - return d * Math.sqrt(1 - (b = b / e - 1) * b) + c; - } - }, a); - this.data(b); - i(); - } else delete b.effect; - } - }); - f.isTouch = !1; - f.mouseEvents = n; - f.cssPrefix = v; - f.cssTransitionEnd = v; - f.findPos = function (a) { - var b = { - top: 0, - left: 0 - }; - do b.left += a.offsetLeft, b.top += a.offsetTop; while (a = a.offsetParent); - return b; - }; -})(jQuery); \ No newline at end of file diff --git a/lib/static/js/turn.js b/lib/static/js/turn.js deleted file mode 100644 index 6814e76..0000000 --- a/lib/static/js/turn.js +++ /dev/null @@ -1,2291 +0,0 @@ -/** - * turn.js 4th release - * turnjs.com - * turnjs.com/license.txt - * - * Copyright (C) 2012 Emmanuel Garcia - * All rights reserved - **/ - -(function ($) { - 'use strict'; - - var has3d, - hasRot, - vendor = '', - version = '4.1.0', - PI = Math.PI, - A90 = PI / 2, - isTouch = ('ontouchstart' in window), - mouseEvents = isTouch ? { - down: 'touchstart', - move: 'touchmove', - up: 'touchend', - over: 'touchstart', - out: 'touchend' - } : { - down: 'mousedown', - move: 'mousemove', - up: 'mouseup', - over: 'mouseover', - out: 'mouseout' - }, - // Contansts used for each corner - // | tl * tr | - // l | * * | r - // | bl * br | - - corners = { - backward: ['bl', 'tl'], - forward: ['br', 'tr'], - all: ['tl', 'bl', 'tr', 'br', 'l', 'r'] - }, - // Display values - - displays = ['single', 'double'], - // Direction values - - directions = ['ltr', 'rtl'], - // Default options - - turnOptions = { - // Enables hardware acceleration - - acceleration: true, - // Display - - display: 'double', - // Duration of transition in milliseconds - - duration: 600, - // First page - - page: 1, - // Enables gradients - - gradients: true, - // Corners used when turning the page - - turnCorners: 'bl,br', - // Events - - when: null - }, - flipOptions = { - // Size of the active zone of each corner - - cornerSize: 100 - }, - // Number of pages in the DOM, minimum value: 6 - - pagesInDOM = 6, - turnMethods = { - // Singleton constructor - // $('#selector').turn([options]); - - init: function (options) { - // Define constants - - has3d = 'WebKitCSSMatrix' in window || 'MozPerspective' in document.body.style; - hasRot = rotationAvailable(); - vendor = getPrefix(); - var i, - that = this, - pageNum = 0, - data = this.data(), - ch = this.children(); - - // Set initial configuration - - options = $.extend({ - width: this.width(), - height: this.height(), - direction: this.attr('dir') || this.css('direction') || 'ltr' - }, turnOptions, options); - data.opts = options; - data.pageObjs = {}; - data.pages = {}; - data.pageWrap = {}; - data.pageZoom = {}; - data.pagePlace = {}; - data.pageMv = []; - data.zoom = 1; - data.totalPages = options.pages || 0; - data.eventHandlers = { - touchStart: $.proxy(turnMethods._touchStart, this), - touchMove: $.proxy(turnMethods._touchMove, this), - touchEnd: $.proxy(turnMethods._touchEnd, this), - start: $.proxy(turnMethods._eventStart, this) - }; - - // Add event listeners - - if (options.when) for (i in options.when) if (has(i, options.when)) this.bind(i, options.when[i]); - - // Set the css - - this.css({ - position: 'relative', - width: options.width, - height: options.height - }); - - // Set the initial display - - this.turn('display', options.display); - - // Set the direction - - if (options.direction !== '') this.turn('direction', options.direction); - - // Prevent blue screen problems of switching to hardware acceleration mode - // By forcing hardware acceleration for ever - - if (has3d && !isTouch && options.acceleration) this.transform(translate(0, 0, true)); - - // Add pages from the DOM - - for (i = 0; i < ch.length; i++) { - if ($(ch[i]).attr('ignore') != '1') { - this.turn('addPage', ch[i], ++pageNum); - } - } - - // Event listeners - - $(this).bind(mouseEvents.down, data.eventHandlers.touchStart).bind('end', turnMethods._eventEnd).bind('pressed', turnMethods._eventPressed).bind('released', turnMethods._eventReleased).bind('flip', turnMethods._flip); - $(this).parent().bind('start', data.eventHandlers.start); - $(document).bind(mouseEvents.move, data.eventHandlers.touchMove).bind(mouseEvents.up, data.eventHandlers.touchEnd); - - // Set the initial page - - this.turn('page', options.page); - - // This flipbook is ready - - data.done = true; - return this; - }, - // Adds a page from external data - - addPage: function (element, page) { - var currentPage, - className, - incPages = false, - data = this.data(), - lastPage = data.totalPages + 1; - if (data.destroying) return false; - - // Read the page number from the className of `element` - format: p[0-9]+ - - if (currentPage = /\bp([0-9]+)\b/.exec($(element).attr('class'))) page = parseInt(currentPage[1], 10); - if (page) { - if (page == lastPage) incPages = true;else if (page > lastPage) throw turnError('Page "' + page + '" cannot be inserted'); - } else { - page = lastPage; - incPages = true; - } - if (page >= 1 && page <= lastPage) { - if (data.display == 'double') className = page % 2 ? ' odd' : ' even';else className = ''; - - // Stop animations - if (data.done) this.turn('stop'); - - // Move pages if it's necessary - if (page in data.pageObjs) turnMethods._movePages.call(this, page, 1); - - // Increase the number of pages - if (incPages) data.totalPages = lastPage; - - // Add element - data.pageObjs[page] = $(element).css({ - 'float': 'left' - }).addClass('page p' + page + className); - if (!hasHardPage() && data.pageObjs[page].hasClass('hard')) { - data.pageObjs[page].removeClass('hard'); - } - - // Add page - turnMethods._addPage.call(this, page); - - // Remove pages out of range - turnMethods._removeFromDOM.call(this); - } - return this; - }, - // Adds a page - - _addPage: function (page) { - var data = this.data(), - element = data.pageObjs[page]; - if (element) if (turnMethods._necessPage.call(this, page)) { - if (!data.pageWrap[page]) { - // Wrapper - data.pageWrap[page] = $('
', { - 'class': 'page-wrapper', - page: page, - css: { - position: 'absolute', - overflow: 'hidden' - } - }); - - // Append to this flipbook - this.append(data.pageWrap[page]); - if (!data.pagePlace[page]) { - data.pagePlace[page] = page; - // Move `pageObjs[page]` to wrapper - data.pageObjs[page].appendTo(data.pageWrap[page]); - } - - // Set the size of the page - var prop = turnMethods._pageSize.call(this, page, true); - element.css({ - width: prop.width, - height: prop.height - }); - data.pageWrap[page].css(prop); - } - if (data.pagePlace[page] == page) { - // If the page isn't in another place, create the flip effect - turnMethods._makeFlip.call(this, page); - } - } else { - // Place - data.pagePlace[page] = 0; - - // Remove element from the DOM - if (data.pageObjs[page]) data.pageObjs[page].remove(); - } - }, - // Checks if a page is in memory - - hasPage: function (page) { - return has(page, this.data().pageObjs); - }, - // Centers the flipbook - - center: function (page) { - var data = this.data(), - size = $(this).turn('size'), - left = 0; - if (!data.noCenter) { - if (data.display == 'double') { - var view = this.turn('view', page || data.tpage || data.page); - if (data.direction == 'ltr') { - if (!view[0]) left -= size.width / 4;else if (!view[1]) left += size.width / 4; - } else { - if (!view[0]) left += size.width / 4;else if (!view[1]) left -= size.width / 4; - } - } - $(this).css({ - marginLeft: left - }); - } - return this; - }, - // Destroys the flipbook - - destroy: function () { - var page, - flipbook = this, - data = this.data(), - events = ['end', 'first', 'flip', 'last', 'pressed', 'released', 'start', 'turning', 'turned', 'zooming', 'missing']; - if (trigger('destroying', this) == 'prevented') return; - data.destroying = true; - $.each(events, function (index, eventName) { - flipbook.unbind(eventName); - }); - this.parent().unbind('start', data.eventHandlers.start); - $(document).unbind(mouseEvents.move, data.eventHandlers.touchMove).unbind(mouseEvents.up, data.eventHandlers.touchEnd); - while (data.totalPages !== 0) { - this.turn('removePage', data.totalPages); - } - if (data.fparent) data.fparent.remove(); - if (data.shadow) data.shadow.remove(); - this.removeData(); - data = null; - return this; - }, - // Checks if this element is a flipbook - - is: function () { - return typeof this.data().pages == 'object'; - }, - // Sets and gets the zoom value - - zoom: function (newZoom) { - var data = this.data(); - if (typeof newZoom == 'number') { - if (newZoom < 0.001 || newZoom > 100) throw turnError(newZoom + ' is not a value for zoom'); - if (trigger('zooming', this, [newZoom, data.zoom]) == 'prevented') return this; - var size = this.turn('size'), - currentView = this.turn('view'), - iz = 1 / data.zoom, - newWidth = Math.round(size.width * iz * newZoom), - newHeight = Math.round(size.height * iz * newZoom); - data.zoom = newZoom; - $(this).turn('stop').turn('size', newWidth, newHeight); - /*. - css({marginTop: size.height * iz / 2 - newHeight / 2});*/ - - if (data.opts.autoCenter) this.turn('center'); - /*else - $(this).css({marginLeft: size.width * iz / 2 - newWidth / 2});*/ - - turnMethods._updateShadow.call(this); - for (var i = 0; i < currentView.length; i++) { - if (currentView[i] && data.pageZoom[currentView[i]] != data.zoom) { - this.trigger('zoomed', [currentView[i], currentView, data.pageZoom[currentView[i]], data.zoom]); - data.pageZoom[currentView[i]] = data.zoom; - } - } - return this; - } else return data.zoom; - }, - // Gets the size of a page - - _pageSize: function (page, position) { - var data = this.data(), - prop = {}; - if (data.display == 'single') { - prop.width = this.width(); - prop.height = this.height(); - if (position) { - prop.top = 0; - prop.left = 0; - prop.right = 'auto'; - } - } else { - var pageWidth = this.width() / 2, - pageHeight = this.height(); - if (data.pageObjs[page].hasClass('own-size')) { - prop.width = data.pageObjs[page].width(); - prop.height = data.pageObjs[page].height(); - } else { - prop.width = pageWidth; - prop.height = pageHeight; - } - if (position) { - var odd = page % 2; - prop.top = (pageHeight - prop.height) / 2; - if (data.direction == 'ltr') { - prop[odd ? 'right' : 'left'] = pageWidth - prop.width; - prop[odd ? 'left' : 'right'] = 'auto'; - } else { - prop[odd ? 'left' : 'right'] = pageWidth - prop.width; - prop[odd ? 'right' : 'left'] = 'auto'; - } - } - } - return prop; - }, - // Prepares the flip effect for a page - - _makeFlip: function (page) { - var data = this.data(); - if (!data.pages[page] && data.pagePlace[page] == page) { - var single = data.display == 'single', - odd = page % 2; - data.pages[page] = data.pageObjs[page].css(turnMethods._pageSize.call(this, page)).flip({ - page: page, - next: odd || single ? page + 1 : page - 1, - turn: this - }).flip('disable', data.disabled); - - // Issue about z-index - turnMethods._setPageLoc.call(this, page); - data.pageZoom[page] = data.zoom; - } - return data.pages[page]; - }, - // Makes pages within a range - - _makeRange: function () { - var page, - range, - data = this.data(); - if (data.totalPages < 1) return; - range = this.turn('range'); - for (page = range[0]; page <= range[1]; page++) turnMethods._addPage.call(this, page); - }, - // Returns a range of pages that should be in the DOM - // Example: - // - page in the current view, return true - // * page is in the range, return true - // Otherwise, return false - // - // 1 2-3 4-5 6-7 8-9 10-11 12-13 - // ** ** -- ** ** - - range: function (page) { - var remainingPages, - left, - right, - view, - data = this.data(); - page = page || data.tpage || data.page || 1; - view = turnMethods._view.call(this, page); - if (page < 1 || page > data.totalPages) throw turnError('"' + page + '" is not a valid page'); - view[1] = view[1] || view[0]; - if (view[0] >= 1 && view[1] <= data.totalPages) { - remainingPages = Math.floor((pagesInDOM - 2) / 2); - if (data.totalPages - view[1] > view[0]) { - left = Math.min(view[0] - 1, remainingPages); - right = 2 * remainingPages - left; - } else { - right = Math.min(data.totalPages - view[1], remainingPages); - left = 2 * remainingPages - right; - } - } else { - left = pagesInDOM - 1; - right = pagesInDOM - 1; - } - return [Math.max(1, view[0] - left), Math.min(data.totalPages, view[1] + right)]; - }, - // Detects if a page is within the range of `pagesInDOM` from the current view - - _necessPage: function (page) { - if (page === 0) return true; - var range = this.turn('range'); - return this.data().pageObjs[page].hasClass('fixed') || page >= range[0] && page <= range[1]; - }, - // Releases memory by removing pages from the DOM - - _removeFromDOM: function () { - var page, - data = this.data(); - for (page in data.pageWrap) if (has(page, data.pageWrap) && !turnMethods._necessPage.call(this, page)) turnMethods._removePageFromDOM.call(this, page); - }, - // Removes a page from DOM and its internal references - - _removePageFromDOM: function (page) { - var data = this.data(); - if (data.pages[page]) { - var dd = data.pages[page].data(); - flipMethods._moveFoldingPage.call(data.pages[page], false); - if (dd.f && dd.f.fwrapper) dd.f.fwrapper.remove(); - data.pages[page].removeData(); - data.pages[page].remove(); - delete data.pages[page]; - } - if (data.pageObjs[page]) data.pageObjs[page].remove(); - if (data.pageWrap[page]) { - data.pageWrap[page].remove(); - delete data.pageWrap[page]; - } - turnMethods._removeMv.call(this, page); - delete data.pagePlace[page]; - delete data.pageZoom[page]; - }, - // Removes a page - - removePage: function (page) { - var data = this.data(); - - // Delete all the pages - if (page == '*') { - while (data.totalPages !== 0) { - this.turn('removePage', data.totalPages); - } - } else { - if (page < 1 || page > data.totalPages) throw turnError('The page ' + page + ' doesn\'t exist'); - if (data.pageObjs[page]) { - // Stop animations - this.turn('stop'); - - // Remove `page` - turnMethods._removePageFromDOM.call(this, page); - delete data.pageObjs[page]; - } - - // Move the pages - turnMethods._movePages.call(this, page, -1); - - // Resize the size of this flipbook - data.totalPages = data.totalPages - 1; - - // Check the current view - - if (data.page > data.totalPages) { - data.page = null; - turnMethods._fitPage.call(this, data.totalPages); - } else { - turnMethods._makeRange.call(this); - this.turn('update'); - } - } - return this; - }, - // Moves pages - - _movePages: function (from, change) { - var page, - that = this, - data = this.data(), - single = data.display == 'single', - move = function (page) { - var next = page + change, - odd = next % 2, - className = odd ? ' odd ' : ' even '; - if (data.pageObjs[page]) data.pageObjs[next] = data.pageObjs[page].removeClass('p' + page + ' odd even').addClass('p' + next + className); - if (data.pagePlace[page] && data.pageWrap[page]) { - data.pagePlace[next] = next; - if (data.pageObjs[next].hasClass('fixed')) data.pageWrap[next] = data.pageWrap[page].attr('page', next);else data.pageWrap[next] = data.pageWrap[page].css(turnMethods._pageSize.call(that, next, true)).attr('page', next); - if (data.pages[page]) data.pages[next] = data.pages[page].flip('options', { - page: next, - next: single || odd ? next + 1 : next - 1 - }); - if (change) { - delete data.pages[page]; - delete data.pagePlace[page]; - delete data.pageZoom[page]; - delete data.pageObjs[page]; - delete data.pageWrap[page]; - } - } - }; - if (change > 0) for (page = data.totalPages; page >= from; page--) move(page);else for (page = from; page <= data.totalPages; page++) move(page); - }, - // Sets or Gets the display mode - - display: function (display) { - var data = this.data(), - currentDisplay = data.display; - if (display === undefined) { - return currentDisplay; - } else { - if ($.inArray(display, displays) == -1) throw turnError('"' + display + '" is not a value for display'); - switch (display) { - case 'single': - // Create a temporal page to use as folded page - - if (!data.pageObjs[0]) { - this.turn('stop').css({ - 'overflow': 'hidden' - }); - data.pageObjs[0] = $('
', { - 'class': 'page p-temporal' - }).css({ - width: this.width(), - height: this.height() - }).appendTo(this); - } - this.addClass('shadow'); - break; - case 'double': - // Remove the temporal page - - if (data.pageObjs[0]) { - this.turn('stop').css({ - 'overflow': '' - }); - data.pageObjs[0].remove(); - delete data.pageObjs[0]; - } - this.removeClass('shadow'); - break; - } - data.display = display; - if (currentDisplay) { - var size = this.turn('size'); - turnMethods._movePages.call(this, 1, 0); - this.turn('size', size.width, size.height).turn('update'); - } - return this; - } - }, - // Gets and sets the direction of the flipbook - - direction: function (dir) { - var data = this.data(); - if (dir === undefined) { - return data.direction; - } else { - dir = dir.toLowerCase(); - if ($.inArray(dir, directions) == -1) throw turnError('"' + dir + '" is not a value for direction'); - if (dir == 'rtl') { - $(this).attr('dir', 'ltr').css({ - direction: 'ltr' - }); - } - data.direction = dir; - if (data.done) this.turn('size', $(this).width(), $(this).height()); - return this; - } - }, - // Detects animation - - animating: function () { - return this.data().pageMv.length > 0; - }, - // Gets the current activated corner - - corner: function () { - var corner, - page, - data = this.data(); - for (page in data.pages) { - if (has(page, data.pages)) if (corner = data.pages[page].flip('corner')) { - return corner; - } - } - return false; - }, - // Gets the data stored in the flipbook - - data: function () { - return this.data(); - }, - // Disables and enables the effect - - disable: function (disable) { - var page, - data = this.data(), - view = this.turn('view'); - data.disabled = disable === undefined || disable === true; - for (page in data.pages) { - if (has(page, data.pages)) data.pages[page].flip('disable', data.disabled ? true : $.inArray(parseInt(page, 10), view) == -1); - } - return this; - }, - // Disables and enables the effect - - disabled: function (disable) { - if (disable === undefined) { - return this.data().disabled === true; - } else { - return this.turn('disable', disable); - } - }, - // Gets and sets the size - - size: function (width, height) { - if (width === undefined || height === undefined) { - return { - width: this.width(), - height: this.height() - }; - } else { - this.turn('stop'); - var page, - prop, - data = this.data(), - pageWidth = data.display == 'double' ? width / 2 : width; - this.css({ - width: width, - height: height - }); - if (data.pageObjs[0]) data.pageObjs[0].css({ - width: pageWidth, - height: height - }); - for (page in data.pageWrap) { - if (!has(page, data.pageWrap)) continue; - prop = turnMethods._pageSize.call(this, page, true); - data.pageObjs[page].css({ - width: prop.width, - height: prop.height - }); - data.pageWrap[page].css(prop); - if (data.pages[page]) data.pages[page].css({ - width: prop.width, - height: prop.height - }); - } - this.turn('resize'); - return this; - } - }, - // Resizes each page - - resize: function () { - var page, - data = this.data(); - if (data.pages[0]) { - data.pageWrap[0].css({ - left: -this.width() - }); - data.pages[0].flip('resize', true); - } - for (page = 1; page <= data.totalPages; page++) if (data.pages[page]) data.pages[page].flip('resize', true); - turnMethods._updateShadow.call(this); - if (data.opts.autoCenter) this.turn('center'); - }, - // Removes an animation from the cache - - _removeMv: function (page) { - var i, - data = this.data(); - for (i = 0; i < data.pageMv.length; i++) if (data.pageMv[i] == page) { - data.pageMv.splice(i, 1); - return true; - } - return false; - }, - // Adds an animation to the cache - - _addMv: function (page) { - var data = this.data(); - turnMethods._removeMv.call(this, page); - data.pageMv.push(page); - }, - // Gets indexes for a view - - _view: function (page) { - var data = this.data(); - page = page || data.page; - if (data.display == 'double') return page % 2 ? [page - 1, page] : [page, page + 1];else return [page]; - }, - // Gets a view - - view: function (page) { - var data = this.data(), - view = turnMethods._view.call(this, page); - if (data.display == 'double') return [view[0] > 0 ? view[0] : 0, view[1] <= data.totalPages ? view[1] : 0];else return [view[0] > 0 && view[0] <= data.totalPages ? view[0] : 0]; - }, - // Stops animations - - stop: function (ignore, animate) { - if (this.turn('animating')) { - var i, - opts, - page, - data = this.data(); - if (data.tpage) { - data.page = data.tpage; - delete data['tpage']; - } - for (i = 0; i < data.pageMv.length; i++) { - if (!data.pageMv[i] || data.pageMv[i] === ignore) continue; - page = data.pages[data.pageMv[i]]; - opts = page.data().f.opts; - page.flip('hideFoldedPage', animate); - if (!animate) flipMethods._moveFoldingPage.call(page, false); - if (opts.force) { - opts.next = opts.page % 2 === 0 ? opts.page - 1 : opts.page + 1; - delete opts['force']; - } - } - } - this.turn('update'); - return this; - }, - // Gets and sets the number of pages - - pages: function (pages) { - var data = this.data(); - if (pages) { - if (pages < data.totalPages) { - for (var page = data.totalPages; page > pages; page--) this.turn('removePage', page); - } - data.totalPages = pages; - turnMethods._fitPage.call(this, data.page); - return this; - } else return data.totalPages; - }, - // Checks missing pages - - _missing: function (page) { - var data = this.data(); - if (data.totalPages < 1) return; - var p, - range = this.turn('range', page), - missing = []; - for (p = range[0]; p <= range[1]; p++) { - if (!data.pageObjs[p]) missing.push(p); - } - if (missing.length > 0) this.trigger('missing', [missing]); - }, - // Sets a page without effect - - _fitPage: function (page) { - var data = this.data(), - newView = this.turn('view', page); - turnMethods._missing.call(this, page); - if (!data.pageObjs[page]) return; - data.page = page; - this.turn('stop'); - for (var i = 0; i < newView.length; i++) { - if (newView[i] && data.pageZoom[newView[i]] != data.zoom) { - this.trigger('zoomed', [newView[i], newView, data.pageZoom[newView[i]], data.zoom]); - data.pageZoom[newView[i]] = data.zoom; - } - } - turnMethods._removeFromDOM.call(this); - turnMethods._makeRange.call(this); - turnMethods._updateShadow.call(this); - this.trigger('turned', [page, newView]); - this.turn('update'); - if (data.opts.autoCenter) this.turn('center'); - }, - // Turns the page - - _turnPage: function (page) { - var current, - next, - data = this.data(), - place = data.pagePlace[page], - view = this.turn('view'), - newView = this.turn('view', page); - if (data.page != page) { - var currentPage = data.page; - if (trigger('turning', this, [page, newView]) == 'prevented') { - if (currentPage == data.page && $.inArray(place, data.pageMv) != -1) data.pages[place].flip('hideFoldedPage', true); - return; - } - if ($.inArray(1, newView) != -1) this.trigger('first'); - if ($.inArray(data.totalPages, newView) != -1) this.trigger('last'); - } - if (data.display == 'single') { - current = view[0]; - next = newView[0]; - } else if (view[1] && page > view[1]) { - current = view[1]; - next = newView[0]; - } else if (view[0] && page < view[0]) { - current = view[0]; - next = newView[1]; - } - var optsCorners = data.opts.turnCorners.split(','), - flipData = data.pages[current].data().f, - opts = flipData.opts, - actualPoint = flipData.point; - turnMethods._missing.call(this, page); - if (!data.pageObjs[page]) return; - this.turn('stop'); - data.page = page; - turnMethods._makeRange.call(this); - data.tpage = next; - if (opts.next != next) { - opts.next = next; - opts.force = true; - } - this.turn('update'); - flipData.point = actualPoint; - if (flipData.effect == 'hard') { - if (data.direction == 'ltr') data.pages[current].flip('turnPage', page > current ? 'r' : 'l');else data.pages[current].flip('turnPage', page > current ? 'l' : 'r'); - } else { - if (data.direction == 'ltr') data.pages[current].flip('turnPage', optsCorners[page > current ? 1 : 0]);else data.pages[current].flip('turnPage', optsCorners[page > current ? 0 : 1]); - } - }, - // Gets and sets a page - - page: function (page) { - var data = this.data(); - if (page === undefined) { - return data.page; - } else { - if (!data.disabled && !data.destroying) { - page = parseInt(page, 10); - if (page > 0 && page <= data.totalPages) { - if (page != data.page) { - if (!data.done || $.inArray(page, this.turn('view')) != -1) turnMethods._fitPage.call(this, page);else turnMethods._turnPage.call(this, page); - } - return this; - } else { - throw turnError('The page ' + page + ' does not exist'); - } - } - } - }, - // Turns to the next view - - next: function () { - return this.turn('page', Math.min(this.data().totalPages, turnMethods._view.call(this, this.data().page).pop() + 1)); - }, - // Turns to the previous view - - previous: function () { - return this.turn('page', Math.max(1, turnMethods._view.call(this, this.data().page).shift() - 1)); - }, - // Shows a peeling corner - - peel: function (corner, animate) { - var data = this.data(), - view = this.turn('view'); - animate = animate === undefined ? true : animate === true; - if (corner === false) { - this.turn('stop', null, animate); - } else { - if (data.display == 'single') { - data.pages[data.page].flip('peel', corner, animate); - } else { - var page; - if (data.direction == 'ltr') { - page = corner.indexOf('l') != -1 ? view[0] : view[1]; - } else { - page = corner.indexOf('l') != -1 ? view[1] : view[0]; - } - if (data.pages[page]) data.pages[page].flip('peel', corner, animate); - } - } - return this; - }, - // Adds a motion to the internal list - // This event is called in context of flip - - _addMotionPage: function () { - var opts = $(this).data().f.opts, - turn = opts.turn, - dd = turn.data(); - turnMethods._addMv.call(turn, opts.page); - }, - // This event is called in context of flip - - _eventStart: function (e, opts, corner) { - var data = opts.turn.data(), - actualZoom = data.pageZoom[opts.page]; - if (e.isDefaultPrevented()) { - turnMethods._updateShadow.call(opts.turn); - return; - } - if (actualZoom && actualZoom != data.zoom) { - opts.turn.trigger('zoomed', [opts.page, opts.turn.turn('view', opts.page), actualZoom, data.zoom]); - data.pageZoom[opts.page] = data.zoom; - } - if (data.display == 'single' && corner) { - if (corner.charAt(1) == 'l' && data.direction == 'ltr' || corner.charAt(1) == 'r' && data.direction == 'rtl') { - opts.next = opts.next < opts.page ? opts.next : opts.page - 1; - opts.force = true; - } else { - opts.next = opts.next > opts.page ? opts.next : opts.page + 1; - } - } - turnMethods._addMotionPage.call(e.target); - turnMethods._updateShadow.call(opts.turn); - }, - // This event is called in context of flip - - _eventEnd: function (e, opts, turned) { - var that = $(e.target), - data = that.data().f, - turn = opts.turn, - dd = turn.data(); - if (turned) { - var tpage = dd.tpage || dd.page; - if (tpage == opts.next || tpage == opts.page) { - delete dd.tpage; - turnMethods._fitPage.call(turn, tpage || opts.next, true); - } - } else { - turnMethods._removeMv.call(turn, opts.page); - turnMethods._updateShadow.call(turn); - turn.turn('update'); - } - }, - // This event is called in context of flip - - _eventPressed: function (e) { - var page, - data = $(e.target).data().f, - turn = data.opts.turn, - turnData = turn.data(), - pages = turnData.pages; - turnData.mouseAction = true; - turn.turn('update'); - return data.time = new Date().getTime(); - }, - // This event is called in context of flip - - _eventReleased: function (e, point) { - var outArea, - page = $(e.target), - data = page.data().f, - turn = data.opts.turn, - turnData = turn.data(); - if (turnData.display == 'single') { - outArea = point.corner == 'br' || point.corner == 'tr' ? point.x < page.width() / 2 : point.x > page.width() / 2; - } else { - outArea = point.x < 0 || point.x > page.width(); - } - if (new Date().getTime() - data.time < 200 || outArea) { - e.preventDefault(); - turnMethods._turnPage.call(turn, data.opts.next); - } - turnData.mouseAction = false; - }, - // This event is called in context of flip - - _flip: function (e) { - e.stopPropagation(); - var opts = $(e.target).data().f.opts; - opts.turn.trigger('turn', [opts.next]); - if (opts.turn.data().opts.autoCenter) { - opts.turn.turn('center', opts.next); - } - }, - // - _touchStart: function () { - var data = this.data(); - for (var page in data.pages) { - if (has(page, data.pages) && flipMethods._eventStart.apply(data.pages[page], arguments) === false) { - return false; - } - } - }, - // - _touchMove: function () { - var data = this.data(); - for (var page in data.pages) { - if (has(page, data.pages)) { - flipMethods._eventMove.apply(data.pages[page], arguments); - } - } - }, - // - _touchEnd: function () { - var data = this.data(); - for (var page in data.pages) { - if (has(page, data.pages)) { - flipMethods._eventEnd.apply(data.pages[page], arguments); - } - } - }, - // Calculate the z-index value for pages during the animation - - calculateZ: function (mv) { - var i, - page, - nextPage, - placePage, - dpage, - that = this, - data = this.data(), - view = this.turn('view'), - currentPage = view[0] || view[1], - total = mv.length - 1, - r = { - pageZ: {}, - partZ: {}, - pageV: {} - }, - addView = function (page) { - var view = that.turn('view', page); - if (view[0]) r.pageV[view[0]] = true; - if (view[1]) r.pageV[view[1]] = true; - }; - for (i = 0; i <= total; i++) { - page = mv[i]; - nextPage = data.pages[page].data().f.opts.next; - placePage = data.pagePlace[page]; - addView(page); - addView(nextPage); - dpage = data.pagePlace[nextPage] == nextPage ? nextPage : page; - r.pageZ[dpage] = data.totalPages - Math.abs(currentPage - dpage); - r.partZ[placePage] = data.totalPages * 2 - total + i; - } - return r; - }, - // Updates the z-index and display property of every page - - update: function () { - var page, - data = this.data(); - if (this.turn('animating') && data.pageMv[0] !== 0) { - // Update motion - - var p, - apage, - fixed, - pos = this.turn('calculateZ', data.pageMv), - corner = this.turn('corner'), - actualView = this.turn('view'), - newView = this.turn('view', data.tpage); - for (page in data.pageWrap) { - if (!has(page, data.pageWrap)) continue; - fixed = data.pageObjs[page].hasClass('fixed'); - data.pageWrap[page].css({ - display: pos.pageV[page] || fixed ? '' : 'none', - zIndex: (data.pageObjs[page].hasClass('hard') ? pos.partZ[page] : pos.pageZ[page]) || (fixed ? -1 : 0) - }); - if (p = data.pages[page]) { - p.flip('z', pos.partZ[page] || null); - if (pos.pageV[page]) p.flip('resize'); - if (data.tpage) { - // Is it turning the page to `tpage`? - - p.flip('hover', false).flip('disable', $.inArray(parseInt(page, 10), data.pageMv) == -1 && page != newView[0] && page != newView[1]); - } else { - p.flip('hover', corner === false).flip('disable', page != actualView[0] && page != actualView[1]); - } - } - } - } else { - // Update static pages - - for (page in data.pageWrap) { - if (!has(page, data.pageWrap)) continue; - var pageLocation = turnMethods._setPageLoc.call(this, page); - if (data.pages[page]) { - data.pages[page].flip('disable', data.disabled || pageLocation != 1).flip('hover', true).flip('z', null); - } - } - } - return this; - }, - // Updates the position and size of the flipbook's shadow - - _updateShadow: function () { - var view, - view2, - shadow, - data = this.data(), - width = this.width(), - height = this.height(), - pageWidth = data.display == 'single' ? width : width / 2; - view = this.turn('view'); - if (!data.shadow) { - data.shadow = $('
', { - 'class': 'shadow', - 'css': divAtt(0, 0, 0).css - }).appendTo(this); - } - for (var i = 0; i < data.pageMv.length; i++) { - if (!view[0] || !view[1]) break; - view = this.turn('view', data.pages[data.pageMv[i]].data().f.opts.next); - view2 = this.turn('view', data.pageMv[i]); - view[0] = view[0] && view2[0]; - view[1] = view[1] && view2[1]; - } - if (!view[0]) shadow = data.direction == 'ltr' ? 1 : 2;else if (!view[1]) shadow = data.direction == 'ltr' ? 2 : 1;else shadow = 3; - switch (shadow) { - case 1: - data.shadow.css({ - width: pageWidth, - height: height, - top: 0, - left: pageWidth - }); - break; - case 2: - data.shadow.css({ - width: pageWidth, - height: height, - top: 0, - left: 0 - }); - break; - case 3: - data.shadow.css({ - width: width, - height: height, - top: 0, - left: 0 - }); - break; - } - }, - // Sets the z-index and display property of a page - // It depends on the current view - - _setPageLoc: function (page) { - var data = this.data(), - view = this.turn('view'), - loc = 0; - if (page == view[0] || page == view[1]) loc = 1;else if (data.display == 'single' && page == view[0] + 1 || data.display == 'double' && page == view[0] - 2 || page == view[1] + 2) loc = 2; - if (!this.turn('animating')) switch (loc) { - case 1: - data.pageWrap[page].css({ - zIndex: data.totalPages, - display: '' - }); - break; - case 2: - data.pageWrap[page].css({ - zIndex: data.totalPages - 1, - display: '' - }); - break; - case 0: - data.pageWrap[page].css({ - zIndex: 0, - display: data.pageObjs[page].hasClass('fixed') ? '' : 'none' - }); - break; - } - return loc; - }, - // Gets and sets the options - - options: function (options) { - if (options === undefined) { - return this.data().opts; - } else { - var data = this.data(); - - // Set new values - - $.extend(data.opts, options); - - // Set pages - - if (options.pages) this.turn('pages', options.pages); - - // Set page - - if (options.page) this.turn('page', options.page); - - // Set display - - if (options.display) this.turn('display', options.display); - - // Set direction - - if (options.direction) this.turn('direction', options.direction); - - // Set size - - if (options.width && options.height) this.turn('size', options.width, options.height); - - // Add event listeners - - if (options.when) for (var eventName in options.when) if (has(eventName, options.when)) { - this.unbind(eventName).bind(eventName, options.when[eventName]); - } - return this; - } - }, - // Gets the current version - - version: function () { - return version; - } - }, - // Methods and properties for the flip page effect - - flipMethods = { - // Constructor - - init: function (opts) { - this.data({ - f: { - disabled: false, - hover: false, - effect: this.hasClass('hard') ? 'hard' : 'sheet' - } - }); - this.flip('options', opts); - flipMethods._addPageWrapper.call(this); - return this; - }, - setData: function (d) { - var data = this.data(); - data.f = $.extend(data.f, d); - return this; - }, - options: function (opts) { - var data = this.data().f; - if (opts) { - flipMethods.setData.call(this, { - opts: $.extend({}, data.opts || flipOptions, opts) - }); - return this; - } else return data.opts; - }, - z: function (z) { - var data = this.data().f; - data.opts['z-index'] = z; - if (data.fwrapper) data.fwrapper.css({ - zIndex: z || parseInt(data.parent.css('z-index'), 10) || 0 - }); - return this; - }, - _cAllowed: function () { - var data = this.data().f, - page = data.opts.page, - turnData = data.opts.turn.data(), - odd = page % 2; - if (data.effect == 'hard') { - return turnData.direction == 'ltr' ? [odd ? 'r' : 'l'] : [odd ? 'l' : 'r']; - } else { - if (turnData.display == 'single') { - if (page == 1) return turnData.direction == 'ltr' ? corners['forward'] : corners['backward'];else if (page == turnData.totalPages) return turnData.direction == 'ltr' ? corners['backward'] : corners['forward'];else return corners['all']; - } else { - return turnData.direction == 'ltr' ? corners[odd ? 'forward' : 'backward'] : corners[odd ? 'backward' : 'forward']; - } - } - }, - _cornerActivated: function (p) { - var data = this.data().f, - width = this.width(), - height = this.height(), - point = { - x: p.x, - y: p.y, - corner: '' - }, - csz = data.opts.cornerSize; - if (point.x <= 0 || point.y <= 0 || point.x >= width || point.y >= height) return false; - var allowedCorners = flipMethods._cAllowed.call(this); - switch (data.effect) { - case 'hard': - if (point.x > width - csz) point.corner = 'r';else if (point.x < csz) point.corner = 'l';else return false; - break; - case 'sheet': - if (point.y < csz) point.corner += 't';else if (point.y >= height - csz) point.corner += 'b';else return false; - if (point.x <= csz) point.corner += 'l';else if (point.x >= width - csz) point.corner += 'r';else return false; - break; - } - return !point.corner || $.inArray(point.corner, allowedCorners) == -1 ? false : point; - }, - _isIArea: function (e) { - var pos = this.data().f.parent.offset(); - e = isTouch && e.originalEvent ? e.originalEvent.touches[0] : e; - return flipMethods._cornerActivated.call(this, { - x: e.pageX - pos.left, - y: e.pageY - pos.top - }); - }, - _c: function (corner, opts) { - opts = opts || 0; - switch (corner) { - case 'tl': - return point2D(opts, opts); - case 'tr': - return point2D(this.width() - opts, opts); - case 'bl': - return point2D(opts, this.height() - opts); - case 'br': - return point2D(this.width() - opts, this.height() - opts); - case 'l': - return point2D(opts, 0); - case 'r': - return point2D(this.width() - opts, 0); - } - }, - _c2: function (corner) { - switch (corner) { - case 'tl': - return point2D(this.width() * 2, 0); - case 'tr': - return point2D(-this.width(), 0); - case 'bl': - return point2D(this.width() * 2, this.height()); - case 'br': - return point2D(-this.width(), this.height()); - case 'l': - return point2D(this.width() * 2, 0); - case 'r': - return point2D(-this.width(), 0); - } - }, - _foldingPage: function () { - var data = this.data().f; - if (!data) return; - var opts = data.opts; - if (opts.turn) { - data = opts.turn.data(); - if (data.display == 'single') return opts.next > 1 || opts.page > 1 ? data.pageObjs[0] : null;else return data.pageObjs[opts.next]; - } - }, - _backGradient: function () { - var data = this.data().f, - turnData = data.opts.turn.data(), - gradient = turnData.opts.gradients && (turnData.display == 'single' || data.opts.page != 2 && data.opts.page != turnData.totalPages - 1); - if (gradient && !data.bshadow) data.bshadow = $('
', divAtt(0, 0, 1)).css({ - 'position': '', - width: this.width(), - height: this.height() - }).appendTo(data.parent); - return gradient; - }, - type: function () { - return this.data().f.effect; - }, - resize: function (full) { - var data = this.data().f, - turnData = data.opts.turn.data(), - width = this.width(), - height = this.height(); - switch (data.effect) { - case 'hard': - if (full) { - data.wrapper.css({ - width: width, - height: height - }); - data.fpage.css({ - width: width, - height: height - }); - if (turnData.opts.gradients) { - data.ashadow.css({ - width: width, - height: height - }); - data.bshadow.css({ - width: width, - height: height - }); - } - } - break; - case 'sheet': - if (full) { - var size = Math.round(Math.sqrt(Math.pow(width, 2) + Math.pow(height, 2))); - data.wrapper.css({ - width: size, - height: size - }); - data.fwrapper.css({ - width: size, - height: size - }).children(':first-child').css({ - width: width, - height: height - }); - data.fpage.css({ - width: width, - height: height - }); - if (turnData.opts.gradients) data.ashadow.css({ - width: width, - height: height - }); - if (flipMethods._backGradient.call(this)) data.bshadow.css({ - width: width, - height: height - }); - } - if (data.parent.is(':visible')) { - var offset = findPos(data.parent[0]); - data.fwrapper.css({ - top: offset.top, - left: offset.left - }); - - //if (data.opts.turn) { - offset = findPos(data.opts.turn[0]); - data.fparent.css({ - top: -offset.top, - left: -offset.left - }); - //} - } - - this.flip('z', data.opts['z-index']); - break; - } - }, - // Prepares the page by adding a general wrapper and another objects - - _addPageWrapper: function () { - var att, - data = this.data().f, - turnData = data.opts.turn.data(), - parent = this.parent(); - data.parent = parent; - if (!data.wrapper) switch (data.effect) { - case 'hard': - var cssProperties = {}; - cssProperties[vendor + 'transform-style'] = 'preserve-3d'; - cssProperties[vendor + 'backface-visibility'] = 'hidden'; - data.wrapper = $('
', divAtt(0, 0, 2)).css(cssProperties).appendTo(parent).prepend(this); - data.fpage = $('
', divAtt(0, 0, 1)).css(cssProperties).appendTo(parent); - if (turnData.opts.gradients) { - data.ashadow = $('
', divAtt(0, 0, 0)).hide().appendTo(parent); - data.bshadow = $('
', divAtt(0, 0, 0)); - } - break; - case 'sheet': - var width = this.width(), - height = this.height(), - size = Math.round(Math.sqrt(Math.pow(width, 2) + Math.pow(height, 2))); - data.fparent = data.opts.turn.data().fparent; - if (!data.fparent) { - var fparent = $('
', { - css: { - 'pointer-events': 'none' - } - }).hide(); - fparent.data().flips = 0; - fparent.css(divAtt(0, 0, 'auto', 'visible').css).appendTo(data.opts.turn); - data.opts.turn.data().fparent = fparent; - data.fparent = fparent; - } - this.css({ - position: 'absolute', - top: 0, - left: 0, - bottom: 'auto', - right: 'auto' - }); - data.wrapper = $('
', divAtt(0, 0, this.css('z-index'))).appendTo(parent).prepend(this); - data.fwrapper = $('
', divAtt(parent.offset().top, parent.offset().left)).hide().appendTo(data.fparent); - data.fpage = $('
', divAtt(0, 0, 0, 'visible')).css({ - cursor: 'default' - }).appendTo(data.fwrapper); - if (turnData.opts.gradients) data.ashadow = $('
', divAtt(0, 0, 1)).appendTo(data.fpage); - flipMethods.setData.call(this, data); - break; - } - - // Set size - flipMethods.resize.call(this, true); - }, - // Takes a 2P point from the screen and applies the transformation - - _fold: function (point) { - var data = this.data().f, - turnData = data.opts.turn.data(), - o = flipMethods._c.call(this, point.corner), - width = this.width(), - height = this.height(); - switch (data.effect) { - case 'hard': - if (point.corner == 'l') point.x = Math.min(Math.max(point.x, 0), width * 2);else point.x = Math.max(Math.min(point.x, width), -width); - var leftPos, - shadow, - gradientX, - fpageOrigin, - parentOrigin, - totalPages = turnData.totalPages, - zIndex = data.opts['z-index'] || totalPages, - parentCss = { - 'overflow': 'visible' - }, - relX = o.x ? (o.x - point.x) / width : point.x / width, - angle = relX * 90, - half = angle < 90; - switch (point.corner) { - case 'l': - fpageOrigin = '0% 50%'; - parentOrigin = '100% 50%'; - if (half) { - leftPos = 0; - shadow = data.opts.next - 1 > 0; - gradientX = 1; - } else { - leftPos = '100%'; - shadow = data.opts.page + 1 < totalPages; - gradientX = 0; - } - break; - case 'r': - fpageOrigin = '100% 50%'; - parentOrigin = '0% 50%'; - angle = -angle; - width = -width; - if (half) { - leftPos = 0; - shadow = data.opts.next + 1 < totalPages; - gradientX = 0; - } else { - leftPos = '-100%'; - shadow = data.opts.page != 1; - gradientX = 1; - } - break; - } - parentCss[vendor + 'perspective-origin'] = parentOrigin; - data.wrapper.transform('rotateY(' + angle + 'deg)' + 'translate3d(0px, 0px, ' + (this.attr('depth') || 0) + 'px)', parentOrigin); - data.fpage.transform('translateX(' + width + 'px) rotateY(' + (180 + angle) + 'deg)', fpageOrigin); - data.parent.css(parentCss); - if (half) { - relX = -relX + 1; - data.wrapper.css({ - zIndex: zIndex + 1 - }); - data.fpage.css({ - zIndex: zIndex - }); - } else { - relX = relX - 1; - data.wrapper.css({ - zIndex: zIndex - }); - data.fpage.css({ - zIndex: zIndex + 1 - }); - } - if (turnData.opts.gradients) { - if (shadow) data.ashadow.css({ - display: '', - left: leftPos, - backgroundColor: 'rgba(0,0,0,' + 0.5 * relX + ')' - }).transform('rotateY(0deg)');else data.ashadow.hide(); - data.bshadow.css({ - opacity: -relX + 1 - }); - if (half) { - if (data.bshadow.parent()[0] != data.wrapper[0]) { - data.bshadow.appendTo(data.wrapper); - } - } else { - if (data.bshadow.parent()[0] != data.fpage[0]) { - data.bshadow.appendTo(data.fpage); - } - } - /*data.bshadow.css({ - backgroundColor: 'rgba(0,0,0,'+(0.1)+')' - })*/ - gradient(data.bshadow, point2D(gradientX * 100, 0), point2D((-gradientX + 1) * 100, 0), [[0, 'rgba(0,0,0,0.3)'], [1, 'rgba(0,0,0,0)']], 2); - } - break; - case 'sheet': - var that = this, - a = 0, - alpha = 0, - beta, - px, - gradientEndPointA, - gradientEndPointB, - gradientStartVal, - gradientSize, - gradientOpacity, - shadowVal, - mv = point2D(0, 0), - df = point2D(0, 0), - tr = point2D(0, 0), - folding = flipMethods._foldingPage.call(this), - tan = Math.tan(alpha), - ac = turnData.opts.acceleration, - h = data.wrapper.height(), - top = point.corner.substr(0, 1) == 't', - left = point.corner.substr(1, 1) == 'l', - compute = function () { - var rel = point2D(0, 0); - var middle = point2D(0, 0); - rel.x = o.x ? o.x - point.x : point.x; - if (!hasRot) { - rel.y = 0; - } else { - rel.y = o.y ? o.y - point.y : point.y; - } - middle.x = left ? width - rel.x / 2 : point.x + rel.x / 2; - middle.y = rel.y / 2; - var alpha = A90 - Math.atan2(rel.y, rel.x), - gamma = alpha - Math.atan2(middle.y, middle.x), - distance = Math.max(0, Math.sin(gamma) * Math.sqrt(Math.pow(middle.x, 2) + Math.pow(middle.y, 2))); - a = deg(alpha); - tr = point2D(distance * Math.sin(alpha), distance * Math.cos(alpha)); - if (alpha > A90) { - tr.x = tr.x + Math.abs(tr.y * rel.y / rel.x); - tr.y = 0; - if (Math.round(tr.x * Math.tan(PI - alpha)) < height) { - point.y = Math.sqrt(Math.pow(height, 2) + 2 * middle.x * rel.x); - if (top) point.y = height - point.y; - return compute(); - } - } - if (alpha > A90) { - var beta = PI - alpha, - dd = h - height / Math.sin(beta); - mv = point2D(Math.round(dd * Math.cos(beta)), Math.round(dd * Math.sin(beta))); - if (left) mv.x = -mv.x; - if (top) mv.y = -mv.y; - } - px = Math.round(tr.y / Math.tan(alpha) + tr.x); - var side = width - px, - sideX = side * Math.cos(alpha * 2), - sideY = side * Math.sin(alpha * 2); - df = point2D(Math.round(left ? side - sideX : px + sideX), Math.round(top ? sideY : height - sideY)); - - // Gradients - if (turnData.opts.gradients) { - gradientSize = side * Math.sin(alpha); - var endingPoint = flipMethods._c2.call(that, point.corner), - far = Math.sqrt(Math.pow(endingPoint.x - point.x, 2) + Math.pow(endingPoint.y - point.y, 2)) / width; - shadowVal = Math.sin(A90 * (far > 1 ? 2 - far : far)); - gradientOpacity = Math.min(far, 1); - gradientStartVal = gradientSize > 100 ? (gradientSize - 100) / gradientSize : 0; - gradientEndPointA = point2D(gradientSize * Math.sin(alpha) / width * 100, gradientSize * Math.cos(alpha) / height * 100); - if (flipMethods._backGradient.call(that)) { - gradientEndPointB = point2D(gradientSize * 1.2 * Math.sin(alpha) / width * 100, gradientSize * 1.2 * Math.cos(alpha) / height * 100); - if (!left) gradientEndPointB.x = 100 - gradientEndPointB.x; - if (!top) gradientEndPointB.y = 100 - gradientEndPointB.y; - } - } - tr.x = Math.round(tr.x); - tr.y = Math.round(tr.y); - return true; - }, - transform = function (tr, c, x, a) { - var f = ['0', 'auto'], - mvW = (width - h) * x[0] / 100, - mvH = (height - h) * x[1] / 100, - cssA = { - left: f[c[0]], - top: f[c[1]], - right: f[c[2]], - bottom: f[c[3]] - }, - cssB = {}, - aliasingFk = a != 90 && a != -90 ? left ? -1 : 1 : 0, - origin = x[0] + '% ' + x[1] + '%'; - that.css(cssA).transform(rotate(a) + translate(tr.x + aliasingFk, tr.y, ac), origin); - data.fpage.css(cssA).transform(rotate(a) + translate(tr.x + df.x - mv.x - width * x[0] / 100, tr.y + df.y - mv.y - height * x[1] / 100, ac) + rotate((180 / a - 2) * a), origin); - data.wrapper.transform(translate(-tr.x + mvW - aliasingFk, -tr.y + mvH, ac) + rotate(-a), origin); - data.fwrapper.transform(translate(-tr.x + mv.x + mvW, -tr.y + mv.y + mvH, ac) + rotate(-a), origin); - if (turnData.opts.gradients) { - if (x[0]) gradientEndPointA.x = 100 - gradientEndPointA.x; - if (x[1]) gradientEndPointA.y = 100 - gradientEndPointA.y; - cssB['box-shadow'] = '0 0 20px rgba(0,0,0,' + 0.5 * shadowVal + ')'; - folding.css(cssB); - gradient(data.ashadow, point2D(left ? 100 : 0, top ? 0 : 100), point2D(gradientEndPointA.x, gradientEndPointA.y), [[gradientStartVal, 'rgba(0,0,0,0)'], [(1 - gradientStartVal) * 0.8 + gradientStartVal, 'rgba(0,0,0,' + 0.2 * gradientOpacity + ')'], [1, 'rgba(255,255,255,' + 0.2 * gradientOpacity + ')']], 3, alpha); - if (flipMethods._backGradient.call(that)) gradient(data.bshadow, point2D(left ? 0 : 100, top ? 0 : 100), point2D(gradientEndPointB.x, gradientEndPointB.y), [[0.6, 'rgba(0,0,0,0)'], [0.8, 'rgba(0,0,0,' + 0.3 * gradientOpacity + ')'], [1, 'rgba(0,0,0,0)']], 3); - } - }; - switch (point.corner) { - case 'l': - break; - case 'r': - break; - case 'tl': - point.x = Math.max(point.x, 1); - compute(); - transform(tr, [1, 0, 0, 1], [100, 0], a); - break; - case 'tr': - point.x = Math.min(point.x, width - 1); - compute(); - transform(point2D(-tr.x, tr.y), [0, 0, 0, 1], [0, 0], -a); - break; - case 'bl': - point.x = Math.max(point.x, 1); - compute(); - transform(point2D(tr.x, -tr.y), [1, 1, 0, 0], [100, 100], -a); - break; - case 'br': - point.x = Math.min(point.x, width - 1); - compute(); - transform(point2D(-tr.x, -tr.y), [0, 1, 1, 0], [0, 100], a); - break; - } - break; - } - data.point = point; - }, - _moveFoldingPage: function (move) { - var data = this.data().f; - if (!data) return; - var turn = data.opts.turn, - turnData = turn.data(), - place = turnData.pagePlace; - if (move) { - var nextPage = data.opts.next; - if (place[nextPage] != data.opts.page) { - if (data.folding) flipMethods._moveFoldingPage.call(this, false); - var folding = flipMethods._foldingPage.call(this); - folding.appendTo(data.fpage); - place[nextPage] = data.opts.page; - data.folding = nextPage; - } - turn.turn('update'); - } else { - if (data.folding) { - if (turnData.pages[data.folding]) { - // If we have flip available - - var flipData = turnData.pages[data.folding].data().f; - turnData.pageObjs[data.folding].appendTo(flipData.wrapper); - } else if (turnData.pageWrap[data.folding]) { - // If we have the pageWrapper - - turnData.pageObjs[data.folding].appendTo(turnData.pageWrap[data.folding]); - } - if (data.folding in place) { - place[data.folding] = data.folding; - } - delete data.folding; - } - } - }, - _showFoldedPage: function (c, animate) { - var folding = flipMethods._foldingPage.call(this), - dd = this.data(), - data = dd.f, - visible = data.visible; - if (folding) { - if (!visible || !data.point || data.point.corner != c.corner) { - var corner = data.status == 'hover' || data.status == 'peel' || data.opts.turn.data().mouseAction ? c.corner : null; - visible = false; - if (trigger('start', this, [data.opts, corner]) == 'prevented') return false; - } - if (animate) { - var that = this, - point = data.point && data.point.corner == c.corner ? data.point : flipMethods._c.call(this, c.corner, 1); - this.animatef({ - from: [point.x, point.y], - to: [c.x, c.y], - duration: 500, - frame: function (v) { - c.x = Math.round(v[0]); - c.y = Math.round(v[1]); - flipMethods._fold.call(that, c); - } - }); - } else { - flipMethods._fold.call(this, c); - if (dd.effect && !dd.effect.turning) this.animatef(false); - } - if (!visible) { - switch (data.effect) { - case 'hard': - data.visible = true; - flipMethods._moveFoldingPage.call(this, true); - data.fpage.show(); - if (data.opts.shadows) data.bshadow.show(); - break; - case 'sheet': - data.visible = true; - data.fparent.show().data().flips++; - flipMethods._moveFoldingPage.call(this, true); - data.fwrapper.show(); - if (data.bshadow) data.bshadow.show(); - break; - } - } - return true; - } - return false; - }, - hide: function () { - var data = this.data().f, - turnData = data.opts.turn.data(), - folding = flipMethods._foldingPage.call(this); - switch (data.effect) { - case 'hard': - if (turnData.opts.gradients) { - data.bshadowLoc = 0; - data.bshadow.remove(); - data.ashadow.hide(); - } - data.wrapper.transform(''); - data.fpage.hide(); - break; - case 'sheet': - if (--data.fparent.data().flips === 0) data.fparent.hide(); - this.css({ - left: 0, - top: 0, - right: 'auto', - bottom: 'auto' - }).transform(''); - data.wrapper.transform(''); - data.fwrapper.hide(); - if (data.bshadow) data.bshadow.hide(); - folding.transform(''); - break; - } - data.visible = false; - return this; - }, - hideFoldedPage: function (animate) { - var data = this.data().f; - if (!data.point) return; - var that = this, - p1 = data.point, - hide = function () { - data.point = null; - data.status = ''; - that.flip('hide'); - that.trigger('end', [data.opts, false]); - }; - if (animate) { - var p4 = flipMethods._c.call(this, p1.corner), - top = p1.corner.substr(0, 1) == 't', - delta = top ? Math.min(0, p1.y - p4.y) / 2 : Math.max(0, p1.y - p4.y) / 2, - p2 = point2D(p1.x, p1.y + delta), - p3 = point2D(p4.x, p4.y - delta); - this.animatef({ - from: 0, - to: 1, - frame: function (v) { - var np = bezier(p1, p2, p3, p4, v); - p1.x = np.x; - p1.y = np.y; - flipMethods._fold.call(that, p1); - }, - complete: hide, - duration: 800, - hiding: true - }); - } else { - this.animatef(false); - hide(); - } - }, - turnPage: function (corner) { - var that = this, - data = this.data().f, - turnData = data.opts.turn.data(); - corner = { - corner: data.corner ? data.corner.corner : corner || flipMethods._cAllowed.call(this)[0] - }; - var p1 = data.point || flipMethods._c.call(this, corner.corner, data.opts.turn ? turnData.opts.elevation : 0), - p4 = flipMethods._c2.call(this, corner.corner); - this.trigger('flip').animatef({ - from: 0, - to: 1, - frame: function (v) { - var np = bezier(p1, p1, p4, p4, v); - corner.x = np.x; - corner.y = np.y; - flipMethods._showFoldedPage.call(that, corner); - }, - complete: function () { - that.trigger('end', [data.opts, true]); - }, - duration: turnData.opts.duration, - turning: true - }); - data.corner = null; - }, - moving: function () { - return 'effect' in this.data(); - }, - isTurning: function () { - return this.flip('moving') && this.data().effect.turning; - }, - corner: function () { - return this.data().f.corner; - }, - _eventStart: function (e) { - var data = this.data().f, - turn = data.opts.turn; - if (!data.corner && !data.disabled && !this.flip('isTurning') && data.opts.page == turn.data().pagePlace[data.opts.page]) { - data.corner = flipMethods._isIArea.call(this, e); - if (data.corner && flipMethods._foldingPage.call(this)) { - this.trigger('pressed', [data.point]); - flipMethods._showFoldedPage.call(this, data.corner); - return false; - } else data.corner = null; - } - }, - _eventMove: function (e) { - var data = this.data().f; - if (!data.disabled) { - e = isTouch ? e.originalEvent.touches : [e]; - if (data.corner) { - var pos = data.parent.offset(); - data.corner.x = e[0].pageX - pos.left; - data.corner.y = e[0].pageY - pos.top; - flipMethods._showFoldedPage.call(this, data.corner); - } else if (data.hover && !this.data().effect && this.is(':visible')) { - var point = flipMethods._isIArea.call(this, e[0]); - if (point) { - if (data.effect == 'sheet' && point.corner.length == 2 || data.effect == 'hard') { - data.status = 'hover'; - var origin = flipMethods._c.call(this, point.corner, data.opts.cornerSize / 2); - point.x = origin.x; - point.y = origin.y; - flipMethods._showFoldedPage.call(this, point, true); - } - } else { - if (data.status == 'hover') { - data.status = ''; - flipMethods.hideFoldedPage.call(this, true); - } - } - } - } - }, - _eventEnd: function () { - var data = this.data().f, - corner = data.corner; - if (!data.disabled && corner) { - if (trigger('released', this, [data.point || corner]) != 'prevented') { - flipMethods.hideFoldedPage.call(this, true); - } - } - data.corner = null; - }, - disable: function (disable) { - flipMethods.setData.call(this, { - 'disabled': disable - }); - return this; - }, - hover: function (hover) { - flipMethods.setData.call(this, { - 'hover': hover - }); - return this; - }, - peel: function (corner, animate) { - var data = this.data().f; - if (corner) { - if ($.inArray(corner, corners.all) == -1) throw turnError('Corner ' + corner + ' is not permitted'); - if ($.inArray(corner, flipMethods._cAllowed.call(this)) != -1) { - var point = flipMethods._c.call(this, corner, data.opts.cornerSize / 2); - data.status = 'peel'; - flipMethods._showFoldedPage.call(this, { - corner: corner, - x: point.x, - y: point.y - }, animate); - } - } else { - data.status = ''; - flipMethods.hideFoldedPage.call(this, animate); - } - return this; - } - }; - - // Processes classes - - function dec(that, methods, args) { - if (!args[0] || typeof args[0] == 'object') return methods.init.apply(that, args);else if (methods[args[0]]) return methods[args[0]].apply(that, Array.prototype.slice.call(args, 1));else throw turnError(args[0] + ' is not a method or property'); - } - - // Attributes for a layer - - function divAtt(top, left, zIndex, overf) { - return { - 'css': { - position: 'absolute', - top: top, - left: left, - 'overflow': overf || 'hidden', - zIndex: zIndex || 'auto' - } - }; - } - - // Gets a 2D point from a bezier curve of four points - - function bezier(p1, p2, p3, p4, t) { - var a = 1 - t, - b = a * a * a, - c = t * t * t; - return point2D(Math.round(b * p1.x + 3 * t * a * a * p2.x + 3 * t * t * a * p3.x + c * p4.x), Math.round(b * p1.y + 3 * t * a * a * p2.y + 3 * t * t * a * p3.y + c * p4.y)); - } - - // Converts an angle from degrees to radians - - function rad(degrees) { - return degrees / 180 * PI; - } - - // Converts an angle from radians to degrees - - function deg(radians) { - return radians / PI * 180; - } - - // Gets a 2D point - - function point2D(x, y) { - return { - x: x, - y: y - }; - } - - // Webkit 534.3 on Android wrongly repaints elements that use overflow:hidden + rotation - - function rotationAvailable() { - var parts; - if (parts = /AppleWebkit\/([0-9\.]+)/i.exec(navigator.userAgent)) { - var webkitVersion = parseFloat(parts[1]); - return webkitVersion > 534.3; - } else { - return true; - } - } - - // Returns the traslate value - - function translate(x, y, use3d) { - return has3d && use3d ? ' translate3d(' + x + 'px,' + y + 'px, 0px) ' : ' translate(' + x + 'px, ' + y + 'px) '; - } - - // Returns the rotation value - - function rotate(degrees) { - return ' rotate(' + degrees + 'deg) '; - } - - // Checks if a property belongs to an object - - function has(property, object) { - return Object.prototype.hasOwnProperty.call(object, property); - } - - // Gets the CSS3 vendor prefix - - function getPrefix() { - var vendorPrefixes = ['Moz', 'Webkit', 'Khtml', 'O', 'ms'], - len = vendorPrefixes.length, - vendor = ''; - while (len--) if (vendorPrefixes[len] + 'Transform' in document.body.style) vendor = '-' + vendorPrefixes[len].toLowerCase() + '-'; - return vendor; - } - - // Detects the transitionEnd Event - - function getTransitionEnd() { - var t, - el = document.createElement('fakeelement'), - transitions = { - 'transition': 'transitionend', - 'OTransition': 'oTransitionEnd', - 'MSTransition': 'transitionend', - 'MozTransition': 'transitionend', - 'WebkitTransition': 'webkitTransitionEnd' - }; - for (t in transitions) { - if (el.style[t] !== undefined) { - return transitions[t]; - } - } - } - - // Gradients - - function gradient(obj, p0, p1, colors, numColors) { - var j, - cols = []; - if (vendor == '-webkit-') { - for (j = 0; j < numColors; j++) cols.push('color-stop(' + colors[j][0] + ', ' + colors[j][1] + ')'); - obj.css({ - 'background-image': '-webkit-gradient(linear, ' + p0.x + '% ' + p0.y + '%,' + p1.x + '% ' + p1.y + '%, ' + cols.join(',') + ' )' - }); - } else { - p0 = { - x: p0.x / 100 * obj.width(), - y: p0.y / 100 * obj.height() - }; - p1 = { - x: p1.x / 100 * obj.width(), - y: p1.y / 100 * obj.height() - }; - var dx = p1.x - p0.x, - dy = p1.y - p0.y, - angle = Math.atan2(dy, dx), - angle2 = angle - Math.PI / 2, - diagonal = Math.abs(obj.width() * Math.sin(angle2)) + Math.abs(obj.height() * Math.cos(angle2)), - gradientDiagonal = Math.sqrt(dy * dy + dx * dx), - corner = point2D(p1.x < p0.x ? obj.width() : 0, p1.y < p0.y ? obj.height() : 0), - slope = Math.tan(angle), - inverse = -1 / slope, - x = (inverse * corner.x - corner.y - slope * p0.x + p0.y) / (inverse - slope), - c = { - x: x, - y: inverse * x - inverse * corner.x + corner.y - }, - segA = Math.sqrt(Math.pow(c.x - p0.x, 2) + Math.pow(c.y - p0.y, 2)); - for (j = 0; j < numColors; j++) cols.push(' ' + colors[j][1] + ' ' + (segA + gradientDiagonal * colors[j][0]) * 100 / diagonal + '%'); - obj.css({ - 'background-image': vendor + 'linear-gradient(' + -angle + 'rad,' + cols.join(',') + ')' - }); - } - } - - // Triggers an event - - function trigger(eventName, context, args) { - var event = $.Event(eventName); - context.trigger(event, args); - if (event.isDefaultPrevented()) return 'prevented';else if (event.isPropagationStopped()) return 'stopped';else return ''; - } - - // JS Errors - - function turnError(message) { - function TurnJsError(message) { - this.name = "TurnJsError"; - this.message = message; - } - TurnJsError.prototype = new Error(); - TurnJsError.prototype.constructor = TurnJsError; - return new TurnJsError(message); - } - - // Find the offset of an element ignoring its transformation - - function findPos(obj) { - var offset = { - top: 0, - left: 0 - }; - do { - offset.left += obj.offsetLeft; - offset.top += obj.offsetTop; - } while (obj = obj.offsetParent); - return offset; - } - - // Checks if there's hard page compatibility - // IE9 is the only browser that does not support hard pages - - function hasHardPage() { - return navigator.userAgent.indexOf('MSIE 9.0') == -1; - } - - // Request an animation - - window.requestAnim = function () { - return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (callback) { - window.setTimeout(callback, 1000 / 60); - }; - }(); - - // Extend $.fn - - $.extend($.fn, { - flip: function () { - return dec($(this[0]), flipMethods, arguments); - }, - turn: function () { - return dec($(this[0]), turnMethods, arguments); - }, - transform: function (transform, origin) { - var properties = {}; - if (origin) properties[vendor + 'transform-origin'] = origin; - properties[vendor + 'transform'] = transform; - return this.css(properties); - }, - animatef: function (point) { - var data = this.data(); - if (data.effect) data.effect.stop(); - if (point) { - if (!point.to.length) point.to = [point.to]; - if (!point.from.length) point.from = [point.from]; - var diff = [], - len = point.to.length, - animating = true, - that = this, - time = new Date().getTime(), - frame = function () { - if (!data.effect || !animating) return; - var v = [], - timeDiff = Math.min(point.duration, new Date().getTime() - time); - for (var i = 0; i < len; i++) v.push(data.effect.easing(1, timeDiff, point.from[i], diff[i], point.duration)); - point.frame(len == 1 ? v[0] : v); - if (timeDiff == point.duration) { - delete data['effect']; - that.data(data); - if (point.complete) point.complete(); - } else { - window.requestAnim(frame); - } - }; - for (var i = 0; i < len; i++) diff.push(point.to[i] - point.from[i]); - data.effect = $.extend({ - stop: function () { - animating = false; - }, - easing: function (x, t, b, c, data) { - return c * Math.sqrt(1 - (t = t / data - 1) * t) + b; - } - }, point); - this.data(data); - frame(); - } else { - delete data['effect']; - } - } - }); - - // Export some globals - - $.isTouch = isTouch; - $.mouseEvents = mouseEvents; - $.cssPrefix = getPrefix; - $.cssTransitionEnd = getTransitionEnd; - $.findPos = findPos; -})(jQuery); \ No newline at end of file