|
|
(11 intermediate revisions by the same user not shown) |
Line 1: |
Line 1: |
− | <html>
| + | {{Nanjing-China/JS/jquery-min}} |
− | <script>
| + | {{Nanjing-China/JS/bootstrap}} |
− | /*!
| + | {{Nanjing-China/JS/jquery-parallax}} |
− | * Bootstrap v3.3.5 (http://getbootstrap.com)
| + | {{Nanjing-China/JS/modernizr-2.6.2-min}} |
− | * Copyright 2011-2015 Twitter, Inc.
| + | {{Nanjing-China/JS/jquery-themepunch-revolution-min}} |
− | * Licensed under the MIT license
| + | {{Nanjing-China/JS/jquery-nivo-slider-pack}} |
− | */
| + | {{Nanjing-China/JS/jquery-prettyPhoto}} |
− | if ("undefined" == typeof jQuery) throw new Error("Bootstrap's JavaScript requires jQuery"); + function (a) {
| + | {{Nanjing-China/JS/superfish}} |
− | "use strict";
| + | |
− | var b = a.fn.jquery.split(" ")[0].split(".");
| + | |
− | if (b[0] < 2 && b[1] < 9 || 1 == b[0] && 9 == b[1] && b[2] < 1) throw new Error("Bootstrap's JavaScript requires jQuery version 1.9.1 or higher")
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b() {
| + | |
− | var a = document.createElement("bootstrap"),
| + | |
− | b = {
| + | |
− | WebkitTransition: "webkitTransitionEnd",
| + | |
− | MozTransition: "transitionend",
| + | |
− | OTransition: "oTransitionEnd otransitionend",
| + | |
− | transition: "transitionend"
| + | |
− | };
| + | |
− | for (var c in b)
| + | |
− | if (void 0 !== a.style[c]) return {
| + | |
− | end: b[c]
| + | |
− | };
| + | |
− | return !1
| + | |
− | }
| + | |
− | a.fn.emulateTransitionEnd = function (b) {
| + | |
− | var c = !1,
| + | |
− | d = this;
| + | |
− | a(this).one("bsTransitionEnd", function () {
| + | |
− | c = !0
| + | |
− | });
| + | |
− | var e = function () {
| + | |
− | c || a(d).trigger(a.support.transition.end)
| + | |
− | };
| + | |
− | return setTimeout(e, b), this
| + | |
− | }, a(function () {
| + | |
− | a.support.transition = b(), a.support.transition && (a.event.special.bsTransitionEnd = {
| + | |
− | bindType: a.support.transition.end,
| + | |
− | delegateType: a.support.transition.end,
| + | |
− | handle: function (b) {
| + | |
− | return a(b.target).is(this) ? b.handleObj.handler.apply(this, arguments) : void 0
| + | |
− | }
| + | |
− | })
| + | |
− | })
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | return this.each(function () {
| + | |
− | var c = a(this),
| + | |
− | e = c.data("bs.alert");
| + | |
− | e || c.data("bs.alert", e = new d(this)), "string" == typeof b && e[b].call(c)
| + | |
− | })
| + | |
− | }
| + | |
− | var c = '[data-dismiss="alert"]',
| + | |
− | d = function (b) {
| + | |
− | a(b).on("click", c, this.close)
| + | |
− | };
| + | |
− | d.VERSION = "3.3.5", d.TRANSITION_DURATION = 150, d.prototype.close = function (b) {
| + | |
− | function c() {
| + | |
− | g.detach().trigger("closed.bs.alert").remove()
| + | |
− | }
| + | |
− | var e = a(this),
| + | |
− | f = e.attr("data-target");
| + | |
− | f || (f = e.attr("href"), f = f && f.replace(/.*(?=#[^\s]*$)/, ""));
| + | |
− | var g = a(f);
| + | |
− | b && b.preventDefault(), g.length || (g = e.closest(".alert")), g.trigger(b = a.Event("close.bs.alert")), b.isDefaultPrevented() || (g.removeClass("in"), a.support.transition && g.hasClass("fade") ? g.one("bsTransitionEnd", c).emulateTransitionEnd(d.TRANSITION_DURATION) : c())
| + | |
− | };
| + | |
− | var e = a.fn.alert;
| + | |
− | a.fn.alert = b, a.fn.alert.Constructor = d, a.fn.alert.noConflict = function () {
| + | |
− | return a.fn.alert = e, this
| + | |
− | }, a(document).on("click.bs.alert.data-api", c, d.prototype.close)
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | return this.each(function () {
| + | |
− | var d = a(this),
| + | |
− | e = d.data("bs.button"),
| + | |
− | f = "object" == typeof b && b;
| + | |
− | e || d.data("bs.button", e = new c(this, f)), "toggle" == b ? e.toggle() : b && e.setState(b)
| + | |
− | })
| + | |
− | }
| + | |
− | var c = function (b, d) {
| + | |
− | this.$element = a(b), this.options = a.extend({}, c.DEFAULTS, d), this.isLoading = !1
| + | |
− | };
| + | |
− | c.VERSION = "3.3.5", c.DEFAULTS = {
| + | |
− | loadingText: "loading..."
| + | |
− | }, c.prototype.setState = function (b) {
| + | |
− | var c = "disabled",
| + | |
− | d = this.$element,
| + | |
− | e = d.is("input") ? "val" : "html",
| + | |
− | f = d.data();
| + | |
− | b += "Text", null == f.resetText && d.data("resetText", d[e]()), setTimeout(a.proxy(function () {
| + | |
− | d[e](null == f[b] ? this.options[b] : f[b]), "loadingText" == b ? (this.isLoading = !0, d.addClass(c).attr(c, c)) : this.isLoading && (this.isLoading = !1, d.removeClass(c).removeAttr(c))
| + | |
− | }, this), 0)
| + | |
− | }, c.prototype.toggle = function () {
| + | |
− | var a = !0,
| + | |
− | b = this.$element.closest('[data-toggle="buttons"]');
| + | |
− | if (b.length) {
| + | |
− | var c = this.$element.find("input");
| + | |
− | "radio" == c.prop("type") ? (c.prop("checked") && (a = !1), b.find(".active").removeClass("active"), this.$element.addClass("active")) : "checkbox" == c.prop("type") && (c.prop("checked") !== this.$element.hasClass("active") && (a = !1), this.$element.toggleClass("active")), c.prop("checked", this.$element.hasClass("active")), a && c.trigger("change")
| + | |
− | } else this.$element.attr("aria-pressed", !this.$element.hasClass("active")), this.$element.toggleClass("active")
| + | |
− | };
| + | |
− | var d = a.fn.button;
| + | |
− | a.fn.button = b, a.fn.button.Constructor = c, a.fn.button.noConflict = function () {
| + | |
− | return a.fn.button = d, this
| + | |
− | }, a(document).on("click.bs.button.data-api", '[data-toggle^="button"]', function (c) {
| + | |
− | var d = a(c.target);
| + | |
− | d.hasClass("btn") || (d = d.closest(".btn")), b.call(d, "toggle"), a(c.target).is('input[type="radio"]') || a(c.target).is('input[type="checkbox"]') || c.preventDefault()
| + | |
− | }).on("focus.bs.button.data-api blur.bs.button.data-api", '[data-toggle^="button"]', function (b) {
| + | |
− | a(b.target).closest(".btn").toggleClass("focus", /^focus(in)?$/.test(b.type))
| + | |
− | })
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | return this.each(function () {
| + | |
− | var d = a(this),
| + | |
− | e = d.data("bs.carousel"),
| + | |
− | f = a.extend({}, c.DEFAULTS, d.data(), "object" == typeof b && b),
| + | |
− | g = "string" == typeof b ? b : f.slide;
| + | |
− | e || d.data("bs.carousel", e = new c(this, f)), "number" == typeof b ? e.to(b) : g ? e[g]() : f.interval && e.pause().cycle()
| + | |
− | })
| + | |
− | }
| + | |
− | var c = function (b, c) {
| + | |
− | this.$element = a(b), this.$indicators = this.$element.find(".carousel-indicators"), this.options = c, this.paused = null, this.sliding = null, this.interval = null, this.$active = null, this.$items = null, this.options.keyboard && this.$element.on("keydown.bs.carousel", a.proxy(this.keydown, this)), "hover" == this.options.pause && !("ontouchstart" in document.documentElement) && this.$element.on("mouseenter.bs.carousel", a.proxy(this.pause, this)).on("mouseleave.bs.carousel", a.proxy(this.cycle, this))
| + | |
− | };
| + | |
− | c.VERSION = "3.3.5", c.TRANSITION_DURATION = 600, c.DEFAULTS = {
| + | |
− | interval: 5e3,
| + | |
− | pause: "hover",
| + | |
− | wrap: !0,
| + | |
− | keyboard: !0
| + | |
− | }, c.prototype.keydown = function (a) {
| + | |
− | if (!/input|textarea/i.test(a.target.tagName)) {
| + | |
− | switch (a.which) {
| + | |
− | case 37:
| + | |
− | this.prev();
| + | |
− | break;
| + | |
− | case 39:
| + | |
− | this.next();
| + | |
− | break;
| + | |
− | default:
| + | |
− | return
| + | |
− | }
| + | |
− | a.preventDefault()
| + | |
− | }
| + | |
− | }, c.prototype.cycle = function (b) {
| + | |
− | return b || (this.paused = !1), this.interval && clearInterval(this.interval), this.options.interval && !this.paused && (this.interval = setInterval(a.proxy(this.next, this), this.options.interval)), this
| + | |
− | }, c.prototype.getItemIndex = function (a) {
| + | |
− | return this.$items = a.parent().children(".item"), this.$items.index(a || this.$active)
| + | |
− | }, c.prototype.getItemForDirection = function (a, b) {
| + | |
− | var c = this.getItemIndex(b),
| + | |
− | d = "prev" == a && 0 === c || "next" == a && c == this.$items.length - 1;
| + | |
− | if (d && !this.options.wrap) return b;
| + | |
− | var e = "prev" == a ? -1 : 1,
| + | |
− | f = (c + e) % this.$items.length;
| + | |
− | return this.$items.eq(f)
| + | |
− | }, c.prototype.to = function (a) {
| + | |
− | var b = this,
| + | |
− | c = this.getItemIndex(this.$active = this.$element.find(".item.active"));
| + | |
− | return a > this.$items.length - 1 || 0 > a ? void 0 : this.sliding ? this.$element.one("slid.bs.carousel", function () {
| + | |
− | b.to(a)
| + | |
− | }) : c == a ? this.pause().cycle() : this.slide(a > c ? "next" : "prev", this.$items.eq(a))
| + | |
− | }, c.prototype.pause = function (b) {
| + | |
− | return b || (this.paused = !0), this.$element.find(".next, .prev").length && a.support.transition && (this.$element.trigger(a.support.transition.end), this.cycle(!0)), this.interval = clearInterval(this.interval), this
| + | |
− | }, c.prototype.next = function () {
| + | |
− | return this.sliding ? void 0 : this.slide("next")
| + | |
− | }, c.prototype.prev = function () {
| + | |
− | return this.sliding ? void 0 : this.slide("prev")
| + | |
− | }, c.prototype.slide = function (b, d) {
| + | |
− | var e = this.$element.find(".item.active"),
| + | |
− | f = d || this.getItemForDirection(b, e),
| + | |
− | g = this.interval,
| + | |
− | h = "next" == b ? "left" : "right",
| + | |
− | i = this;
| + | |
− | if (f.hasClass("active")) return this.sliding = !1;
| + | |
− | var j = f[0],
| + | |
− | k = a.Event("slide.bs.carousel", {
| + | |
− | relatedTarget: j,
| + | |
− | direction: h
| + | |
− | });
| + | |
− | if (this.$element.trigger(k), !k.isDefaultPrevented()) {
| + | |
− | if (this.sliding = !0, g && this.pause(), this.$indicators.length) {
| + | |
− | this.$indicators.find(".active").removeClass("active");
| + | |
− | var l = a(this.$indicators.children()[this.getItemIndex(f)]);
| + | |
− | l && l.addClass("active")
| + | |
− | }
| + | |
− | var m = a.Event("slid.bs.carousel", {
| + | |
− | relatedTarget: j,
| + | |
− | direction: h
| + | |
− | });
| + | |
− | return a.support.transition && this.$element.hasClass("slide") ? (f.addClass(b), f[0].offsetWidth, e.addClass(h), f.addClass(h), e.one("bsTransitionEnd", function () {
| + | |
− | f.removeClass([b, h].join(" ")).addClass("active"), e.removeClass(["active", h].join(" ")), i.sliding = !1, setTimeout(function () {
| + | |
− | i.$element.trigger(m)
| + | |
− | }, 0)
| + | |
− | }).emulateTransitionEnd(c.TRANSITION_DURATION)) : (e.removeClass("active"), f.addClass("active"), this.sliding = !1, this.$element.trigger(m)), g && this.cycle(), this
| + | |
− | }
| + | |
− | };
| + | |
− | var d = a.fn.carousel;
| + | |
− | a.fn.carousel = b, a.fn.carousel.Constructor = c, a.fn.carousel.noConflict = function () {
| + | |
− | return a.fn.carousel = d, this
| + | |
− | };
| + | |
− | var e = function (c) {
| + | |
− | var d, e = a(this),
| + | |
− | f = a(e.attr("data-target") || (d = e.attr("href")) && d.replace(/.*(?=#[^\s]+$)/, ""));
| + | |
− | if (f.hasClass("carousel")) {
| + | |
− | var g = a.extend({}, f.data(), e.data()),
| + | |
− | h = e.attr("data-slide-to");
| + | |
− | h && (g.interval = !1), b.call(f, g), h && f.data("bs.carousel").to(h), c.preventDefault()
| + | |
− | }
| + | |
− | };
| + | |
− | a(document).on("click.bs.carousel.data-api", "[data-slide]", e).on("click.bs.carousel.data-api", "[data-slide-to]", e), a(window).on("load", function () {
| + | |
− | a('[data-ride="carousel"]').each(function () {
| + | |
− | var c = a(this);
| + | |
− | b.call(c, c.data())
| + | |
− | })
| + | |
− | })
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | var c, d = b.attr("data-target") || (c = b.attr("href")) && c.replace(/.*(?=#[^\s]+$)/, "");
| + | |
− | return a(d)
| + | |
− | }
| + | |
− | | + | |
− | function c(b) {
| + | |
− | return this.each(function () {
| + | |
− | var c = a(this),
| + | |
− | e = c.data("bs.collapse"),
| + | |
− | f = a.extend({}, d.DEFAULTS, c.data(), "object" == typeof b && b);
| + | |
− | !e && f.toggle && /show|hide/.test(b) && (f.toggle = !1), e || c.data("bs.collapse", e = new d(this, f)), "string" == typeof b && e[b]()
| + | |
− | })
| + | |
− | }
| + | |
− | var d = function (b, c) {
| + | |
− | this.$element = a(b), this.options = a.extend({}, d.DEFAULTS, c), this.$trigger = a('[data-toggle="collapse"][href="#' + b.id + '"],[data-toggle="collapse"][data-target="#' + b.id + '"]'), this.transitioning = null, this.options.parent ? this.$parent = this.getParent() : this.addAriaAndCollapsedClass(this.$element, this.$trigger), this.options.toggle && this.toggle()
| + | |
− | };
| + | |
− | d.VERSION = "3.3.5", d.TRANSITION_DURATION = 350, d.DEFAULTS = {
| + | |
− | toggle: !0
| + | |
− | }, d.prototype.dimension = function () {
| + | |
− | var a = this.$element.hasClass("width");
| + | |
− | return a ? "width" : "height"
| + | |
− | }, d.prototype.show = function () {
| + | |
− | if (!this.transitioning && !this.$element.hasClass("in")) {
| + | |
− | var b, e = this.$parent && this.$parent.children(".panel").children(".in, .collapsing");
| + | |
− | if (!(e && e.length && (b = e.data("bs.collapse"), b && b.transitioning))) {
| + | |
− | var f = a.Event("show.bs.collapse");
| + | |
− | if (this.$element.trigger(f), !f.isDefaultPrevented()) {
| + | |
− | e && e.length && (c.call(e, "hide"), b || e.data("bs.collapse", null));
| + | |
− | var g = this.dimension();
| + | |
− | this.$element.removeClass("collapse").addClass("collapsing")[g](0).attr("aria-expanded", !0), this.$trigger.removeClass("collapsed").attr("aria-expanded", !0), this.transitioning = 1;
| + | |
− | var h = function () {
| + | |
− | this.$element.removeClass("collapsing").addClass("collapse in")[g](""), this.transitioning = 0, this.$element.trigger("shown.bs.collapse")
| + | |
− | };
| + | |
− | if (!a.support.transition) return h.call(this);
| + | |
− | var i = a.camelCase(["scroll", g].join("-"));
| + | |
− | this.$element.one("bsTransitionEnd", a.proxy(h, this)).emulateTransitionEnd(d.TRANSITION_DURATION)[g](this.$element[0][i])
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | }, d.prototype.hide = function () {
| + | |
− | if (!this.transitioning && this.$element.hasClass("in")) {
| + | |
− | var b = a.Event("hide.bs.collapse");
| + | |
− | if (this.$element.trigger(b), !b.isDefaultPrevented()) {
| + | |
− | var c = this.dimension();
| + | |
− | this.$element[c](this.$element[c]())[0].offsetHeight, this.$element.addClass("collapsing").removeClass("collapse in").attr("aria-expanded", !1), this.$trigger.addClass("collapsed").attr("aria-expanded", !1), this.transitioning = 1;
| + | |
− | var e = function () {
| + | |
− | this.transitioning = 0, this.$element.removeClass("collapsing").addClass("collapse").trigger("hidden.bs.collapse")
| + | |
− | };
| + | |
− | return a.support.transition ? void this.$element[c](0).one("bsTransitionEnd", a.proxy(e, this)).emulateTransitionEnd(d.TRANSITION_DURATION) : e.call(this)
| + | |
− | }
| + | |
− | }
| + | |
− | }, d.prototype.toggle = function () {
| + | |
− | this[this.$element.hasClass("in") ? "hide" : "show"]()
| + | |
− | }, d.prototype.getParent = function () {
| + | |
− | return a(this.options.parent).find('[data-toggle="collapse"][data-parent="' + this.options.parent + '"]').each(a.proxy(function (c, d) {
| + | |
− | var e = a(d);
| + | |
− | this.addAriaAndCollapsedClass(b(e), e)
| + | |
− | }, this)).end()
| + | |
− | }, d.prototype.addAriaAndCollapsedClass = function (a, b) {
| + | |
− | var c = a.hasClass("in");
| + | |
− | a.attr("aria-expanded", c), b.toggleClass("collapsed", !c).attr("aria-expanded", c)
| + | |
− | };
| + | |
− | var e = a.fn.collapse;
| + | |
− | a.fn.collapse = c, a.fn.collapse.Constructor = d, a.fn.collapse.noConflict = function () {
| + | |
− | return a.fn.collapse = e, this
| + | |
− | }, a(document).on("click.bs.collapse.data-api", '[data-toggle="collapse"]', function (d) {
| + | |
− | var e = a(this);
| + | |
− | e.attr("data-target") || d.preventDefault();
| + | |
− | var f = b(e),
| + | |
− | g = f.data("bs.collapse"),
| + | |
− | h = g ? "toggle" : e.data();
| + | |
− | c.call(f, h)
| + | |
− | })
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | var c = b.attr("data-target");
| + | |
− | c || (c = b.attr("href"), c = c && /#[A-Za-z]/.test(c) && c.replace(/.*(?=#[^\s]*$)/, ""));
| + | |
− | var d = c && a(c);
| + | |
− | return d && d.length ? d : b.parent()
| + | |
− | }
| + | |
− | | + | |
− | function c(c) {
| + | |
− | c && 3 === c.which || (a(e).remove(), a(f).each(function () {
| + | |
− | var d = a(this),
| + | |
− | e = b(d),
| + | |
− | f = {
| + | |
− | relatedTarget: this
| + | |
− | };
| + | |
− | e.hasClass("open") && (c && "click" == c.type && /input|textarea/i.test(c.target.tagName) && a.contains(e[0], c.target) || (e.trigger(c = a.Event("hide.bs.dropdown", f)), c.isDefaultPrevented() || (d.attr("aria-expanded", "false"), e.removeClass("open").trigger("hidden.bs.dropdown", f))))
| + | |
− | }))
| + | |
− | }
| + | |
− | | + | |
− | function d(b) {
| + | |
− | return this.each(function () {
| + | |
− | var c = a(this),
| + | |
− | d = c.data("bs.dropdown");
| + | |
− | d || c.data("bs.dropdown", d = new g(this)), "string" == typeof b && d[b].call(c)
| + | |
− | })
| + | |
− | }
| + | |
− | var e = ".dropdown-backdrop",
| + | |
− | f = '[data-toggle="dropdown"]',
| + | |
− | g = function (b) {
| + | |
− | a(b).on("click.bs.dropdown", this.toggle)
| + | |
− | };
| + | |
− | g.VERSION = "3.3.5", g.prototype.toggle = function (d) {
| + | |
− | var e = a(this);
| + | |
− | if (!e.is(".disabled, :disabled")) {
| + | |
− | var f = b(e),
| + | |
− | g = f.hasClass("open");
| + | |
− | if (c(), !g) {
| + | |
− | "ontouchstart" in document.documentElement && !f.closest(".navbar-nav").length && a(document.createElement("div")).addClass("dropdown-backdrop").insertAfter(a(this)).on("click", c);
| + | |
− | var h = {
| + | |
− | relatedTarget: this
| + | |
− | };
| + | |
− | if (f.trigger(d = a.Event("show.bs.dropdown", h)), d.isDefaultPrevented()) return;
| + | |
− | e.trigger("focus").attr("aria-expanded", "true"), f.toggleClass("open").trigger("shown.bs.dropdown", h)
| + | |
− | }
| + | |
− | return !1
| + | |
− | }
| + | |
− | }, g.prototype.keydown = function (c) {
| + | |
− | if (/(38|40|27|32)/.test(c.which) && !/input|textarea/i.test(c.target.tagName)) {
| + | |
− | var d = a(this);
| + | |
− | if (c.preventDefault(), c.stopPropagation(), !d.is(".disabled, :disabled")) {
| + | |
− | var e = b(d),
| + | |
− | g = e.hasClass("open");
| + | |
− | if (!g && 27 != c.which || g && 27 == c.which) return 27 == c.which && e.find(f).trigger("focus"), d.trigger("click");
| + | |
− | var h = " li:not(.disabled):visible a",
| + | |
− | i = e.find(".dropdown-menu" + h);
| + | |
− | if (i.length) {
| + | |
− | var j = i.index(c.target);
| + | |
− | 38 == c.which && j > 0 && j--, 40 == c.which && j < i.length - 1 && j++, ~j || (j = 0), i.eq(j).trigger("focus")
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | };
| + | |
− | var h = a.fn.dropdown;
| + | |
− | a.fn.dropdown = d, a.fn.dropdown.Constructor = g, a.fn.dropdown.noConflict = function () {
| + | |
− | return a.fn.dropdown = h, this
| + | |
− | }, a(document).on("click.bs.dropdown.data-api", c).on("click.bs.dropdown.data-api", ".dropdown form", function (a) {
| + | |
− | a.stopPropagation()
| + | |
− | }).on("click.bs.dropdown.data-api", f, g.prototype.toggle).on("keydown.bs.dropdown.data-api", f, g.prototype.keydown).on("keydown.bs.dropdown.data-api", ".dropdown-menu", g.prototype.keydown)
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b, d) {
| + | |
− | return this.each(function () {
| + | |
− | var e = a(this),
| + | |
− | f = e.data("bs.modal"),
| + | |
− | g = a.extend({}, c.DEFAULTS, e.data(), "object" == typeof b && b);
| + | |
− | f || e.data("bs.modal", f = new c(this, g)), "string" == typeof b ? f[b](d) : g.show && f.show(d)
| + | |
− | })
| + | |
− | }
| + | |
− | var c = function (b, c) {
| + | |
− | this.options = c, this.$body = a(document.body), this.$element = a(b), this.$dialog = this.$element.find(".modal-dialog"), this.$backdrop = null, this.isShown = null, this.originalBodyPad = null, this.scrollbarWidth = 0, this.ignoreBackdropClick = !1, this.options.remote && this.$element.find(".modal-content").load(this.options.remote, a.proxy(function () {
| + | |
− | this.$element.trigger("loaded.bs.modal")
| + | |
− | }, this))
| + | |
− | };
| + | |
− | c.VERSION = "3.3.5", c.TRANSITION_DURATION = 300, c.BACKDROP_TRANSITION_DURATION = 150, c.DEFAULTS = {
| + | |
− | backdrop: !0,
| + | |
− | keyboard: !0,
| + | |
− | show: !0
| + | |
− | }, c.prototype.toggle = function (a) {
| + | |
− | return this.isShown ? this.hide() : this.show(a)
| + | |
− | }, c.prototype.show = function (b) {
| + | |
− | var d = this,
| + | |
− | e = a.Event("show.bs.modal", {
| + | |
− | relatedTarget: b
| + | |
− | });
| + | |
− | this.$element.trigger(e), this.isShown || e.isDefaultPrevented() || (this.isShown = !0, this.checkScrollbar(), this.setScrollbar(), this.$body.addClass("modal-open"), this.escape(), this.resize(), this.$element.on("click.dismiss.bs.modal", '[data-dismiss="modal"]', a.proxy(this.hide, this)), this.$dialog.on("mousedown.dismiss.bs.modal", function () {
| + | |
− | d.$element.one("mouseup.dismiss.bs.modal", function (b) {
| + | |
− | a(b.target).is(d.$element) && (d.ignoreBackdropClick = !0)
| + | |
− | })
| + | |
− | }), this.backdrop(function () {
| + | |
− | var e = a.support.transition && d.$element.hasClass("fade");
| + | |
− | d.$element.parent().length || d.$element.appendTo(d.$body), d.$element.show().scrollTop(0), d.adjustDialog(), e && d.$element[0].offsetWidth, d.$element.addClass("in"), d.enforceFocus();
| + | |
− | var f = a.Event("shown.bs.modal", {
| + | |
− | relatedTarget: b
| + | |
− | });
| + | |
− | e ? d.$dialog.one("bsTransitionEnd", function () {
| + | |
− | d.$element.trigger("focus").trigger(f)
| + | |
− | }).emulateTransitionEnd(c.TRANSITION_DURATION) : d.$element.trigger("focus").trigger(f)
| + | |
− | }))
| + | |
− | }, c.prototype.hide = function (b) {
| + | |
− | b && b.preventDefault(), b = a.Event("hide.bs.modal"), this.$element.trigger(b), this.isShown && !b.isDefaultPrevented() && (this.isShown = !1, this.escape(), this.resize(), a(document).off("focusin.bs.modal"), this.$element.removeClass("in").off("click.dismiss.bs.modal").off("mouseup.dismiss.bs.modal"), this.$dialog.off("mousedown.dismiss.bs.modal"), a.support.transition && this.$element.hasClass("fade") ? this.$element.one("bsTransitionEnd", a.proxy(this.hideModal, this)).emulateTransitionEnd(c.TRANSITION_DURATION) : this.hideModal())
| + | |
− | }, c.prototype.enforceFocus = function () {
| + | |
− | a(document).off("focusin.bs.modal").on("focusin.bs.modal", a.proxy(function (a) {
| + | |
− | this.$element[0] === a.target || this.$element.has(a.target).length || this.$element.trigger("focus")
| + | |
− | }, this))
| + | |
− | }, c.prototype.escape = function () {
| + | |
− | this.isShown && this.options.keyboard ? this.$element.on("keydown.dismiss.bs.modal", a.proxy(function (a) {
| + | |
− | 27 == a.which && this.hide()
| + | |
− | }, this)) : this.isShown || this.$element.off("keydown.dismiss.bs.modal")
| + | |
− | }, c.prototype.resize = function () {
| + | |
− | this.isShown ? a(window).on("resize.bs.modal", a.proxy(this.handleUpdate, this)) : a(window).off("resize.bs.modal")
| + | |
− | }, c.prototype.hideModal = function () {
| + | |
− | var a = this;
| + | |
− | this.$element.hide(), this.backdrop(function () {
| + | |
− | a.$body.removeClass("modal-open"), a.resetAdjustments(), a.resetScrollbar(), a.$element.trigger("hidden.bs.modal")
| + | |
− | })
| + | |
− | }, c.prototype.removeBackdrop = function () {
| + | |
− | this.$backdrop && this.$backdrop.remove(), this.$backdrop = null
| + | |
− | }, c.prototype.backdrop = function (b) {
| + | |
− | var d = this,
| + | |
− | e = this.$element.hasClass("fade") ? "fade" : "";
| + | |
− | if (this.isShown && this.options.backdrop) {
| + | |
− | var f = a.support.transition && e;
| + | |
− | if (this.$backdrop = a(document.createElement("div")).addClass("modal-backdrop " + e).appendTo(this.$body), this.$element.on("click.dismiss.bs.modal", a.proxy(function (a) {
| + | |
− | return this.ignoreBackdropClick ? void(this.ignoreBackdropClick = !1) : void(a.target === a.currentTarget && ("static" == this.options.backdrop ? this.$element[0].focus() : this.hide()))
| + | |
− | }, this)), f && this.$backdrop[0].offsetWidth, this.$backdrop.addClass("in"), !b) return;
| + | |
− | f ? this.$backdrop.one("bsTransitionEnd", b).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION) : b()
| + | |
− | } else if (!this.isShown && this.$backdrop) {
| + | |
− | this.$backdrop.removeClass("in");
| + | |
− | var g = function () {
| + | |
− | d.removeBackdrop(), b && b()
| + | |
− | };
| + | |
− | a.support.transition && this.$element.hasClass("fade") ? this.$backdrop.one("bsTransitionEnd", g).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION) : g()
| + | |
− | } else b && b()
| + | |
− | }, c.prototype.handleUpdate = function () {
| + | |
− | this.adjustDialog()
| + | |
− | }, c.prototype.adjustDialog = function () {
| + | |
− | var a = this.$element[0].scrollHeight > document.documentElement.clientHeight;
| + | |
− | this.$element.css({
| + | |
− | paddingLeft: !this.bodyIsOverflowing && a ? this.scrollbarWidth : "",
| + | |
− | paddingRight: this.bodyIsOverflowing && !a ? this.scrollbarWidth : ""
| + | |
− | })
| + | |
− | }, c.prototype.resetAdjustments = function () {
| + | |
− | this.$element.css({
| + | |
− | paddingLeft: "",
| + | |
− | paddingRight: ""
| + | |
− | })
| + | |
− | }, c.prototype.checkScrollbar = function () {
| + | |
− | var a = window.innerWidth;
| + | |
− | if (!a) {
| + | |
− | var b = document.documentElement.getBoundingClientRect();
| + | |
− | a = b.right - Math.abs(b.left)
| + | |
− | }
| + | |
− | this.bodyIsOverflowing = document.body.clientWidth < a, this.scrollbarWidth = this.measureScrollbar()
| + | |
− | }, c.prototype.setScrollbar = function () {
| + | |
− | var a = parseInt(this.$body.css("padding-right") || 0, 10);
| + | |
− | this.originalBodyPad = document.body.style.paddingRight || "", this.bodyIsOverflowing && this.$body.css("padding-right", a + this.scrollbarWidth)
| + | |
− | }, c.prototype.resetScrollbar = function () {
| + | |
− | this.$body.css("padding-right", this.originalBodyPad)
| + | |
− | }, c.prototype.measureScrollbar = function () {
| + | |
− | var a = document.createElement("div");
| + | |
− | a.className = "modal-scrollbar-measure", this.$body.append(a);
| + | |
− | var b = a.offsetWidth - a.clientWidth;
| + | |
− | return this.$body[0].removeChild(a), b
| + | |
− | };
| + | |
− | var d = a.fn.modal;
| + | |
− | a.fn.modal = b, a.fn.modal.Constructor = c, a.fn.modal.noConflict = function () {
| + | |
− | return a.fn.modal = d, this
| + | |
− | }, a(document).on("click.bs.modal.data-api", '[data-toggle="modal"]', function (c) {
| + | |
− | var d = a(this),
| + | |
− | e = d.attr("href"),
| + | |
− | f = a(d.attr("data-target") || e && e.replace(/.*(?=#[^\s]+$)/, "")),
| + | |
− | g = f.data("bs.modal") ? "toggle" : a.extend({
| + | |
− | remote: !/#/.test(e) && e
| + | |
− | }, f.data(), d.data());
| + | |
− | d.is("a") && c.preventDefault(), f.one("show.bs.modal", function (a) {
| + | |
− | a.isDefaultPrevented() || f.one("hidden.bs.modal", function () {
| + | |
− | d.is(":visible") && d.trigger("focus")
| + | |
− | })
| + | |
− | }), b.call(f, g, this)
| + | |
− | })
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | return this.each(function () {
| + | |
− | var d = a(this),
| + | |
− | e = d.data("bs.tooltip"),
| + | |
− | f = "object" == typeof b && b;
| + | |
− | (e || !/destroy|hide/.test(b)) && (e || d.data("bs.tooltip", e = new c(this, f)), "string" == typeof b && e[b]())
| + | |
− | })
| + | |
− | }
| + | |
− | var c = function (a, b) {
| + | |
− | this.type = null, this.options = null, this.enabled = null, this.timeout = null, this.hoverState = null, this.$element = null, this.inState = null, this.init("tooltip", a, b)
| + | |
− | };
| + | |
− | c.VERSION = "3.3.5", c.TRANSITION_DURATION = 150, c.DEFAULTS = {
| + | |
− | animation: !0,
| + | |
− | placement: "top",
| + | |
− | selector: !1,
| + | |
− | template: '<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',
| + | |
− | trigger: "hover focus",
| + | |
− | title: "",
| + | |
− | delay: 0,
| + | |
− | html: !1,
| + | |
− | container: !1,
| + | |
− | viewport: {
| + | |
− | selector: "body",
| + | |
− | padding: 0
| + | |
− | }
| + | |
− | }, c.prototype.init = function (b, c, d) {
| + | |
− | if (this.enabled = !0, this.type = b, this.$element = a(c), this.options = this.getOptions(d), this.$viewport = this.options.viewport && a(a.isFunction(this.options.viewport) ? this.options.viewport.call(this, this.$element) : this.options.viewport.selector || this.options.viewport), this.inState = {
| + | |
− | click: !1,
| + | |
− | hover: !1,
| + | |
− | focus: !1
| + | |
− | }, this.$element[0] instanceof document.constructor && !this.options.selector) throw new Error("`selector` option must be specified when initializing " + this.type + " on the window.document object!");
| + | |
− | for (var e = this.options.trigger.split(" "), f = e.length; f--;) {
| + | |
− | var g = e[f];
| + | |
− | if ("click" == g) this.$element.on("click." + this.type, this.options.selector, a.proxy(this.toggle, this));
| + | |
− | else if ("manual" != g) {
| + | |
− | var h = "hover" == g ? "mouseenter" : "focusin",
| + | |
− | i = "hover" == g ? "mouseleave" : "focusout";
| + | |
− | this.$element.on(h + "." + this.type, this.options.selector, a.proxy(this.enter, this)), this.$element.on(i + "." + this.type, this.options.selector, a.proxy(this.leave, this))
| + | |
− | }
| + | |
− | }
| + | |
− | this.options.selector ? this._options = a.extend({}, this.options, {
| + | |
− | trigger: "manual",
| + | |
− | selector: ""
| + | |
− | }) : this.fixTitle()
| + | |
− | }, c.prototype.getDefaults = function () {
| + | |
− | return c.DEFAULTS
| + | |
− | }, c.prototype.getOptions = function (b) {
| + | |
− | return b = a.extend({}, this.getDefaults(), this.$element.data(), b), b.delay && "number" == typeof b.delay && (b.delay = {
| + | |
− | show: b.delay,
| + | |
− | hide: b.delay
| + | |
− | }), b
| + | |
− | }, c.prototype.getDelegateOptions = function () {
| + | |
− | var b = {},
| + | |
− | c = this.getDefaults();
| + | |
− | return this._options && a.each(this._options, function (a, d) {
| + | |
− | c[a] != d && (b[a] = d)
| + | |
− | }), b
| + | |
− | }, c.prototype.enter = function (b) {
| + | |
− | var c = b instanceof this.constructor ? b : a(b.currentTarget).data("bs." + this.type);
| + | |
− | return c || (c = new this.constructor(b.currentTarget, this.getDelegateOptions()), a(b.currentTarget).data("bs." + this.type, c)), b instanceof a.Event && (c.inState["focusin" == b.type ? "focus" : "hover"] = !0), c.tip().hasClass("in") || "in" == c.hoverState ? void(c.hoverState = "in") : (clearTimeout(c.timeout), c.hoverState = "in", c.options.delay && c.options.delay.show ? void(c.timeout = setTimeout(function () {
| + | |
− | "in" == c.hoverState && c.show()
| + | |
− | }, c.options.delay.show)) : c.show())
| + | |
− | }, c.prototype.isInStateTrue = function () {
| + | |
− | for (var a in this.inState)
| + | |
− | if (this.inState[a]) return !0;
| + | |
− | return !1
| + | |
− | }, c.prototype.leave = function (b) {
| + | |
− | var c = b instanceof this.constructor ? b : a(b.currentTarget).data("bs." + this.type);
| + | |
− | return c || (c = new this.constructor(b.currentTarget, this.getDelegateOptions()), a(b.currentTarget).data("bs." + this.type, c)), b instanceof a.Event && (c.inState["focusout" == b.type ? "focus" : "hover"] = !1), c.isInStateTrue() ? void 0 : (clearTimeout(c.timeout), c.hoverState = "out", c.options.delay && c.options.delay.hide ? void(c.timeout = setTimeout(function () {
| + | |
− | "out" == c.hoverState && c.hide()
| + | |
− | }, c.options.delay.hide)) : c.hide())
| + | |
− | }, c.prototype.show = function () {
| + | |
− | var b = a.Event("show.bs." + this.type);
| + | |
− | if (this.hasContent() && this.enabled) {
| + | |
− | this.$element.trigger(b);
| + | |
− | var d = a.contains(this.$element[0].ownerDocument.documentElement, this.$element[0]);
| + | |
− | if (b.isDefaultPrevented() || !d) return;
| + | |
− | var e = this,
| + | |
− | f = this.tip(),
| + | |
− | g = this.getUID(this.type);
| + | |
− | this.setContent(), f.attr("id", g), this.$element.attr("aria-describedby", g), this.options.animation && f.addClass("fade");
| + | |
− | var h = "function" == typeof this.options.placement ? this.options.placement.call(this, f[0], this.$element[0]) : this.options.placement,
| + | |
− | i = /\s?auto?\s?/i,
| + | |
− | j = i.test(h);
| + | |
− | j && (h = h.replace(i, "") || "top"), f.detach().css({
| + | |
− | top: 0,
| + | |
− | left: 0,
| + | |
− | display: "block"
| + | |
− | }).addClass(h).data("bs." + this.type, this), this.options.container ? f.appendTo(this.options.container) : f.insertAfter(this.$element), this.$element.trigger("inserted.bs." + this.type);
| + | |
− | var k = this.getPosition(),
| + | |
− | l = f[0].offsetWidth,
| + | |
− | m = f[0].offsetHeight;
| + | |
− | if (j) {
| + | |
− | var n = h,
| + | |
− | o = this.getPosition(this.$viewport);
| + | |
− | h = "bottom" == h && k.bottom + m > o.bottom ? "top" : "top" == h && k.top - m < o.top ? "bottom" : "right" == h && k.right + l > o.width ? "left" : "left" == h && k.left - l < o.left ? "right" : h, f.removeClass(n).addClass(h)
| + | |
− | }
| + | |
− | var p = this.getCalculatedOffset(h, k, l, m);
| + | |
− | this.applyPlacement(p, h);
| + | |
− | var q = function () {
| + | |
− | var a = e.hoverState;
| + | |
− | e.$element.trigger("shown.bs." + e.type), e.hoverState = null, "out" == a && e.leave(e)
| + | |
− | };
| + | |
− | a.support.transition && this.$tip.hasClass("fade") ? f.one("bsTransitionEnd", q).emulateTransitionEnd(c.TRANSITION_DURATION) : q()
| + | |
− | }
| + | |
− | }, c.prototype.applyPlacement = function (b, c) {
| + | |
− | var d = this.tip(),
| + | |
− | e = d[0].offsetWidth,
| + | |
− | f = d[0].offsetHeight,
| + | |
− | g = parseInt(d.css("margin-top"), 10),
| + | |
− | h = parseInt(d.css("margin-left"), 10);
| + | |
− | isNaN(g) && (g = 0), isNaN(h) && (h = 0), b.top += g, b.left += h, a.offset.setOffset(d[0], a.extend({
| + | |
− | using: function (a) {
| + | |
− | d.css({
| + | |
− | top: Math.round(a.top),
| + | |
− | left: Math.round(a.left)
| + | |
− | })
| + | |
− | }
| + | |
− | }, b), 0), d.addClass("in");
| + | |
− | var i = d[0].offsetWidth,
| + | |
− | j = d[0].offsetHeight;
| + | |
− | "top" == c && j != f && (b.top = b.top + f - j);
| + | |
− | var k = this.getViewportAdjustedDelta(c, b, i, j);
| + | |
− | k.left ? b.left += k.left : b.top += k.top;
| + | |
− | var l = /top|bottom/.test(c),
| + | |
− | m = l ? 2 * k.left - e + i : 2 * k.top - f + j,
| + | |
− | n = l ? "offsetWidth" : "offsetHeight";
| + | |
− | d.offset(b), this.replaceArrow(m, d[0][n], l)
| + | |
− | }, c.prototype.replaceArrow = function (a, b, c) {
| + | |
− | this.arrow().css(c ? "left" : "top", 50 * (1 - a / b) + "%").css(c ? "top" : "left", "")
| + | |
− | }, c.prototype.setContent = function () {
| + | |
− | var a = this.tip(),
| + | |
− | b = this.getTitle();
| + | |
− | a.find(".tooltip-inner")[this.options.html ? "html" : "text"](b), a.removeClass("fade in top bottom left right")
| + | |
− | }, c.prototype.hide = function (b) {
| + | |
− | function d() {
| + | |
− | "in" != e.hoverState && f.detach(), e.$element.removeAttr("aria-describedby").trigger("hidden.bs." + e.type), b && b()
| + | |
− | }
| + | |
− | var e = this,
| + | |
− | f = a(this.$tip),
| + | |
− | g = a.Event("hide.bs." + this.type);
| + | |
− | return this.$element.trigger(g), g.isDefaultPrevented() ? void 0 : (f.removeClass("in"), a.support.transition && f.hasClass("fade") ? f.one("bsTransitionEnd", d).emulateTransitionEnd(c.TRANSITION_DURATION) : d(), this.hoverState = null, this)
| + | |
− | }, c.prototype.fixTitle = function () {
| + | |
− | var a = this.$element;
| + | |
− | (a.attr("title") || "string" != typeof a.attr("data-original-title")) && a.attr("data-original-title", a.attr("title") || "").attr("title", "")
| + | |
− | }, c.prototype.hasContent = function () {
| + | |
− | return this.getTitle()
| + | |
− | }, c.prototype.getPosition = function (b) {
| + | |
− | b = b || this.$element;
| + | |
− | var c = b[0],
| + | |
− | d = "BODY" == c.tagName,
| + | |
− | e = c.getBoundingClientRect();
| + | |
− | null == e.width && (e = a.extend({}, e, {
| + | |
− | width: e.right - e.left,
| + | |
− | height: e.bottom - e.top
| + | |
− | }));
| + | |
− | var f = d ? {
| + | |
− | top: 0,
| + | |
− | left: 0
| + | |
− | } : b.offset(),
| + | |
− | g = {
| + | |
− | scroll: d ? document.documentElement.scrollTop || document.body.scrollTop : b.scrollTop()
| + | |
− | },
| + | |
− | h = d ? {
| + | |
− | width: a(window).width(),
| + | |
− | height: a(window).height()
| + | |
− | } : null;
| + | |
− | return a.extend({}, e, g, h, f)
| + | |
− | }, c.prototype.getCalculatedOffset = function (a, b, c, d) {
| + | |
− | return "bottom" == a ? {
| + | |
− | top: b.top + b.height,
| + | |
− | left: b.left + b.width / 2 - c / 2
| + | |
− | } : "top" == a ? {
| + | |
− | top: b.top - d,
| + | |
− | left: b.left + b.width / 2 - c / 2
| + | |
− | } : "left" == a ? {
| + | |
− | top: b.top + b.height / 2 - d / 2,
| + | |
− | left: b.left - c
| + | |
− | } : {
| + | |
− | top: b.top + b.height / 2 - d / 2,
| + | |
− | left: b.left + b.width
| + | |
− | }
| + | |
− | }, c.prototype.getViewportAdjustedDelta = function (a, b, c, d) {
| + | |
− | var e = {
| + | |
− | top: 0,
| + | |
− | left: 0
| + | |
− | };
| + | |
− | if (!this.$viewport) return e;
| + | |
− | var f = this.options.viewport && this.options.viewport.padding || 0,
| + | |
− | g = this.getPosition(this.$viewport);
| + | |
− | if (/right|left/.test(a)) {
| + | |
− | var h = b.top - f - g.scroll,
| + | |
− | i = b.top + f - g.scroll + d;
| + | |
− | h < g.top ? e.top = g.top - h : i > g.top + g.height && (e.top = g.top + g.height - i)
| + | |
− | } else {
| + | |
− | var j = b.left - f,
| + | |
− | k = b.left + f + c;
| + | |
− | j < g.left ? e.left = g.left - j : k > g.right && (e.left = g.left + g.width - k)
| + | |
− | }
| + | |
− | return e
| + | |
− | }, c.prototype.getTitle = function () {
| + | |
− | var a, b = this.$element,
| + | |
− | c = this.options;
| + | |
− | return a = b.attr("data-original-title") || ("function" == typeof c.title ? c.title.call(b[0]) : c.title)
| + | |
− | }, c.prototype.getUID = function (a) {
| + | |
− | do a += ~~(1e6 * Math.random()); while (document.getElementById(a));
| + | |
− | return a
| + | |
− | }, c.prototype.tip = function () {
| + | |
− | if (!this.$tip && (this.$tip = a(this.options.template), 1 != this.$tip.length)) throw new Error(this.type + " `template` option must consist of exactly 1 top-level element!");
| + | |
− | return this.$tip
| + | |
− | }, c.prototype.arrow = function () {
| + | |
− | return this.$arrow = this.$arrow || this.tip().find(".tooltip-arrow")
| + | |
− | }, c.prototype.enable = function () {
| + | |
− | this.enabled = !0
| + | |
− | }, c.prototype.disable = function () {
| + | |
− | this.enabled = !1
| + | |
− | }, c.prototype.toggleEnabled = function () {
| + | |
− | this.enabled = !this.enabled
| + | |
− | }, c.prototype.toggle = function (b) {
| + | |
− | var c = this;
| + | |
− | b && (c = a(b.currentTarget).data("bs." + this.type), c || (c = new this.constructor(b.currentTarget, this.getDelegateOptions()), a(b.currentTarget).data("bs." + this.type, c))), b ? (c.inState.click = !c.inState.click, c.isInStateTrue() ? c.enter(c) : c.leave(c)) : c.tip().hasClass("in") ? c.leave(c) : c.enter(c)
| + | |
− | }, c.prototype.destroy = function () {
| + | |
− | var a = this;
| + | |
− | clearTimeout(this.timeout), this.hide(function () {
| + | |
− | a.$element.off("." + a.type).removeData("bs." + a.type), a.$tip && a.$tip.detach(), a.$tip = null, a.$arrow = null, a.$viewport = null
| + | |
− | })
| + | |
− | };
| + | |
− | var d = a.fn.tooltip;
| + | |
− | a.fn.tooltip = b, a.fn.tooltip.Constructor = c, a.fn.tooltip.noConflict = function () {
| + | |
− | return a.fn.tooltip = d, this
| + | |
− | }
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | return this.each(function () {
| + | |
− | var d = a(this),
| + | |
− | e = d.data("bs.popover"),
| + | |
− | f = "object" == typeof b && b;
| + | |
− | (e || !/destroy|hide/.test(b)) && (e || d.data("bs.popover", e = new c(this, f)), "string" == typeof b && e[b]())
| + | |
− | })
| + | |
− | }
| + | |
− | var c = function (a, b) {
| + | |
− | this.init("popover", a, b)
| + | |
− | };
| + | |
− | if (!a.fn.tooltip) throw new Error("Popover requires tooltip.js");
| + | |
− | c.VERSION = "3.3.5", c.DEFAULTS = a.extend({}, a.fn.tooltip.Constructor.DEFAULTS, {
| + | |
− | placement: "right",
| + | |
− | trigger: "click",
| + | |
− | content: "",
| + | |
− | template: '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
| + | |
− | }), c.prototype = a.extend({}, a.fn.tooltip.Constructor.prototype), c.prototype.constructor = c, c.prototype.getDefaults = function () {
| + | |
− | return c.DEFAULTS
| + | |
− | }, c.prototype.setContent = function () {
| + | |
− | var a = this.tip(),
| + | |
− | b = this.getTitle(),
| + | |
− | c = this.getContent();
| + | |
− | a.find(".popover-title")[this.options.html ? "html" : "text"](b), a.find(".popover-content").children().detach().end()[this.options.html ? "string" == typeof c ? "html" : "append" : "text"](c), a.removeClass("fade top bottom left right in"), a.find(".popover-title").html() || a.find(".popover-title").hide()
| + | |
− | }, c.prototype.hasContent = function () {
| + | |
− | return this.getTitle() || this.getContent()
| + | |
− | }, c.prototype.getContent = function () {
| + | |
− | var a = this.$element,
| + | |
− | b = this.options;
| + | |
− | return a.attr("data-content") || ("function" == typeof b.content ? b.content.call(a[0]) : b.content)
| + | |
− | }, c.prototype.arrow = function () {
| + | |
− | return this.$arrow = this.$arrow || this.tip().find(".arrow")
| + | |
− | };
| + | |
− | var d = a.fn.popover;
| + | |
− | a.fn.popover = b, a.fn.popover.Constructor = c, a.fn.popover.noConflict = function () {
| + | |
− | return a.fn.popover = d, this
| + | |
− | }
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(c, d) {
| + | |
− | this.$body = a(document.body), this.$scrollElement = a(a(c).is(document.body) ? window : c), this.options = a.extend({}, b.DEFAULTS, d), this.selector = (this.options.target || "") + " .nav li > a", this.offsets = [], this.targets = [], this.activeTarget = null, this.scrollHeight = 0, this.$scrollElement.on("scroll.bs.scrollspy", a.proxy(this.process, this)), this.refresh(), this.process()
| + | |
− | }
| + | |
− | | + | |
− | function c(c) {
| + | |
− | return this.each(function () {
| + | |
− | var d = a(this),
| + | |
− | e = d.data("bs.scrollspy"),
| + | |
− | f = "object" == typeof c && c;
| + | |
− | e || d.data("bs.scrollspy", e = new b(this, f)), "string" == typeof c && e[c]()
| + | |
− | })
| + | |
− | }
| + | |
− | b.VERSION = "3.3.5", b.DEFAULTS = {
| + | |
− | offset: 10
| + | |
− | }, b.prototype.getScrollHeight = function () {
| + | |
− | return this.$scrollElement[0].scrollHeight || Math.max(this.$body[0].scrollHeight, document.documentElement.scrollHeight)
| + | |
− | }, b.prototype.refresh = function () {
| + | |
− | var b = this,
| + | |
− | c = "offset",
| + | |
− | d = 0;
| + | |
− | this.offsets = [], this.targets = [], this.scrollHeight = this.getScrollHeight(), a.isWindow(this.$scrollElement[0]) || (c = "position", d = this.$scrollElement.scrollTop()), this.$body.find(this.selector).map(function () {
| + | |
− | var b = a(this),
| + | |
− | e = b.data("target") || b.attr("href"),
| + | |
− | f = /^#./.test(e) && a(e);
| + | |
− | return f && f.length && f.is(":visible") && [
| + | |
− | [f[c]().top + d, e]
| + | |
− | ] || null
| + | |
− | }).sort(function (a, b) {
| + | |
− | return a[0] - b[0]
| + | |
− | }).each(function () {
| + | |
− | b.offsets.push(this[0]), b.targets.push(this[1])
| + | |
− | })
| + | |
− | }, b.prototype.process = function () {
| + | |
− | var a, b = this.$scrollElement.scrollTop() + this.options.offset,
| + | |
− | c = this.getScrollHeight(),
| + | |
− | d = this.options.offset + c - this.$scrollElement.height(),
| + | |
− | e = this.offsets,
| + | |
− | f = this.targets,
| + | |
− | g = this.activeTarget;
| + | |
− | if (this.scrollHeight != c && this.refresh(), b >= d) return g != (a = f[f.length - 1]) && this.activate(a);
| + | |
− | if (g && b < e[0]) return this.activeTarget = null, this.clear();
| + | |
− | for (a = e.length; a--;) g != f[a] && b >= e[a] && (void 0 === e[a + 1] || b < e[a + 1]) && this.activate(f[a])
| + | |
− | }, b.prototype.activate = function (b) {
| + | |
− | this.activeTarget = b, this.clear();
| + | |
− | var c = this.selector + '[data-target="' + b + '"],' + this.selector + '[href="' + b + '"]',
| + | |
− | d = a(c).parents("li").addClass("active");
| + | |
− | d.parent(".dropdown-menu").length && (d = d.closest("li.dropdown").addClass("active")),
| + | |
− | d.trigger("activate.bs.scrollspy")
| + | |
− | }, b.prototype.clear = function () {
| + | |
− | a(this.selector).parentsUntil(this.options.target, ".active").removeClass("active")
| + | |
− | };
| + | |
− | var d = a.fn.scrollspy;
| + | |
− | a.fn.scrollspy = c, a.fn.scrollspy.Constructor = b, a.fn.scrollspy.noConflict = function () {
| + | |
− | return a.fn.scrollspy = d, this
| + | |
− | }, a(window).on("load.bs.scrollspy.data-api", function () {
| + | |
− | a('[data-spy="scroll"]').each(function () {
| + | |
− | var b = a(this);
| + | |
− | c.call(b, b.data())
| + | |
− | })
| + | |
− | })
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | return this.each(function () {
| + | |
− | var d = a(this),
| + | |
− | e = d.data("bs.tab");
| + | |
− | e || d.data("bs.tab", e = new c(this)), "string" == typeof b && e[b]()
| + | |
− | })
| + | |
− | }
| + | |
− | var c = function (b) {
| + | |
− | this.element = a(b)
| + | |
− | };
| + | |
− | c.VERSION = "3.3.5", c.TRANSITION_DURATION = 150, c.prototype.show = function () {
| + | |
− | var b = this.element,
| + | |
− | c = b.closest("ul:not(.dropdown-menu)"),
| + | |
− | d = b.data("target");
| + | |
− | if (d || (d = b.attr("href"), d = d && d.replace(/.*(?=#[^\s]*$)/, "")), !b.parent("li").hasClass("active")) {
| + | |
− | var e = c.find(".active:last a"),
| + | |
− | f = a.Event("hide.bs.tab", {
| + | |
− | relatedTarget: b[0]
| + | |
− | }),
| + | |
− | g = a.Event("show.bs.tab", {
| + | |
− | relatedTarget: e[0]
| + | |
− | });
| + | |
− | if (e.trigger(f), b.trigger(g), !g.isDefaultPrevented() && !f.isDefaultPrevented()) {
| + | |
− | var h = a(d);
| + | |
− | this.activate(b.closest("li"), c), this.activate(h, h.parent(), function () {
| + | |
− | e.trigger({
| + | |
− | type: "hidden.bs.tab",
| + | |
− | relatedTarget: b[0]
| + | |
− | }), b.trigger({
| + | |
− | type: "shown.bs.tab",
| + | |
− | relatedTarget: e[0]
| + | |
− | })
| + | |
− | })
| + | |
− | }
| + | |
− | }
| + | |
− | }, c.prototype.activate = function (b, d, e) {
| + | |
− | function f() {
| + | |
− | g.removeClass("active").find("> .dropdown-menu > .active").removeClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded", !1), b.addClass("active").find('[data-toggle="tab"]').attr("aria-expanded", !0), h ? (b[0].offsetWidth, b.addClass("in")) : b.removeClass("fade"), b.parent(".dropdown-menu").length && b.closest("li.dropdown").addClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded", !0), e && e()
| + | |
− | }
| + | |
− | var g = d.find("> .active"),
| + | |
− | h = e && a.support.transition && (g.length && g.hasClass("fade") || !!d.find("> .fade").length);
| + | |
− | g.length && h ? g.one("bsTransitionEnd", f).emulateTransitionEnd(c.TRANSITION_DURATION) : f(), g.removeClass("in")
| + | |
− | };
| + | |
− | var d = a.fn.tab;
| + | |
− | a.fn.tab = b, a.fn.tab.Constructor = c, a.fn.tab.noConflict = function () {
| + | |
− | return a.fn.tab = d, this
| + | |
− | };
| + | |
− | var e = function (c) {
| + | |
− | c.preventDefault(), b.call(a(this), "show")
| + | |
− | };
| + | |
− | a(document).on("click.bs.tab.data-api", '[data-toggle="tab"]', e).on("click.bs.tab.data-api", '[data-toggle="pill"]', e)
| + | |
− | }(jQuery), + function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b(b) {
| + | |
− | return this.each(function () {
| + | |
− | var d = a(this),
| + | |
− | e = d.data("bs.affix"),
| + | |
− | f = "object" == typeof b && b;
| + | |
− | e || d.data("bs.affix", e = new c(this, f)), "string" == typeof b && e[b]()
| + | |
− | })
| + | |
− | }
| + | |
− | var c = function (b, d) {
| + | |
− | this.options = a.extend({}, c.DEFAULTS, d), this.$target = a(this.options.target).on("scroll.bs.affix.data-api", a.proxy(this.checkPosition, this)).on("click.bs.affix.data-api", a.proxy(this.checkPositionWithEventLoop, this)), this.$element = a(b), this.affixed = null, this.unpin = null, this.pinnedOffset = null, this.checkPosition()
| + | |
− | };
| + | |
− | c.VERSION = "3.3.5", c.RESET = "affix affix-top affix-bottom", c.DEFAULTS = {
| + | |
− | offset: 0,
| + | |
− | target: window
| + | |
− | }, c.prototype.getState = function (a, b, c, d) {
| + | |
− | var e = this.$target.scrollTop(),
| + | |
− | f = this.$element.offset(),
| + | |
− | g = this.$target.height();
| + | |
− | if (null != c && "top" == this.affixed) return c > e ? "top" : !1;
| + | |
− | if ("bottom" == this.affixed) return null != c ? e + this.unpin <= f.top ? !1 : "bottom" : a - d >= e + g ? !1 : "bottom";
| + | |
− | var h = null == this.affixed,
| + | |
− | i = h ? e : f.top,
| + | |
− | j = h ? g : b;
| + | |
− | return null != c && c >= e ? "top" : null != d && i + j >= a - d ? "bottom" : !1
| + | |
− | }, c.prototype.getPinnedOffset = function () {
| + | |
− | if (this.pinnedOffset) return this.pinnedOffset;
| + | |
− | this.$element.removeClass(c.RESET).addClass("affix");
| + | |
− | var a = this.$target.scrollTop(),
| + | |
− | b = this.$element.offset();
| + | |
− | return this.pinnedOffset = b.top - a
| + | |
− | }, c.prototype.checkPositionWithEventLoop = function () {
| + | |
− | setTimeout(a.proxy(this.checkPosition, this), 1)
| + | |
− | }, c.prototype.checkPosition = function () {
| + | |
− | if (this.$element.is(":visible")) {
| + | |
− | var b = this.$element.height(),
| + | |
− | d = this.options.offset,
| + | |
− | e = d.top,
| + | |
− | f = d.bottom,
| + | |
− | g = Math.max(a(document).height(), a(document.body).height());
| + | |
− | "object" != typeof d && (f = e = d), "function" == typeof e && (e = d.top(this.$element)), "function" == typeof f && (f = d.bottom(this.$element));
| + | |
− | var h = this.getState(g, b, e, f);
| + | |
− | if (this.affixed != h) {
| + | |
− | null != this.unpin && this.$element.css("top", "");
| + | |
− | var i = "affix" + (h ? "-" + h : ""),
| + | |
− | j = a.Event(i + ".bs.affix");
| + | |
− | if (this.$element.trigger(j), j.isDefaultPrevented()) return;
| + | |
− | this.affixed = h, this.unpin = "bottom" == h ? this.getPinnedOffset() : null, this.$element.removeClass(c.RESET).addClass(i).trigger(i.replace("affix", "affixed") + ".bs.affix")
| + | |
− | }
| + | |
− | "bottom" == h && this.$element.offset({
| + | |
− | top: g - b - f
| + | |
− | })
| + | |
− | }
| + | |
− | };
| + | |
− | var d = a.fn.affix;
| + | |
− | a.fn.affix = b, a.fn.affix.Constructor = c, a.fn.affix.noConflict = function () {
| + | |
− | return a.fn.affix = d, this
| + | |
− | }, a(window).on("load", function () {
| + | |
− | a('[data-spy="affix"]').each(function () {
| + | |
− | var c = a(this),
| + | |
− | d = c.data();
| + | |
− | d.offset = d.offset || {}, null != d.offsetBottom && (d.offset.bottom = d.offsetBottom), null != d.offsetTop && (d.offset.top = d.offsetTop), b.call(c, d)
| + | |
− | })
| + | |
− | })
| + | |
− | }(jQuery);
| + | |
− | | + | |
− | </script>
| + | |
− | | + | |
− | <script>
| + | |
− | /*
| + | |
− | HTML5 Shiv v3.7.0 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
| + | |
− | */
| + | |
− | (function (l, f) {
| + | |
− | function m() {
| + | |
− | var a = e.elements;
| + | |
− | return "string" == typeof a ? a.split(" ") : a
| + | |
− | }
| + | |
− | | + | |
− | function i(a) {
| + | |
− | var b = n[a[o]];
| + | |
− | b || (b = {}, h++, a[o] = h, n[h] = b);
| + | |
− | return b
| + | |
− | }
| + | |
− | | + | |
− | function p(a, b, c) {
| + | |
− | b || (b = f);
| + | |
− | if (g) return b.createElement(a);
| + | |
− | c || (c = i(b));
| + | |
− | b = c.cache[a] ? c.cache[a].cloneNode() : r.test(a) ? (c.cache[a] = c.createElem(a)).cloneNode() : c.createElem(a);
| + | |
− | return b.canHaveChildren && !s.test(a) ? c.frag.appendChild(b) : b
| + | |
− | }
| + | |
− | | + | |
− | function t(a, b) {
| + | |
− | if (!b.cache) b.cache = {}, b.createElem = a.createElement, b.createFrag = a.createDocumentFragment, b.frag = b.createFrag();
| + | |
− | a.createElement = function (c) {
| + | |
− | return !e.shivMethods ? b.createElem(c) : p(c, a, b)
| + | |
− | };
| + | |
− | a.createDocumentFragment = Function("h,f", "return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&(" + m().join().replace(/[\w\-]+/g, function (a) {
| + | |
− | b.createElem(a);
| + | |
− | b.frag.createElement(a);
| + | |
− | return 'c("' + a + '")'
| + | |
− | }) + ");return n}")(e, b.frag)
| + | |
− | }
| + | |
− | | + | |
− | function q(a) {
| + | |
− | a || (a = f);
| + | |
− | var b = i(a);
| + | |
− | if (e.shivCSS && !j && !b.hasCSS) {
| + | |
− | var c, d = a;
| + | |
− | c = d.createElement("p");
| + | |
− | d = d.getElementsByTagName("head")[0] || d.documentElement;
| + | |
− | c.innerHTML = "x<style>article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}</style>";
| + | |
− | c = d.insertBefore(c.lastChild, d.firstChild);
| + | |
− | b.hasCSS = !!c
| + | |
− | }
| + | |
− | g || t(a, b);
| + | |
− | return a
| + | |
− | }
| + | |
− | var k = l.html5 || {},
| + | |
− | s = /^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,
| + | |
− | r = /^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,
| + | |
− | j, o = "_html5shiv",
| + | |
− | h = 0,
| + | |
− | n = {},
| + | |
− | g;
| + | |
− | (function () {
| + | |
− | try {
| + | |
− | var a = f.createElement("a");
| + | |
− | a.innerHTML = "<xyz></xyz>";
| + | |
− | j = "hidden" in a;
| + | |
− | var b;
| + | |
− | if (!(b = 1 == a.childNodes.length)) {
| + | |
− | f.createElement("a");
| + | |
− | var c = f.createDocumentFragment();
| + | |
− | b = "undefined" == typeof c.cloneNode ||
| + | |
− | "undefined" == typeof c.createDocumentFragment || "undefined" == typeof c.createElement
| + | |
− | }
| + | |
− | g = b
| + | |
− | } catch (d) {
| + | |
− | g = j = !0
| + | |
− | }
| + | |
− | })();
| + | |
− | var e = {
| + | |
− | elements: k.elements || "abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output progress section summary template time video",
| + | |
− | version: "3.7.0",
| + | |
− | shivCSS: !1 !== k.shivCSS,
| + | |
− | supportsUnknownElements: g,
| + | |
− | shivMethods: !1 !== k.shivMethods,
| + | |
− | type: "default",
| + | |
− | shivDocument: q,
| + | |
− | createElement: p,
| + | |
− | createDocumentFragment: function (a, b) {
| + | |
− | a || (a = f);
| + | |
− | if (g) return a.createDocumentFragment();
| + | |
− | for (var b = b || i(a), c = b.frag.cloneNode(), d = 0, e = m(), h = e.length; d < h; d++) c.createElement(e[d]);
| + | |
− | return c
| + | |
− | }
| + | |
− | };
| + | |
− | l.html5 = e;
| + | |
− | q(f)
| + | |
− | })(this, document);
| + | |
− | | + | |
− | </script>
| + | |
− | | + | |
− | <script>
| + | |
− | !function(t,e){"function"==typeof define&&define.amd?define("jquery-bridget/jquery-bridget",["jquery"],function(i){return e(t,i)}):"object"==typeof module&&module.exports?module.exports=e(t,require("jquery")):t.jQueryBridget=e(t,t.jQuery)}(window,function(t,e){"use strict";function i(i,s,a){function u(t,e,o){var n,s="$()."+i+'("'+e+'")';return t.each(function(t,u){var h=a.data(u,i);if(!h)return void r(i+" not initialized. Cannot call methods, i.e. "+s);var d=h[e];if(!d||"_"==e.charAt(0))return void r(s+" is not a valid method");var l=d.apply(h,o);n=void 0===n?l:n}),void 0!==n?n:t}function h(t,e){t.each(function(t,o){var n=a.data(o,i);n?(n.option(e),n._init()):(n=new s(o,e),a.data(o,i,n))})}a=a||e||t.jQuery,a&&(s.prototype.option||(s.prototype.option=function(t){a.isPlainObject(t)&&(this.options=a.extend(!0,this.options,t))}),a.fn[i]=function(t){if("string"==typeof t){var e=n.call(arguments,1);return u(this,t,e)}return h(this,t),this},o(a))}function o(t){!t||t&&t.bridget||(t.bridget=i)}var n=Array.prototype.slice,s=t.console,r="undefined"==typeof s?function(){}:function(t){s.error(t)};return o(e||t.jQuery),i}),function(t,e){"function"==typeof define&&define.amd?define("ev-emitter/ev-emitter",e):"object"==typeof module&&module.exports?module.exports=e():t.EvEmitter=e()}("undefined"!=typeof window?window:this,function(){function t(){}var e=t.prototype;return e.on=function(t,e){if(t&&e){var i=this._events=this._events||{},o=i[t]=i[t]||[];return o.indexOf(e)==-1&&o.push(e),this}},e.once=function(t,e){if(t&&e){this.on(t,e);var i=this._onceEvents=this._onceEvents||{},o=i[t]=i[t]||{};return o[e]=!0,this}},e.off=function(t,e){var i=this._events&&this._events[t];if(i&&i.length){var o=i.indexOf(e);return o!=-1&&i.splice(o,1),this}},e.emitEvent=function(t,e){var i=this._events&&this._events[t];if(i&&i.length){var o=0,n=i[o];e=e||[];for(var s=this._onceEvents&&this._onceEvents[t];n;){var r=s&&s[n];r&&(this.off(t,n),delete s[n]),n.apply(this,e),o+=r?0:1,n=i[o]}return this}},t}),function(t,e){"use strict";"function"==typeof define&&define.amd?define("get-size/get-size",[],function(){return e()}):"object"==typeof module&&module.exports?module.exports=e():t.getSize=e()}(window,function(){"use strict";function t(t){var e=parseFloat(t),i=t.indexOf("%")==-1&&!isNaN(e);return i&&e}function e(){}function i(){for(var t={width:0,height:0,innerWidth:0,innerHeight:0,outerWidth:0,outerHeight:0},e=0;e<h;e++){var i=u[e];t[i]=0}return t}function o(t){var e=getComputedStyle(t);return e||a("Style returned "+e+". Are you running this code in a hidden iframe on Firefox? See http://bit.ly/getsizebug1"),e}function n(){if(!d){d=!0;var e=document.createElement("div");e.style.width="200px",e.style.padding="1px 2px 3px 4px",e.style.borderStyle="solid",e.style.borderWidth="1px 2px 3px 4px",e.style.boxSizing="border-box";var i=document.body||document.documentElement;i.appendChild(e);var n=o(e);s.isBoxSizeOuter=r=200==t(n.width),i.removeChild(e)}}function s(e){if(n(),"string"==typeof e&&(e=document.querySelector(e)),e&&"object"==typeof e&&e.nodeType){var s=o(e);if("none"==s.display)return i();var a={};a.width=e.offsetWidth,a.height=e.offsetHeight;for(var d=a.isBorderBox="border-box"==s.boxSizing,l=0;l<h;l++){var f=u[l],c=s[f],m=parseFloat(c);a[f]=isNaN(m)?0:m}var p=a.paddingLeft+a.paddingRight,y=a.paddingTop+a.paddingBottom,g=a.marginLeft+a.marginRight,v=a.marginTop+a.marginBottom,_=a.borderLeftWidth+a.borderRightWidth,I=a.borderTopWidth+a.borderBottomWidth,z=d&&r,x=t(s.width);x!==!1&&(a.width=x+(z?0:p+_));var S=t(s.height);return S!==!1&&(a.height=S+(z?0:y+I)),a.innerWidth=a.width-(p+_),a.innerHeight=a.height-(y+I),a.outerWidth=a.width+g,a.outerHeight=a.height+v,a}}var r,a="undefined"==typeof console?e:function(t){console.error(t)},u=["paddingLeft","paddingRight","paddingTop","paddingBottom","marginLeft","marginRight","marginTop","marginBottom","borderLeftWidth","borderRightWidth","borderTopWidth","borderBottomWidth"],h=u.length,d=!1;return s}),function(t,e){"use strict";"function"==typeof define&&define.amd?define("desandro-matches-selector/matches-selector",e):"object"==typeof module&&module.exports?module.exports=e():t.matchesSelector=e()}(window,function(){"use strict";var t=function(){var t=window.Element.prototype;if(t.matches)return"matches";if(t.matchesSelector)return"matchesSelector";for(var e=["webkit","moz","ms","o"],i=0;i<e.length;i++){var o=e[i],n=o+"MatchesSelector";if(t[n])return n}}();return function(e,i){return e[t](i)}}),function(t,e){"function"==typeof define&&define.amd?define("fizzy-ui-utils/utils",["desandro-matches-selector/matches-selector"],function(i){return e(t,i)}):"object"==typeof module&&module.exports?module.exports=e(t,require("desandro-matches-selector")):t.fizzyUIUtils=e(t,t.matchesSelector)}(window,function(t,e){var i={};i.extend=function(t,e){for(var i in e)t[i]=e[i];return t},i.modulo=function(t,e){return(t%e+e)%e},i.makeArray=function(t){var e=[];if(Array.isArray(t))e=t;else if(t&&"object"==typeof t&&"number"==typeof t.length)for(var i=0;i<t.length;i++)e.push(t[i]);else e.push(t);return e},i.removeFrom=function(t,e){var i=t.indexOf(e);i!=-1&&t.splice(i,1)},i.getParent=function(t,i){for(;t.parentNode&&t!=document.body;)if(t=t.parentNode,e(t,i))return t},i.getQueryElement=function(t){return"string"==typeof t?document.querySelector(t):t},i.handleEvent=function(t){var e="on"+t.type;this[e]&&this[e](t)},i.filterFindElements=function(t,o){t=i.makeArray(t);var n=[];return t.forEach(function(t){if(t instanceof HTMLElement){if(!o)return void n.push(t);e(t,o)&&n.push(t);for(var i=t.querySelectorAll(o),s=0;s<i.length;s++)n.push(i[s])}}),n},i.debounceMethod=function(t,e,i){var o=t.prototype[e],n=e+"Timeout";t.prototype[e]=function(){var t=this[n];t&&clearTimeout(t);var e=arguments,s=this;this[n]=setTimeout(function(){o.apply(s,e),delete s[n]},i||100)}},i.docReady=function(t){var e=document.readyState;"complete"==e||"interactive"==e?setTimeout(t):document.addEventListener("DOMContentLoaded",t)},i.toDashed=function(t){return t.replace(/(.)([A-Z])/g,function(t,e,i){return e+"-"+i}).toLowerCase()};var o=t.console;return i.htmlInit=function(e,n){i.docReady(function(){var s=i.toDashed(n),r="data-"+s,a=document.querySelectorAll("["+r+"]"),u=document.querySelectorAll(".js-"+s),h=i.makeArray(a).concat(i.makeArray(u)),d=r+"-options",l=t.jQuery;h.forEach(function(t){var i,s=t.getAttribute(r)||t.getAttribute(d);try{i=s&&JSON.parse(s)}catch(a){return void(o&&o.error("Error parsing "+r+" on "+t.className+": "+a))}var u=new e(t,i);l&&l.data(t,n,u)})})},i}),function(t,e){"function"==typeof define&&define.amd?define("outlayer/item",["ev-emitter/ev-emitter","get-size/get-size"],e):"object"==typeof module&&module.exports?module.exports=e(require("ev-emitter"),require("get-size")):(t.Outlayer={},t.Outlayer.Item=e(t.EvEmitter,t.getSize))}(window,function(t,e){"use strict";function i(t){for(var e in t)return!1;return e=null,!0}function o(t,e){t&&(this.element=t,this.layout=e,this.position={x:0,y:0},this._create())}function n(t){return t.replace(/([A-Z])/g,function(t){return"-"+t.toLowerCase()})}var s=document.documentElement.style,r="string"==typeof s.transition?"transition":"WebkitTransition",a="string"==typeof s.transform?"transform":"WebkitTransform",u={WebkitTransition:"webkitTransitionEnd",transition:"transitionend"}[r],h={transform:a,transition:r,transitionDuration:r+"Duration",transitionProperty:r+"Property",transitionDelay:r+"Delay"},d=o.prototype=Object.create(t.prototype);d.constructor=o,d._create=function(){this._transn={ingProperties:{},clean:{},onEnd:{}},this.css({position:"absolute"})},d.handleEvent=function(t){var e="on"+t.type;this[e]&&this[e](t)},d.getSize=function(){this.size=e(this.element)},d.css=function(t){var e=this.element.style;for(var i in t){var o=h[i]||i;e[o]=t[i]}},d.getPosition=function(){var t=getComputedStyle(this.element),e=this.layout._getOption("originLeft"),i=this.layout._getOption("originTop"),o=t[e?"left":"right"],n=t[i?"top":"bottom"],s=this.layout.size,r=o.indexOf("%")!=-1?parseFloat(o)/100*s.width:parseInt(o,10),a=n.indexOf("%")!=-1?parseFloat(n)/100*s.height:parseInt(n,10);r=isNaN(r)?0:r,a=isNaN(a)?0:a,r-=e?s.paddingLeft:s.paddingRight,a-=i?s.paddingTop:s.paddingBottom,this.position.x=r,this.position.y=a},d.layoutPosition=function(){var t=this.layout.size,e={},i=this.layout._getOption("originLeft"),o=this.layout._getOption("originTop"),n=i?"paddingLeft":"paddingRight",s=i?"left":"right",r=i?"right":"left",a=this.position.x+t[n];e[s]=this.getXValue(a),e[r]="";var u=o?"paddingTop":"paddingBottom",h=o?"top":"bottom",d=o?"bottom":"top",l=this.position.y+t[u];e[h]=this.getYValue(l),e[d]="",this.css(e),this.emitEvent("layout",[this])},d.getXValue=function(t){var e=this.layout._getOption("horizontal");return this.layout.options.percentPosition&&!e?t/this.layout.size.width*100+"%":t+"px"},d.getYValue=function(t){var e=this.layout._getOption("horizontal");return this.layout.options.percentPosition&&e?t/this.layout.size.height*100+"%":t+"px"},d._transitionTo=function(t,e){this.getPosition();var i=this.position.x,o=this.position.y,n=parseInt(t,10),s=parseInt(e,10),r=n===this.position.x&&s===this.position.y;if(this.setPosition(t,e),r&&!this.isTransitioning)return void this.layoutPosition();var a=t-i,u=e-o,h={};h.transform=this.getTranslate(a,u),this.transition({to:h,onTransitionEnd:{transform:this.layoutPosition},isCleaning:!0})},d.getTranslate=function(t,e){var i=this.layout._getOption("originLeft"),o=this.layout._getOption("originTop");return t=i?t:-t,e=o?e:-e,"translate3d("+t+"px, "+e+"px, 0)"},d.goTo=function(t,e){this.setPosition(t,e),this.layoutPosition()},d.moveTo=d._transitionTo,d.setPosition=function(t,e){this.position.x=parseInt(t,10),this.position.y=parseInt(e,10)},d._nonTransition=function(t){this.css(t.to),t.isCleaning&&this._removeStyles(t.to);for(var e in t.onTransitionEnd)t.onTransitionEnd[e].call(this)},d.transition=function(t){if(!parseFloat(this.layout.options.transitionDuration))return void this._nonTransition(t);var e=this._transn;for(var i in t.onTransitionEnd)e.onEnd[i]=t.onTransitionEnd[i];for(i in t.to)e.ingProperties[i]=!0,t.isCleaning&&(e.clean[i]=!0);if(t.from){this.css(t.from);var o=this.element.offsetHeight;o=null}this.enableTransition(t.to),this.css(t.to),this.isTransitioning=!0};var l="opacity,"+n(a);d.enableTransition=function(){if(!this.isTransitioning){var t=this.layout.options.transitionDuration;t="number"==typeof t?t+"ms":t,this.css({transitionProperty:l,transitionDuration:t,transitionDelay:this.staggerDelay||0}),this.element.addEventListener(u,this,!1)}},d.onwebkitTransitionEnd=function(t){this.ontransitionend(t)},d.onotransitionend=function(t){this.ontransitionend(t)};var f={"-webkit-transform":"transform"};d.ontransitionend=function(t){if(t.target===this.element){var e=this._transn,o=f[t.propertyName]||t.propertyName;if(delete e.ingProperties[o],i(e.ingProperties)&&this.disableTransition(),o in e.clean&&(this.element.style[t.propertyName]="",delete e.clean[o]),o in e.onEnd){var n=e.onEnd[o];n.call(this),delete e.onEnd[o]}this.emitEvent("transitionEnd",[this])}},d.disableTransition=function(){this.removeTransitionStyles(),this.element.removeEventListener(u,this,!1),this.isTransitioning=!1},d._removeStyles=function(t){var e={};for(var i in t)e[i]="";this.css(e)};var c={transitionProperty:"",transitionDuration:"",transitionDelay:""};return d.removeTransitionStyles=function(){this.css(c)},d.stagger=function(t){t=isNaN(t)?0:t,this.staggerDelay=t+"ms"},d.removeElem=function(){this.element.parentNode.removeChild(this.element),this.css({display:""}),this.emitEvent("remove",[this])},d.remove=function(){return r&&parseFloat(this.layout.options.transitionDuration)?(this.once("transitionEnd",function(){this.removeElem()}),void this.hide()):void this.removeElem()},d.reveal=function(){delete this.isHidden,this.css({display:""});var t=this.layout.options,e={},i=this.getHideRevealTransitionEndProperty("visibleStyle");e[i]=this.onRevealTransitionEnd,this.transition({from:t.hiddenStyle,to:t.visibleStyle,isCleaning:!0,onTransitionEnd:e})},d.onRevealTransitionEnd=function(){this.isHidden||this.emitEvent("reveal")},d.getHideRevealTransitionEndProperty=function(t){var e=this.layout.options[t];if(e.opacity)return"opacity";for(var i in e)return i},d.hide=function(){this.isHidden=!0,this.css({display:""});var t=this.layout.options,e={},i=this.getHideRevealTransitionEndProperty("hiddenStyle");e[i]=this.onHideTransitionEnd,this.transition({from:t.visibleStyle,to:t.hiddenStyle,isCleaning:!0,onTransitionEnd:e})},d.onHideTransitionEnd=function(){this.isHidden&&(this.css({display:"none"}),this.emitEvent("hide"))},d.destroy=function(){this.css({position:"",left:"",right:"",top:"",bottom:"",transition:"",transform:""})},o}),function(t,e){"use strict";"function"==typeof define&&define.amd?define("outlayer/outlayer",["ev-emitter/ev-emitter","get-size/get-size","fizzy-ui-utils/utils","./item"],function(i,o,n,s){return e(t,i,o,n,s)}):"object"==typeof module&&module.exports?module.exports=e(t,require("ev-emitter"),require("get-size"),require("fizzy-ui-utils"),require("./item")):t.Outlayer=e(t,t.EvEmitter,t.getSize,t.fizzyUIUtils,t.Outlayer.Item)}(window,function(t,e,i,o,n){"use strict";function s(t,e){var i=o.getQueryElement(t);if(!i)return void(u&&u.error("Bad element for "+this.constructor.namespace+": "+(i||t)));this.element=i,h&&(this.$element=h(this.element)),this.options=o.extend({},this.constructor.defaults),this.option(e);var n=++l;this.element.outlayerGUID=n,f[n]=this,this._create();var s=this._getOption("initLayout");s&&this.layout()}function r(t){function e(){t.apply(this,arguments)}return e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e}function a(t){if("number"==typeof t)return t;var e=t.match(/(^\d*\.?\d*)(\w*)/),i=e&&e[1],o=e&&e[2];if(!i.length)return 0;i=parseFloat(i);var n=m[o]||1;return i*n}var u=t.console,h=t.jQuery,d=function(){},l=0,f={};s.namespace="outlayer",s.Item=n,s.defaults={containerStyle:{position:"relative"},initLayout:!0,originLeft:!0,originTop:!0,resize:!0,resizeContainer:!0,transitionDuration:"0.4s",hiddenStyle:{opacity:0,transform:"scale(0.001)"},visibleStyle:{opacity:1,transform:"scale(1)"}};var c=s.prototype;o.extend(c,e.prototype),c.option=function(t){o.extend(this.options,t)},c._getOption=function(t){var e=this.constructor.compatOptions[t];return e&&void 0!==this.options[e]?this.options[e]:this.options[t]},s.compatOptions={initLayout:"isInitLayout",horizontal:"isHorizontal",layoutInstant:"isLayoutInstant",originLeft:"isOriginLeft",originTop:"isOriginTop",resize:"isResizeBound",resizeContainer:"isResizingContainer"},c._create=function(){this.reloadItems(),this.stamps=[],this.stamp(this.options.stamp),o.extend(this.element.style,this.options.containerStyle);var t=this._getOption("resize");t&&this.bindResize()},c.reloadItems=function(){this.items=this._itemize(this.element.children)},c._itemize=function(t){for(var e=this._filterFindItemElements(t),i=this.constructor.Item,o=[],n=0;n<e.length;n++){var s=e[n],r=new i(s,this);o.push(r)}return o},c._filterFindItemElements=function(t){return o.filterFindElements(t,this.options.itemSelector)},c.getItemElements=function(){return this.items.map(function(t){return t.element})},c.layout=function(){this._resetLayout(),this._manageStamps();var t=this._getOption("layoutInstant"),e=void 0!==t?t:!this._isLayoutInited;this.layoutItems(this.items,e),this._isLayoutInited=!0},c._init=c.layout,c._resetLayout=function(){this.getSize()},c.getSize=function(){this.size=i(this.element)},c._getMeasurement=function(t,e){var o,n=this.options[t];n?("string"==typeof n?o=this.element.querySelector(n):n instanceof HTMLElement&&(o=n),this[t]=o?i(o)[e]:n):this[t]=0},c.layoutItems=function(t,e){t=this._getItemsForLayout(t),this._layoutItems(t,e),this._postLayout()},c._getItemsForLayout=function(t){return t.filter(function(t){return!t.isIgnored})},c._layoutItems=function(t,e){if(this._emitCompleteOnItems("layout",t),t&&t.length){var i=[];t.forEach(function(t){var o=this._getItemLayoutPosition(t);o.item=t,o.isInstant=e||t.isLayoutInstant,i.push(o)},this),this._processLayoutQueue(i)}},c._getItemLayoutPosition=function(){return{x:0,y:0}},c._processLayoutQueue=function(t){this.updateStagger(),t.forEach(function(t,e){this._positionItem(t.item,t.x,t.y,t.isInstant,e)},this)},c.updateStagger=function(){var t=this.options.stagger;return null===t||void 0===t?void(this.stagger=0):(this.stagger=a(t),this.stagger)},c._positionItem=function(t,e,i,o,n){o?t.goTo(e,i):(t.stagger(n*this.stagger),t.moveTo(e,i))},c._postLayout=function(){this.resizeContainer()},c.resizeContainer=function(){var t=this._getOption("resizeContainer");if(t){var e=this._getContainerSize();e&&(this._setContainerMeasure(e.width,!0),this._setContainerMeasure(e.height,!1))}},c._getContainerSize=d,c._setContainerMeasure=function(t,e){if(void 0!==t){var i=this.size;i.isBorderBox&&(t+=e?i.paddingLeft+i.paddingRight+i.borderLeftWidth+i.borderRightWidth:i.paddingBottom+i.paddingTop+i.borderTopWidth+i.borderBottomWidth),t=Math.max(t,0),this.element.style[e?"width":"height"]=t+"px"}},c._emitCompleteOnItems=function(t,e){function i(){n.dispatchEvent(t+"Complete",null,[e])}function o(){r++,r==s&&i()}var n=this,s=e.length;if(!e||!s)return void i();var r=0;e.forEach(function(e){e.once(t,o)})},c.dispatchEvent=function(t,e,i){var o=e?[e].concat(i):i;if(this.emitEvent(t,o),h)if(this.$element=this.$element||h(this.element),e){var n=h.Event(e);n.type=t,this.$element.trigger(n,i)}else this.$element.trigger(t,i)},c.ignore=function(t){var e=this.getItem(t);e&&(e.isIgnored=!0)},c.unignore=function(t){var e=this.getItem(t);e&&delete e.isIgnored},c.stamp=function(t){t=this._find(t),t&&(this.stamps=this.stamps.concat(t),t.forEach(this.ignore,this))},c.unstamp=function(t){t=this._find(t),t&&t.forEach(function(t){o.removeFrom(this.stamps,t),this.unignore(t)},this)},c._find=function(t){if(t)return"string"==typeof t&&(t=this.element.querySelectorAll(t)),t=o.makeArray(t)},c._manageStamps=function(){this.stamps&&this.stamps.length&&(this._getBoundingRect(),this.stamps.forEach(this._manageStamp,this))},c._getBoundingRect=function(){var t=this.element.getBoundingClientRect(),e=this.size;this._boundingRect={left:t.left+e.paddingLeft+e.borderLeftWidth,top:t.top+e.paddingTop+e.borderTopWidth,right:t.right-(e.paddingRight+e.borderRightWidth),bottom:t.bottom-(e.paddingBottom+e.borderBottomWidth)}},c._manageStamp=d,c._getElementOffset=function(t){var e=t.getBoundingClientRect(),o=this._boundingRect,n=i(t),s={left:e.left-o.left-n.marginLeft,top:e.top-o.top-n.marginTop,right:o.right-e.right-n.marginRight,bottom:o.bottom-e.bottom-n.marginBottom};return s},c.handleEvent=o.handleEvent,c.bindResize=function(){t.addEventListener("resize",this),this.isResizeBound=!0},c.unbindResize=function(){t.removeEventListener("resize",this),this.isResizeBound=!1},c.onresize=function(){this.resize()},o.debounceMethod(s,"onresize",100),c.resize=function(){this.isResizeBound&&this.needsResizeLayout()&&this.layout()},c.needsResizeLayout=function(){var t=i(this.element),e=this.size&&t;return e&&t.innerWidth!==this.size.innerWidth},c.addItems=function(t){var e=this._itemize(t);return e.length&&(this.items=this.items.concat(e)),e},c.appended=function(t){var e=this.addItems(t);e.length&&(this.layoutItems(e,!0),this.reveal(e))},c.prepended=function(t){var e=this._itemize(t);if(e.length){var i=this.items.slice(0);this.items=e.concat(i),this._resetLayout(),this._manageStamps(),this.layoutItems(e,!0),this.reveal(e),this.layoutItems(i)}},c.reveal=function(t){if(this._emitCompleteOnItems("reveal",t),t&&t.length){var e=this.updateStagger();t.forEach(function(t,i){t.stagger(i*e),t.reveal()})}},c.hide=function(t){if(this._emitCompleteOnItems("hide",t),t&&t.length){var e=this.updateStagger();t.forEach(function(t,i){t.stagger(i*e),t.hide()})}},c.revealItemElements=function(t){var e=this.getItems(t);this.reveal(e)},c.hideItemElements=function(t){var e=this.getItems(t);this.hide(e)},c.getItem=function(t){for(var e=0;e<this.items.length;e++){var i=this.items[e];if(i.element==t)return i}},c.getItems=function(t){t=o.makeArray(t);var e=[];return t.forEach(function(t){var i=this.getItem(t);i&&e.push(i)},this),e},c.remove=function(t){var e=this.getItems(t);this._emitCompleteOnItems("remove",e),e&&e.length&&e.forEach(function(t){t.remove(),o.removeFrom(this.items,t)},this)},c.destroy=function(){var t=this.element.style;t.height="",t.position="",t.width="",this.items.forEach(function(t){t.destroy()}),this.unbindResize();var e=this.element.outlayerGUID;delete f[e],delete this.element.outlayerGUID,h&&h.removeData(this.element,this.constructor.namespace)},s.data=function(t){t=o.getQueryElement(t);var e=t&&t.outlayerGUID;return e&&f[e]},s.create=function(t,e){var i=r(s);return i.defaults=o.extend({},s.defaults),o.extend(i.defaults,e),i.compatOptions=o.extend({},s.compatOptions),i.namespace=t,i.data=s.data,i.Item=r(n),o.htmlInit(i,t),h&&h.bridget&&h.bridget(t,i),i};var m={ms:1,s:1e3};return s.Item=n,s}),function(t,e){"function"==typeof define&&define.amd?define("isotope/js/item",["outlayer/outlayer"],e):"object"==typeof module&&module.exports?module.exports=e(require("outlayer")):(t.Isotope=t.Isotope||{},t.Isotope.Item=e(t.Outlayer))}(window,function(t){"use strict";function e(){t.Item.apply(this,arguments)}var i=e.prototype=Object.create(t.Item.prototype),o=i._create;i._create=function(){this.id=this.layout.itemGUID++,o.call(this),this.sortData={}},i.updateSortData=function(){if(!this.isIgnored){this.sortData.id=this.id,this.sortData["original-order"]=this.id,this.sortData.random=Math.random();var t=this.layout.options.getSortData,e=this.layout._sorters;for(var i in t){var o=e[i];this.sortData[i]=o(this.element,this)}}};var n=i.destroy;return i.destroy=function(){n.apply(this,arguments),this.css({display:""})},e}),function(t,e){"function"==typeof define&&define.amd?define("isotope/js/layout-mode",["get-size/get-size","outlayer/outlayer"],e):"object"==typeof module&&module.exports?module.exports=e(require("get-size"),require("outlayer")):(t.Isotope=t.Isotope||{},t.Isotope.LayoutMode=e(t.getSize,t.Outlayer))}(window,function(t,e){"use strict";function i(t){this.isotope=t,t&&(this.options=t.options[this.namespace],this.element=t.element,this.items=t.filteredItems,this.size=t.size)}var o=i.prototype,n=["_resetLayout","_getItemLayoutPosition","_manageStamp","_getContainerSize","_getElementOffset","needsResizeLayout","_getOption"];return n.forEach(function(t){o[t]=function(){return e.prototype[t].apply(this.isotope,arguments)}}),o.needsVerticalResizeLayout=function(){var e=t(this.isotope.element),i=this.isotope.size&&e;return i&&e.innerHeight!=this.isotope.size.innerHeight},o._getMeasurement=function(){this.isotope._getMeasurement.apply(this,arguments)},o.getColumnWidth=function(){this.getSegmentSize("column","Width")},o.getRowHeight=function(){this.getSegmentSize("row","Height")},o.getSegmentSize=function(t,e){var i=t+e,o="outer"+e;if(this._getMeasurement(i,o),!this[i]){var n=this.getFirstItemSize();this[i]=n&&n[o]||this.isotope.size["inner"+e]}},o.getFirstItemSize=function(){var e=this.isotope.filteredItems[0];return e&&e.element&&t(e.element)},o.layout=function(){this.isotope.layout.apply(this.isotope,arguments)},o.getSize=function(){this.isotope.getSize(),this.size=this.isotope.size},i.modes={},i.create=function(t,e){function n(){i.apply(this,arguments)}return n.prototype=Object.create(o),n.prototype.constructor=n,e&&(n.options=e),n.prototype.namespace=t,i.modes[t]=n,n},i}),function(t,e){"function"==typeof define&&define.amd?define("masonry/masonry",["outlayer/outlayer","get-size/get-size"],e):"object"==typeof module&&module.exports?module.exports=e(require("outlayer"),require("get-size")):t.Masonry=e(t.Outlayer,t.getSize)}(window,function(t,e){var i=t.create("masonry");i.compatOptions.fitWidth="isFitWidth";var o=i.prototype;return o._resetLayout=function(){this.getSize(),this._getMeasurement("columnWidth","outerWidth"),this._getMeasurement("gutter","outerWidth"),this.measureColumns(),this.colYs=[];for(var t=0;t<this.cols;t++)this.colYs.push(0);this.maxY=0,this.horizontalColIndex=0},o.measureColumns=function(){if(this.getContainerWidth(),!this.columnWidth){var t=this.items[0],i=t&&t.element;this.columnWidth=i&&e(i).outerWidth||this.containerWidth}var o=this.columnWidth+=this.gutter,n=this.containerWidth+this.gutter,s=n/o,r=o-n%o,a=r&&r<1?"round":"floor";s=Math[a](s),this.cols=Math.max(s,1)},o.getContainerWidth=function(){var t=this._getOption("fitWidth"),i=t?this.element.parentNode:this.element,o=e(i);this.containerWidth=o&&o.innerWidth},o._getItemLayoutPosition=function(t){t.getSize();var e=t.size.outerWidth%this.columnWidth,i=e&&e<1?"round":"ceil",o=Math[i](t.size.outerWidth/this.columnWidth);o=Math.min(o,this.cols);for(var n=this.options.horizontalOrder?"_getHorizontalColPosition":"_getTopColPosition",s=this[n](o,t),r={x:this.columnWidth*s.col,y:s.y},a=s.y+t.size.outerHeight,u=o+s.col,h=s.col;h<u;h++)this.colYs[h]=a;return r},o._getTopColPosition=function(t){var e=this._getTopColGroup(t),i=Math.min.apply(Math,e);return{col:e.indexOf(i),y:i}},o._getTopColGroup=function(t){if(t<2)return this.colYs;for(var e=[],i=this.cols+1-t,o=0;o<i;o++)e[o]=this._getColGroupY(o,t);return e},o._getColGroupY=function(t,e){if(e<2)return this.colYs[t];var i=this.colYs.slice(t,t+e);return Math.max.apply(Math,i)},o._getHorizontalColPosition=function(t,e){var i=this.horizontalColIndex%this.cols,o=t>1&&i+t>this.cols;i=o?0:i;var n=e.size.outerWidth&&e.size.outerHeight;return this.horizontalColIndex=n?i+t:this.horizontalColIndex,{col:i,y:this._getColGroupY(i,t)}},o._manageStamp=function(t){var i=e(t),o=this._getElementOffset(t),n=this._getOption("originLeft"),s=n?o.left:o.right,r=s+i.outerWidth,a=Math.floor(s/this.columnWidth);a=Math.max(0,a);var u=Math.floor(r/this.columnWidth);u-=r%this.columnWidth?0:1,u=Math.min(this.cols-1,u);for(var h=this._getOption("originTop"),d=(h?o.top:o.bottom)+i.outerHeight,l=a;l<=u;l++)this.colYs[l]=Math.max(d,this.colYs[l])},o._getContainerSize=function(){this.maxY=Math.max.apply(Math,this.colYs);var t={height:this.maxY};return this._getOption("fitWidth")&&(t.width=this._getContainerFitWidth()),t},o._getContainerFitWidth=function(){for(var t=0,e=this.cols;--e&&0===this.colYs[e];)t++;return(this.cols-t)*this.columnWidth-this.gutter},o.needsResizeLayout=function(){var t=this.containerWidth;return this.getContainerWidth(),t!=this.containerWidth},i}),function(t,e){"function"==typeof define&&define.amd?define("isotope/js/layout-modes/masonry",["../layout-mode","masonry/masonry"],e):"object"==typeof module&&module.exports?module.exports=e(require("../layout-mode"),require("masonry-layout")):e(t.Isotope.LayoutMode,t.Masonry)}(window,function(t,e){"use strict";var i=t.create("masonry"),o=i.prototype,n={_getElementOffset:!0,layout:!0,_getMeasurement:!0};for(var s in e.prototype)n[s]||(o[s]=e.prototype[s]);var r=o.measureColumns;o.measureColumns=function(){this.items=this.isotope.filteredItems,r.call(this)};var a=o._getOption;return o._getOption=function(t){return"fitWidth"==t?void 0!==this.options.isFitWidth?this.options.isFitWidth:this.options.fitWidth:a.apply(this.isotope,arguments)},i}),function(t,e){"function"==typeof define&&define.amd?define("isotope/js/layout-modes/fit-rows",["../layout-mode"],e):"object"==typeof exports?module.exports=e(require("../layout-mode")):e(t.Isotope.LayoutMode)}(window,function(t){"use strict";var e=t.create("fitRows"),i=e.prototype;return i._resetLayout=function(){this.x=0,this.y=0,this.maxY=0,this._getMeasurement("gutter","outerWidth")},i._getItemLayoutPosition=function(t){t.getSize();var e=t.size.outerWidth+this.gutter,i=this.isotope.size.innerWidth+this.gutter;0!==this.x&&e+this.x>i&&(this.x=0,this.y=this.maxY);var o={x:this.x,y:this.y};return this.maxY=Math.max(this.maxY,this.y+t.size.outerHeight),this.x+=e,o},i._getContainerSize=function(){return{height:this.maxY}},e}),function(t,e){"function"==typeof define&&define.amd?define("isotope/js/layout-modes/vertical",["../layout-mode"],e):"object"==typeof module&&module.exports?module.exports=e(require("../layout-mode")):e(t.Isotope.LayoutMode)}(window,function(t){"use strict";var e=t.create("vertical",{horizontalAlignment:0}),i=e.prototype;return i._resetLayout=function(){this.y=0},i._getItemLayoutPosition=function(t){t.getSize();var e=(this.isotope.size.innerWidth-t.size.outerWidth)*this.options.horizontalAlignment,i=this.y;return this.y+=t.size.outerHeight,{x:e,y:i}},i._getContainerSize=function(){return{height:this.y}},e}),function(t,e){"function"==typeof define&&define.amd?define(["outlayer/outlayer","get-size/get-size","desandro-matches-selector/matches-selector","fizzy-ui-utils/utils","isotope/js/item","isotope/js/layout-mode","isotope/js/layout-modes/masonry","isotope/js/layout-modes/fit-rows","isotope/js/layout-modes/vertical"],function(i,o,n,s,r,a){return e(t,i,o,n,s,r,a)}):"object"==typeof module&&module.exports?module.exports=e(t,require("outlayer"),require("get-size"),require("desandro-matches-selector"),require("fizzy-ui-utils"),require("isotope/js/item"),require("isotope/js/layout-mode"),require("isotope/js/layout-modes/masonry"),require("isotope/js/layout-modes/fit-rows"),require("isotope/js/layout-modes/vertical")):t.Isotope=e(t,t.Outlayer,t.getSize,t.matchesSelector,t.fizzyUIUtils,t.Isotope.Item,t.Isotope.LayoutMode)}(window,function(t,e,i,o,n,s,r){function a(t,e){return function(i,o){for(var n=0;n<t.length;n++){var s=t[n],r=i.sortData[s],a=o.sortData[s];if(r>a||r<a){var u=void 0!==e[s]?e[s]:e,h=u?1:-1;return(r>a?1:-1)*h}}return 0}}var u=t.jQuery,h=String.prototype.trim?function(t){return t.trim()}:function(t){return t.replace(/^\s+|\s+$/g,"")},d=e.create("isotope",{layoutMode:"masonry",isJQueryFiltering:!0,sortAscending:!0});d.Item=s,d.LayoutMode=r;var l=d.prototype;l._create=function(){this.itemGUID=0,this._sorters={},this._getSorters(),e.prototype._create.call(this),this.modes={},this.filteredItems=this.items,this.sortHistory=["original-order"];for(var t in r.modes)this._initLayoutMode(t)},l.reloadItems=function(){this.itemGUID=0,e.prototype.reloadItems.call(this)},l._itemize=function(){for(var t=e.prototype._itemize.apply(this,arguments),i=0;i<t.length;i++){var o=t[i];o.id=this.itemGUID++}return this._updateItemsSortData(t),t},l._initLayoutMode=function(t){var e=r.modes[t],i=this.options[t]||{};this.options[t]=e.options?n.extend(e.options,i):i,this.modes[t]=new e(this)},l.layout=function(){return!this._isLayoutInited&&this._getOption("initLayout")?void this.arrange():void this._layout()},l._layout=function(){var t=this._getIsInstant();this._resetLayout(),this._manageStamps(),this.layoutItems(this.filteredItems,t),this._isLayoutInited=!0},l.arrange=function(t){this.option(t),this._getIsInstant();var e=this._filter(this.items);this.filteredItems=e.matches,this._bindArrangeComplete(),this._isInstant?this._noTransition(this._hideReveal,[e]):this._hideReveal(e),this._sort(),this._layout()},l._init=l.arrange,l._hideReveal=function(t){this.reveal(t.needReveal),this.hide(t.needHide)},l._getIsInstant=function(){var t=this._getOption("layoutInstant"),e=void 0!==t?t:!this._isLayoutInited;return this._isInstant=e,e},l._bindArrangeComplete=function(){function t(){e&&i&&o&&n.dispatchEvent("arrangeComplete",null,[n.filteredItems])}var e,i,o,n=this;this.once("layoutComplete",function(){e=!0,t()}),this.once("hideComplete",function(){i=!0,t()}),this.once("revealComplete",function(){o=!0,t()})},l._filter=function(t){var e=this.options.filter;e=e||"*";for(var i=[],o=[],n=[],s=this._getFilterTest(e),r=0;r<t.length;r++){var a=t[r];if(!a.isIgnored){var u=s(a);u&&i.push(a),u&&a.isHidden?o.push(a):u||a.isHidden||n.push(a)}}return{matches:i,needReveal:o,needHide:n}},l._getFilterTest=function(t){return u&&this.options.isJQueryFiltering?function(e){return u(e.element).is(t)}:"function"==typeof t?function(e){return t(e.element)}:function(e){return o(e.element,t)}},l.updateSortData=function(t){
| + | |
− | var e;t?(t=n.makeArray(t),e=this.getItems(t)):e=this.items,this._getSorters(),this._updateItemsSortData(e)},l._getSorters=function(){var t=this.options.getSortData;for(var e in t){var i=t[e];this._sorters[e]=f(i)}},l._updateItemsSortData=function(t){for(var e=t&&t.length,i=0;e&&i<e;i++){var o=t[i];o.updateSortData()}};var f=function(){function t(t){if("string"!=typeof t)return t;var i=h(t).split(" "),o=i[0],n=o.match(/^\[(.+)\]$/),s=n&&n[1],r=e(s,o),a=d.sortDataParsers[i[1]];return t=a?function(t){return t&&a(r(t))}:function(t){return t&&r(t)}}function e(t,e){return t?function(e){return e.getAttribute(t)}:function(t){var i=t.querySelector(e);return i&&i.textContent}}return t}();d.sortDataParsers={parseInt:function(t){return parseInt(t,10)},parseFloat:function(t){return parseFloat(t)}},l._sort=function(){if(this.options.sortBy){var t=n.makeArray(this.options.sortBy);this._getIsSameSortBy(t)||(this.sortHistory=t.concat(this.sortHistory));var e=a(this.sortHistory,this.options.sortAscending);this.filteredItems.sort(e)}},l._getIsSameSortBy=function(t){for(var e=0;e<t.length;e++)if(t[e]!=this.sortHistory[e])return!1;return!0},l._mode=function(){var t=this.options.layoutMode,e=this.modes[t];if(!e)throw new Error("No layout mode: "+t);return e.options=this.options[t],e},l._resetLayout=function(){e.prototype._resetLayout.call(this),this._mode()._resetLayout()},l._getItemLayoutPosition=function(t){return this._mode()._getItemLayoutPosition(t)},l._manageStamp=function(t){this._mode()._manageStamp(t)},l._getContainerSize=function(){return this._mode()._getContainerSize()},l.needsResizeLayout=function(){return this._mode().needsResizeLayout()},l.appended=function(t){var e=this.addItems(t);if(e.length){var i=this._filterRevealAdded(e);this.filteredItems=this.filteredItems.concat(i)}},l.prepended=function(t){var e=this._itemize(t);if(e.length){this._resetLayout(),this._manageStamps();var i=this._filterRevealAdded(e);this.layoutItems(this.filteredItems),this.filteredItems=i.concat(this.filteredItems),this.items=e.concat(this.items)}},l._filterRevealAdded=function(t){var e=this._filter(t);return this.hide(e.needHide),this.reveal(e.matches),this.layoutItems(e.matches,!0),e.matches},l.insert=function(t){var e=this.addItems(t);if(e.length){var i,o,n=e.length;for(i=0;i<n;i++)o=e[i],this.element.appendChild(o.element);var s=this._filter(e).matches;for(i=0;i<n;i++)e[i].isLayoutInstant=!0;for(this.arrange(),i=0;i<n;i++)delete e[i].isLayoutInstant;this.reveal(s)}};var c=l.remove;return l.remove=function(t){t=n.makeArray(t);var e=this.getItems(t);c.call(this,t);for(var i=e&&e.length,o=0;i&&o<i;o++){var s=e[o];n.removeFrom(this.filteredItems,s)}},l.shuffle=function(){for(var t=0;t<this.items.length;t++){var e=this.items[t];e.sortData.random=Math.random()}this.options.sortBy="random",this._sort(),this._layout()},l._noTransition=function(t,e){var i=this.options.transitionDuration;this.options.transitionDuration=0;var o=t.apply(this,e);return this.options.transitionDuration=i,o},l.getFilteredItemElements=function(){return this.filteredItems.map(function(t){return t.element})},d});
| + | |
− | </script>
| + | |
− | <script>
| + | |
− | /**
| + | |
− | * Copyright (c) 2007 Ariel Flesler - aflesler<a>gmail<d>com | https://github.com/flesler
| + | |
− | * Licensed under MIT
| + | |
− | * @author Ariel Flesler
| + | |
− | * @version 2.0.0
| + | |
− | */
| + | |
− | ! function (e) {
| + | |
− | "function" == typeof define && define.amd ? define(["jquery"], e) : e(jQuery)
| + | |
− | }(function (e) {
| + | |
− | function t(t, o, n) {
| + | |
− | var i = o.hash.slice(1),
| + | |
− | a = document.getElementById(i) || document.getElementsByName(i)[0];
| + | |
− | if (a) {
| + | |
− | t && t.preventDefault();
| + | |
− | var l = e(n.target);
| + | |
− | if (!(n.lock && l.is(":animated") || n.onBefore && !1 === n.onBefore(t, a, l))) {
| + | |
− | if (n.stop && l.stop(!0), n.hash) {
| + | |
− | var r = a.id === i ? "id" : "name",
| + | |
− | s = e("<a> </a>").attr(r, i).css({
| + | |
− | position: "absolute",
| + | |
− | top: e(window).scrollTop(),
| + | |
− | left: e(window).scrollLeft()
| + | |
− | });
| + | |
− | a[r] = "", e("body").prepend(s), location.hash = o.hash, s.remove(), a[r] = i
| + | |
− | }
| + | |
− | l.scrollTo(a, n).trigger("notify.serialScroll", [a])
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | var o = location.href.replace(/#.*/, ""),
| + | |
− | n = e.localScroll = function (t) {
| + | |
− | e("body").localScroll(t)
| + | |
− | };
| + | |
− | return n.defaults = {
| + | |
− | duration: 1e3,
| + | |
− | axis: "y",
| + | |
− | event: "click",
| + | |
− | stop: !0,
| + | |
− | target: window,
| + | |
− | autoscroll: !0
| + | |
− | }, e.fn.localScroll = function (i) {
| + | |
− | function a() {
| + | |
− | return !!this.href && !!this.hash && this.href.replace(this.hash, "") === o && (!i.filter || e(this).is(i.filter))
| + | |
− | }
| + | |
− | return (i = e.extend({}, n.defaults, i)).autoscroll && i.hash && location.hash && (i.target && window.scrollTo(0, 0), t(0, location, i)), i.lazy ? this.on(i.event, "a,area", function (e) {
| + | |
− | a.call(this) && t(e, this, i)
| + | |
− | }) : this.find("a,area").filter(a).bind(i.event, function (e) {
| + | |
− | t(e, this, i)
| + | |
− | }).end().end()
| + | |
− | }, n.hash = function () {}, n
| + | |
− | });
| + | |
− | | + | |
− | </script>
| + | |
− | <script>
| + | |
− | /**
| + | |
− | * Copyright (c) 2007-2015 Ariel Flesler - aflesler ○ gmail • com | http://flesler.blogspot.com
| + | |
− | * Licensed under MIT
| + | |
− | * @author Ariel Flesler
| + | |
− | * @version 2.1.3
| + | |
− | */
| + | |
− | ;
| + | |
− | (function (f) {
| + | |
− | "use strict";
| + | |
− | "function" === typeof define && define.amd ? define(["jquery"], f) : "undefined" !== typeof module && module.exports ? module.exports = f(require("jquery")) : f(jQuery)
| + | |
− | })(function ($) { | + | |
− | "use strict";
| + | |
− | | + | |
− | function n(a) {
| + | |
− | return !a.nodeName || -1 !== $.inArray(a.nodeName.toLowerCase(), ["iframe", "#document", "html", "body"])
| + | |
− | }
| + | |
− | | + | |
− | function h(a) {
| + | |
− | return $.isFunction(a) || $.isPlainObject(a) ? a : {
| + | |
− | top: a,
| + | |
− | left: a
| + | |
− | }
| + | |
− | }
| + | |
− | var p = $.scrollTo = function (a, d, b) {
| + | |
− | return $(window).scrollTo(a, d, b)
| + | |
− | };
| + | |
− | p.defaults = {
| + | |
− | axis: "xy",
| + | |
− | duration: 0,
| + | |
− | limit: !0
| + | |
− | };
| + | |
− | $.fn.scrollTo = function (a, d, b) {
| + | |
− | "object" === typeof d && (b = d, d = 0);
| + | |
− | "function" === typeof b && (b = {
| + | |
− | onAfter: b
| + | |
− | });
| + | |
− | "max" === a && (a = 9E9);
| + | |
− | b = $.extend({}, p.defaults, b);
| + | |
− | d = d || b.duration;
| + | |
− | var u = b.queue && 1 < b.axis.length;
| + | |
− | u && (d /= 2);
| + | |
− | b.offset = h(b.offset);
| + | |
− | b.over = h(b.over);
| + | |
− | return this.each(function () {
| + | |
− | function k(a) {
| + | |
− | var k = $.extend({}, b, {
| + | |
− | queue: !0,
| + | |
− | duration: d,
| + | |
− | complete: a && function () {
| + | |
− | a.call(q, e, b)
| + | |
− | }
| + | |
− | });
| + | |
− | r.animate(f, k)
| + | |
− | }
| + | |
− | if (null !== a) {
| + | |
− | var l = n(this),
| + | |
− | q = l ? this.contentWindow || window : this,
| + | |
− | r = $(q),
| + | |
− | e = a,
| + | |
− | f = {},
| + | |
− | t;
| + | |
− | switch (typeof e) {
| + | |
− | case "number":
| + | |
− | case "string":
| + | |
− | if (/^([+-]=?)?\d+(\.\d+)?(px|%)?$/.test(e)) {
| + | |
− | e = h(e);
| + | |
− | break
| + | |
− | }
| + | |
− | e = l ? $(e) : $(e, q);
| + | |
− | case "object":
| + | |
− | if (e.length === 0) return;
| + | |
− | if (e.is || e.style) t = (e = $(e)).offset()
| + | |
− | }
| + | |
− | var v = $.isFunction(b.offset) && b.offset(q, e) || b.offset;
| + | |
− | $.each(b.axis.split(""), function (a, c) {
| + | |
− | var d = "x" === c ? "Left" : "Top",
| + | |
− | m = d.toLowerCase(),
| + | |
− | g = "scroll" + d,
| + | |
− | h = r[g](),
| + | |
− | n = p.max(q, c);
| + | |
− | t ? (f[g] = t[m] + (l ? 0 : h - r.offset()[m]), b.margin && (f[g] -= parseInt(e.css("margin" + d), 10) || 0, f[g] -= parseInt(e.css("border" + d + "Width"), 10) || 0), f[g] += v[m] || 0, b.over[m] && (f[g] += e["x" === c ? "width" : "height"]() * b.over[m])) : (d = e[m], f[g] = d.slice && "%" === d.slice(-1) ? parseFloat(d) / 100 * n : d);
| + | |
− | b.limit && /^\d+$/.test(f[g]) && (f[g] = 0 >= f[g] ? 0 : Math.min(f[g], n));
| + | |
− | !a && 1 < b.axis.length && (h === f[g] ? f = {} : u && (k(b.onAfterFirst), f = {}))
| + | |
− | });
| + | |
− | k(b.onAfter)
| + | |
− | }
| + | |
− | })
| + | |
− | };
| + | |
− | p.max = function (a, d) {
| + | |
− | var b = "x" === d ? "Width" : "Height",
| + | |
− | h = "scroll" + b;
| + | |
− | if (!n(a)) return a[h] - $(a)[b.toLowerCase()]();
| + | |
− | var b = "client" + b,
| + | |
− | k = a.ownerDocument || a.document,
| + | |
− | l = k.documentElement,
| + | |
− | k = k.body;
| + | |
− | return Math.max(l[h], k[h]) - Math.min(l[b], k[b])
| + | |
− | };
| + | |
− | $.Tween.propHooks.scrollLeft = $.Tween.propHooks.scrollTop = {
| + | |
− | get: function (a) {
| + | |
− | return $(a.elem)[a.prop]()
| + | |
− | },
| + | |
− | set: function (a) {
| + | |
− | var d = this.get(a);
| + | |
− | if (a.options.interrupt && a._last && a._last !== d) return $(a.elem).stop();
| + | |
− | var b = Math.round(a.now);
| + | |
− | d !== b && ($(a.elem)[a.prop](b), a._last = this.get(a))
| + | |
− | }
| + | |
− | };
| + | |
− | return p
| + | |
− | });
| + | |
− | | + | |
− | </script>
| + | |
− | <script>
| + | |
− | /*! jQuery v3.1.1 | (c) jQuery Foundation | jquery.org/license */ ! function (a, b) {
| + | |
− | "use strict";
| + | |
− | "object" == typeof module && "object" == typeof module.exports ? module.exports = a.document ? b(a, !0) : function (a) {
| + | |
− | if (!a.document) throw new Error("jQuery requires a window with a document");
| + | |
− | return b(a)
| + | |
− | } : b(a)
| + | |
− | }("undefined" != typeof window ? window : this, function (a, b) {
| + | |
− | "use strict";
| + | |
− | var c = [],
| + | |
− | d = a.document,
| + | |
− | e = Object.getPrototypeOf,
| + | |
− | f = c.slice,
| + | |
− | g = c.concat,
| + | |
− | h = c.push,
| + | |
− | i = c.indexOf,
| + | |
− | j = {},
| + | |
− | k = j.toString,
| + | |
− | l = j.hasOwnProperty,
| + | |
− | m = l.toString,
| + | |
− | n = m.call(Object),
| + | |
− | o = {};
| + | |
− | | + | |
− | function p(a, b) {
| + | |
− | b = b || d;
| + | |
− | var c = b.createElement("script");
| + | |
− | c.text = a, b.head.appendChild(c).parentNode.removeChild(c)
| + | |
− | }
| + | |
− | var q = "3.1.1",
| + | |
− | r = function (a, b) {
| + | |
− | return new r.fn.init(a, b)
| + | |
− | },
| + | |
− | s = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
| + | |
− | t = /^-ms-/,
| + | |
− | u = /-([a-z])/g,
| + | |
− | v = function (a, b) {
| + | |
− | return b.toUpperCase()
| + | |
− | };
| + | |
− | r.fn = r.prototype = {
| + | |
− | jquery: q,
| + | |
− | constructor: r,
| + | |
− | length: 0,
| + | |
− | toArray: function () {
| + | |
− | return f.call(this)
| + | |
− | },
| + | |
− | get: function (a) {
| + | |
− | return null == a ? f.call(this) : a < 0 ? this[a + this.length] : this[a]
| + | |
− | },
| + | |
− | pushStack: function (a) {
| + | |
− | var b = r.merge(this.constructor(), a);
| + | |
− | return b.prevObject = this, b
| + | |
− | },
| + | |
− | each: function (a) {
| + | |
− | return r.each(this, a)
| + | |
− | },
| + | |
− | map: function (a) {
| + | |
− | return this.pushStack(r.map(this, function (b, c) {
| + | |
− | return a.call(b, c, b)
| + | |
− | }))
| + | |
− | },
| + | |
− | slice: function () {
| + | |
− | return this.pushStack(f.apply(this, arguments))
| + | |
− | },
| + | |
− | first: function () {
| + | |
− | return this.eq(0)
| + | |
− | },
| + | |
− | last: function () {
| + | |
− | return this.eq(-1)
| + | |
− | },
| + | |
− | eq: function (a) {
| + | |
− | var b = this.length,
| + | |
− | c = +a + (a < 0 ? b : 0);
| + | |
− | return this.pushStack(c >= 0 && c < b ? [this[c]] : [])
| + | |
− | },
| + | |
− | end: function () {
| + | |
− | return this.prevObject || this.constructor()
| + | |
− | },
| + | |
− | push: h,
| + | |
− | sort: c.sort,
| + | |
− | splice: c.splice
| + | |
− | }, r.extend = r.fn.extend = function () {
| + | |
− | var a, b, c, d, e, f, g = arguments[0] || {},
| + | |
− | h = 1,
| + | |
− | i = arguments.length,
| + | |
− | j = !1;
| + | |
− | for ("boolean" == typeof g && (j = g, g = arguments[h] || {}, h++), "object" == typeof g || r.isFunction(g) || (g = {}), h === i && (g = this, h--); h < i; h++)
| + | |
− | if (null != (a = arguments[h]))
| + | |
− | for (b in a) c = g[b], d = a[b], g !== d && (j && d && (r.isPlainObject(d) || (e = r.isArray(d))) ? (e ? (e = !1, f = c && r.isArray(c) ? c : []) : f = c && r.isPlainObject(c) ? c : {}, g[b] = r.extend(j, f, d)) : void 0 !== d && (g[b] = d));
| + | |
− | return g
| + | |
− | }, r.extend({
| + | |
− | expando: "jQuery" + (q + Math.random()).replace(/\D/g, ""),
| + | |
− | isReady: !0,
| + | |
− | error: function (a) {
| + | |
− | throw new Error(a)
| + | |
− | },
| + | |
− | noop: function () {},
| + | |
− | isFunction: function (a) {
| + | |
− | return "function" === r.type(a)
| + | |
− | },
| + | |
− | isArray: Array.isArray,
| + | |
− | isWindow: function (a) {
| + | |
− | return null != a && a === a.window
| + | |
− | },
| + | |
− | isNumeric: function (a) {
| + | |
− | var b = r.type(a);
| + | |
− | return ("number" === b || "string" === b) && !isNaN(a - parseFloat(a))
| + | |
− | },
| + | |
− | isPlainObject: function (a) {
| + | |
− | var b, c;
| + | |
− | return !(!a || "[object Object]" !== k.call(a)) && (!(b = e(a)) || (c = l.call(b, "constructor") && b.constructor, "function" == typeof c && m.call(c) === n))
| + | |
− | },
| + | |
− | isEmptyObject: function (a) {
| + | |
− | var b;
| + | |
− | for (b in a) return !1;
| + | |
− | return !0
| + | |
− | },
| + | |
− | type: function (a) {
| + | |
− | return null == a ? a + "" : "object" == typeof a || "function" == typeof a ? j[k.call(a)] || "object" : typeof a
| + | |
− | },
| + | |
− | globalEval: function (a) {
| + | |
− | p(a)
| + | |
− | },
| + | |
− | camelCase: function (a) {
| + | |
− | return a.replace(t, "ms-").replace(u, v)
| + | |
− | },
| + | |
− | nodeName: function (a, b) {
| + | |
− | return a.nodeName && a.nodeName.toLowerCase() === b.toLowerCase()
| + | |
− | },
| + | |
− | each: function (a, b) {
| + | |
− | var c, d = 0;
| + | |
− | if (w(a)) {
| + | |
− | for (c = a.length; d < c; d++)
| + | |
− | if (b.call(a[d], d, a[d]) === !1) break
| + | |
− | } else
| + | |
− | for (d in a)
| + | |
− | if (b.call(a[d], d, a[d]) === !1) break; return a
| + | |
− | },
| + | |
− | trim: function (a) {
| + | |
− | return null == a ? "" : (a + "").replace(s, "")
| + | |
− | },
| + | |
− | makeArray: function (a, b) {
| + | |
− | var c = b || [];
| + | |
− | return null != a && (w(Object(a)) ? r.merge(c, "string" == typeof a ? [a] : a) : h.call(c, a)), c
| + | |
− | },
| + | |
− | inArray: function (a, b, c) {
| + | |
− | return null == b ? -1 : i.call(b, a, c)
| + | |
− | },
| + | |
− | merge: function (a, b) {
| + | |
− | for (var c = +b.length, d = 0, e = a.length; d < c; d++) a[e++] = b[d];
| + | |
− | return a.length = e, a
| + | |
− | },
| + | |
− | grep: function (a, b, c) {
| + | |
− | for (var d, e = [], f = 0, g = a.length, h = !c; f < g; f++) d = !b(a[f], f), d !== h && e.push(a[f]);
| + | |
− | return e
| + | |
− | },
| + | |
− | map: function (a, b, c) {
| + | |
− | var d, e, f = 0,
| + | |
− | h = [];
| + | |
− | if (w(a))
| + | |
− | for (d = a.length; f < d; f++) e = b(a[f], f, c), null != e && h.push(e);
| + | |
− | else
| + | |
− | for (f in a) e = b(a[f], f, c), null != e && h.push(e);
| + | |
− | return g.apply([], h)
| + | |
− | },
| + | |
− | guid: 1,
| + | |
− | proxy: function (a, b) {
| + | |
− | var c, d, e;
| + | |
− | if ("string" == typeof b && (c = a[b], b = a, a = c), r.isFunction(a)) return d = f.call(arguments, 2), e = function () {
| + | |
− | return a.apply(b || this, d.concat(f.call(arguments)))
| + | |
− | }, e.guid = a.guid = a.guid || r.guid++, e
| + | |
− | },
| + | |
− | now: Date.now,
| + | |
− | support: o
| + | |
− | }), "function" == typeof Symbol && (r.fn[Symbol.iterator] = c[Symbol.iterator]), r.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function (a, b) {
| + | |
− | j["[object " + b + "]"] = b.toLowerCase()
| + | |
− | });
| + | |
− | | + | |
− | function w(a) {
| + | |
− | var b = !!a && "length" in a && a.length,
| + | |
− | c = r.type(a);
| + | |
− | return "function" !== c && !r.isWindow(a) && ("array" === c || 0 === b || "number" == typeof b && b > 0 && b - 1 in a)
| + | |
− | }
| + | |
− | var x = function (a) {
| + | |
− | var b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u = "sizzle" + 1 * new Date,
| + | |
− | v = a.document,
| + | |
− | w = 0,
| + | |
− | x = 0,
| + | |
− | y = ha(),
| + | |
− | z = ha(),
| + | |
− | A = ha(),
| + | |
− | B = function (a, b) {
| + | |
− | return a === b && (l = !0), 0
| + | |
− | },
| + | |
− | C = {}.hasOwnProperty,
| + | |
− | D = [],
| + | |
− | E = D.pop,
| + | |
− | F = D.push,
| + | |
− | G = D.push,
| + | |
− | H = D.slice,
| + | |
− | I = function (a, b) {
| + | |
− | for (var c = 0, d = a.length; c < d; c++)
| + | |
− | if (a[c] === b) return c;
| + | |
− | return -1
| + | |
− | },
| + | |
− | J = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
| + | |
− | K = "[\\x20\\t\\r\\n\\f]",
| + | |
− | L = "(?:\\\\.|[\\w-]|[^\0-\\xa0])+",
| + | |
− | M = "\\[" + K + "*(" + L + ")(?:" + K + "*([*^$|!~]?=)" + K + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + L + "))|)" + K + "*\\]",
| + | |
− | N = ":(" + L + ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" + M + ")*)|.*)\\)|)",
| + | |
− | O = new RegExp(K + "+", "g"),
| + | |
− | P = new RegExp("^" + K + "+|((?:^|[^\\\\])(?:\\\\.)*)" + K + "+$", "g"),
| + | |
− | Q = new RegExp("^" + K + "*," + K + "*"),
| + | |
− | R = new RegExp("^" + K + "*([>+~]|" + K + ")" + K + "*"),
| + | |
− | S = new RegExp("=" + K + "*([^\\]'\"]*?)" + K + "*\\]", "g"),
| + | |
− | T = new RegExp(N),
| + | |
− | U = new RegExp("^" + L + "$"),
| + | |
− | V = {
| + | |
− | ID: new RegExp("^#(" + L + ")"),
| + | |
− | CLASS: new RegExp("^\\.(" + L + ")"),
| + | |
− | TAG: new RegExp("^(" + L + "|[*])"),
| + | |
− | ATTR: new RegExp("^" + M),
| + | |
− | PSEUDO: new RegExp("^" + N),
| + | |
− | CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + K + "*(even|odd|(([+-]|)(\\d*)n|)" + K + "*(?:([+-]|)" + K + "*(\\d+)|))" + K + "*\\)|)", "i"),
| + | |
− | bool: new RegExp("^(?:" + J + ")$", "i"),
| + | |
− | needsContext: new RegExp("^" + K + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + K + "*((?:-\\d)?\\d*)" + K + "*\\)|)(?=[^-]|$)", "i")
| + | |
− | },
| + | |
− | W = /^(?:input|select|textarea|button)$/i,
| + | |
− | X = /^h\d$/i,
| + | |
− | Y = /^[^{]+\{\s*\[native \w/,
| + | |
− | Z = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
| + | |
− | $ = /[+~]/,
| + | |
− | _ = new RegExp("\\\\([\\da-f]{1,6}" + K + "?|(" + K + ")|.)", "ig"),
| + | |
− | aa = function (a, b, c) {
| + | |
− | var d = "0x" + b - 65536;
| + | |
− | return d !== d || c ? b : d < 0 ? String.fromCharCode(d + 65536) : String.fromCharCode(d >> 10 | 55296, 1023 & d | 56320)
| + | |
− | },
| + | |
− | ba = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,
| + | |
− | ca = function (a, b) {
| + | |
− | return b ? "\0" === a ? "\ufffd" : a.slice(0, -1) + "\\" + a.charCodeAt(a.length - 1).toString(16) + " " : "\\" + a
| + | |
− | },
| + | |
− | da = function () {
| + | |
− | m()
| + | |
− | },
| + | |
− | ea = ta(function (a) {
| + | |
− | return a.disabled === !0 && ("form" in a || "label" in a)
| + | |
− | }, {
| + | |
− | dir: "parentNode",
| + | |
− | next: "legend"
| + | |
− | });
| + | |
− | try {
| + | |
− | G.apply(D = H.call(v.childNodes), v.childNodes), D[v.childNodes.length].nodeType
| + | |
− | } catch (fa) {
| + | |
− | G = {
| + | |
− | apply: D.length ? function (a, b) {
| + | |
− | F.apply(a, H.call(b))
| + | |
− | } : function (a, b) {
| + | |
− | var c = a.length,
| + | |
− | d = 0;
| + | |
− | while (a[c++] = b[d++]);
| + | |
− | a.length = c - 1
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function ga(a, b, d, e) {
| + | |
− | var f, h, j, k, l, o, r, s = b && b.ownerDocument,
| + | |
− | w = b ? b.nodeType : 9;
| + | |
− | if (d = d || [], "string" != typeof a || !a || 1 !== w && 9 !== w && 11 !== w) return d;
| + | |
− | if (!e && ((b ? b.ownerDocument || b : v) !== n && m(b), b = b || n, p)) {
| + | |
− | if (11 !== w && (l = Z.exec(a)))
| + | |
− | if (f = l[1]) {
| + | |
− | if (9 === w) {
| + | |
− | if (!(j = b.getElementById(f))) return d;
| + | |
− | if (j.id === f) return d.push(j), d
| + | |
− | } else if (s && (j = s.getElementById(f)) && t(b, j) && j.id === f) return d.push(j), d
| + | |
− | } else {
| + | |
− | if (l[2]) return G.apply(d, b.getElementsByTagName(a)), d;
| + | |
− | if ((f = l[3]) && c.getElementsByClassName && b.getElementsByClassName) return G.apply(d, b.getElementsByClassName(f)), d
| + | |
− | }
| + | |
− | if (c.qsa && !A[a + " "] && (!q || !q.test(a))) {
| + | |
− | if (1 !== w) s = b, r = a;
| + | |
− | else if ("object" !== b.nodeName.toLowerCase()) {
| + | |
− | (k = b.getAttribute("id")) ? k = k.replace(ba, ca): b.setAttribute("id", k = u), o = g(a), h = o.length;
| + | |
− | while (h--) o[h] = "#" + k + " " + sa(o[h]);
| + | |
− | r = o.join(","), s = $.test(a) && qa(b.parentNode) || b
| + | |
− | }
| + | |
− | if (r) try {
| + | |
− | return G.apply(d, s.querySelectorAll(r)), d
| + | |
− | } catch (x) {} finally {
| + | |
− | k === u && b.removeAttribute("id")
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | return i(a.replace(P, "$1"), b, d, e)
| + | |
− | }
| + | |
− | | + | |
− | function ha() {
| + | |
− | var a = [];
| + | |
− | | + | |
− | function b(c, e) {
| + | |
− | return a.push(c + " ") > d.cacheLength && delete b[a.shift()], b[c + " "] = e
| + | |
− | }
| + | |
− | return b
| + | |
− | }
| + | |
− | | + | |
− | function ia(a) {
| + | |
− | return a[u] = !0, a
| + | |
− | }
| + | |
− | | + | |
− | function ja(a) {
| + | |
− | var b = n.createElement("fieldset");
| + | |
− | try {
| + | |
− | return !!a(b)
| + | |
− | } catch (c) {
| + | |
− | return !1
| + | |
− | } finally {
| + | |
− | b.parentNode && b.parentNode.removeChild(b), b = null
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function ka(a, b) {
| + | |
− | var c = a.split("|"),
| + | |
− | e = c.length;
| + | |
− | while (e--) d.attrHandle[c[e]] = b
| + | |
− | }
| + | |
− | | + | |
− | function la(a, b) {
| + | |
− | var c = b && a,
| + | |
− | d = c && 1 === a.nodeType && 1 === b.nodeType && a.sourceIndex - b.sourceIndex;
| + | |
− | if (d) return d;
| + | |
− | if (c)
| + | |
− | while (c = c.nextSibling)
| + | |
− | if (c === b) return -1;
| + | |
− | return a ? 1 : -1
| + | |
− | }
| + | |
− | | + | |
− | function ma(a) {
| + | |
− | return function (b) {
| + | |
− | var c = b.nodeName.toLowerCase();
| + | |
− | return "input" === c && b.type === a
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function na(a) {
| + | |
− | return function (b) {
| + | |
− | var c = b.nodeName.toLowerCase();
| + | |
− | return ("input" === c || "button" === c) && b.type === a
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function oa(a) {
| + | |
− | return function (b) {
| + | |
− | return "form" in b ? b.parentNode && b.disabled === !1 ? "label" in b ? "label" in b.parentNode ? b.parentNode.disabled === a : b.disabled === a : b.isDisabled === a || b.isDisabled !== !a && ea(b) === a : b.disabled === a : "label" in b && b.disabled === a
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function pa(a) {
| + | |
− | return ia(function (b) {
| + | |
− | return b = +b, ia(function (c, d) {
| + | |
− | var e, f = a([], c.length, b),
| + | |
− | g = f.length;
| + | |
− | while (g--) c[e = f[g]] && (c[e] = !(d[e] = c[e]))
| + | |
− | })
| + | |
− | })
| + | |
− | }
| + | |
− | | + | |
− | function qa(a) {
| + | |
− | return a && "undefined" != typeof a.getElementsByTagName && a
| + | |
− | }
| + | |
− | c = ga.support = {}, f = ga.isXML = function (a) {
| + | |
− | var b = a && (a.ownerDocument || a).documentElement;
| + | |
− | return !!b && "HTML" !== b.nodeName
| + | |
− | }, m = ga.setDocument = function (a) {
| + | |
− | var b, e, g = a ? a.ownerDocument || a : v;
| + | |
− | return g !== n && 9 === g.nodeType && g.documentElement ? (n = g, o = n.documentElement, p = !f(n), v !== n && (e = n.defaultView) && e.top !== e && (e.addEventListener ? e.addEventListener("unload", da, !1) : e.attachEvent && e.attachEvent("onunload", da)), c.attributes = ja(function (a) {
| + | |
− | return a.className = "i", !a.getAttribute("className")
| + | |
− | }), c.getElementsByTagName = ja(function (a) {
| + | |
− | return a.appendChild(n.createComment("")), !a.getElementsByTagName("*").length
| + | |
− | }), c.getElementsByClassName = Y.test(n.getElementsByClassName), c.getById = ja(function (a) {
| + | |
− | return o.appendChild(a).id = u, !n.getElementsByName || !n.getElementsByName(u).length
| + | |
− | }), c.getById ? (d.filter.ID = function (a) {
| + | |
− | var b = a.replace(_, aa);
| + | |
− | return function (a) {
| + | |
− | return a.getAttribute("id") === b
| + | |
− | }
| + | |
− | }, d.find.ID = function (a, b) {
| + | |
− | if ("undefined" != typeof b.getElementById && p) {
| + | |
− | var c = b.getElementById(a);
| + | |
− | return c ? [c] : []
| + | |
− | }
| + | |
− | }) : (d.filter.ID = function (a) {
| + | |
− | var b = a.replace(_, aa);
| + | |
− | return function (a) {
| + | |
− | var c = "undefined" != typeof a.getAttributeNode && a.getAttributeNode("id");
| + | |
− | return c && c.value === b
| + | |
− | }
| + | |
− | }, d.find.ID = function (a, b) {
| + | |
− | if ("undefined" != typeof b.getElementById && p) {
| + | |
− | var c, d, e, f = b.getElementById(a);
| + | |
− | if (f) {
| + | |
− | if (c = f.getAttributeNode("id"), c && c.value === a) return [f];
| + | |
− | e = b.getElementsByName(a), d = 0;
| + | |
− | while (f = e[d++])
| + | |
− | if (c = f.getAttributeNode("id"), c && c.value === a) return [f]
| + | |
− | }
| + | |
− | return []
| + | |
− | }
| + | |
− | }), d.find.TAG = c.getElementsByTagName ? function (a, b) {
| + | |
− | return "undefined" != typeof b.getElementsByTagName ? b.getElementsByTagName(a) : c.qsa ? b.querySelectorAll(a) : void 0
| + | |
− | } : function (a, b) {
| + | |
− | var c, d = [],
| + | |
− | e = 0,
| + | |
− | f = b.getElementsByTagName(a);
| + | |
− | if ("*" === a) {
| + | |
− | while (c = f[e++]) 1 === c.nodeType && d.push(c);
| + | |
− | return d
| + | |
− | }
| + | |
− | return f
| + | |
− | }, d.find.CLASS = c.getElementsByClassName && function (a, b) {
| + | |
− | if ("undefined" != typeof b.getElementsByClassName && p) return b.getElementsByClassName(a)
| + | |
− | }, r = [], q = [], (c.qsa = Y.test(n.querySelectorAll)) && (ja(function (a) {
| + | |
− | o.appendChild(a).innerHTML = "<a id='" + u + "'></a><select id='" + u + "-\r\\' msallowcapture=''><option selected=''></option></select>", a.querySelectorAll("[msallowcapture^='']").length && q.push("[*^$]=" + K + "*(?:''|\"\")"), a.querySelectorAll("[selected]").length || q.push("\\[" + K + "*(?:value|" + J + ")"), a.querySelectorAll("[id~=" + u + "-]").length || q.push("~="), a.querySelectorAll(":checked").length || q.push(":checked"), a.querySelectorAll("a#" + u + "+*").length || q.push(".#.+[+~]")
| + | |
− | }), ja(function (a) {
| + | |
− | a.innerHTML = "<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";
| + | |
− | var b = n.createElement("input");
| + | |
− | b.setAttribute("type", "hidden"), a.appendChild(b).setAttribute("name", "D"), a.querySelectorAll("[name=d]").length && q.push("name" + K + "*[*^$|!~]?="), 2 !== a.querySelectorAll(":enabled").length && q.push(":enabled", ":disabled"), o.appendChild(a).disabled = !0, 2 !== a.querySelectorAll(":disabled").length && q.push(":enabled", ":disabled"), a.querySelectorAll("*,:x"), q.push(",.*:")
| + | |
− | })), (c.matchesSelector = Y.test(s = o.matches || o.webkitMatchesSelector || o.mozMatchesSelector || o.oMatchesSelector || o.msMatchesSelector)) && ja(function (a) {
| + | |
− | c.disconnectedMatch = s.call(a, "*"), s.call(a, "[s!='']:x"), r.push("!=", N)
| + | |
− | }), q = q.length && new RegExp(q.join("|")), r = r.length && new RegExp(r.join("|")), b = Y.test(o.compareDocumentPosition), t = b || Y.test(o.contains) ? function (a, b) {
| + | |
− | var c = 9 === a.nodeType ? a.documentElement : a,
| + | |
− | d = b && b.parentNode;
| + | |
− | return a === d || !(!d || 1 !== d.nodeType || !(c.contains ? c.contains(d) : a.compareDocumentPosition && 16 & a.compareDocumentPosition(d)))
| + | |
− | } : function (a, b) {
| + | |
− | if (b)
| + | |
− | while (b = b.parentNode)
| + | |
− | if (b === a) return !0;
| + | |
− | return !1
| + | |
− | }, B = b ? function (a, b) {
| + | |
− | if (a === b) return l = !0, 0;
| + | |
− | var d = !a.compareDocumentPosition - !b.compareDocumentPosition;
| + | |
− | return d ? d : (d = (a.ownerDocument || a) === (b.ownerDocument || b) ? a.compareDocumentPosition(b) : 1, 1 & d || !c.sortDetached && b.compareDocumentPosition(a) === d ? a === n || a.ownerDocument === v && t(v, a) ? -1 : b === n || b.ownerDocument === v && t(v, b) ? 1 : k ? I(k, a) - I(k, b) : 0 : 4 & d ? -1 : 1)
| + | |
− | } : function (a, b) {
| + | |
− | if (a === b) return l = !0, 0;
| + | |
− | var c, d = 0,
| + | |
− | e = a.parentNode,
| + | |
− | f = b.parentNode,
| + | |
− | g = [a],
| + | |
− | h = [b];
| + | |
− | if (!e || !f) return a === n ? -1 : b === n ? 1 : e ? -1 : f ? 1 : k ? I(k, a) - I(k, b) : 0;
| + | |
− | if (e === f) return la(a, b);
| + | |
− | c = a;
| + | |
− | while (c = c.parentNode) g.unshift(c);
| + | |
− | c = b;
| + | |
− | while (c = c.parentNode) h.unshift(c);
| + | |
− | while (g[d] === h[d]) d++;
| + | |
− | return d ? la(g[d], h[d]) : g[d] === v ? -1 : h[d] === v ? 1 : 0
| + | |
− | }, n) : n
| + | |
− | }, ga.matches = function (a, b) {
| + | |
− | return ga(a, null, null, b)
| + | |
− | }, ga.matchesSelector = function (a, b) {
| + | |
− | if ((a.ownerDocument || a) !== n && m(a), b = b.replace(S, "='$1']"), c.matchesSelector && p && !A[b + " "] && (!r || !r.test(b)) && (!q || !q.test(b))) try {
| + | |
− | var d = s.call(a, b);
| + | |
− | if (d || c.disconnectedMatch || a.document && 11 !== a.document.nodeType) return d
| + | |
− | } catch (e) {}
| + | |
− | return ga(b, n, null, [a]).length > 0
| + | |
− | }, ga.contains = function (a, b) {
| + | |
− | return (a.ownerDocument || a) !== n && m(a), t(a, b)
| + | |
− | }, ga.attr = function (a, b) {
| + | |
− | (a.ownerDocument || a) !== n && m(a);
| + | |
− | var e = d.attrHandle[b.toLowerCase()],
| + | |
− | f = e && C.call(d.attrHandle, b.toLowerCase()) ? e(a, b, !p) : void 0;
| + | |
− | return void 0 !== f ? f : c.attributes || !p ? a.getAttribute(b) : (f = a.getAttributeNode(b)) && f.specified ? f.value : null
| + | |
− | }, ga.escape = function (a) {
| + | |
− | return (a + "").replace(ba, ca)
| + | |
− | }, ga.error = function (a) {
| + | |
− | throw new Error("Syntax error, unrecognized expression: " + a)
| + | |
− | }, ga.uniqueSort = function (a) {
| + | |
− | var b, d = [],
| + | |
− | e = 0,
| + | |
− | f = 0;
| + | |
− | if (l = !c.detectDuplicates, k = !c.sortStable && a.slice(0), a.sort(B), l) {
| + | |
− | while (b = a[f++]) b === a[f] && (e = d.push(f));
| + | |
− | while (e--) a.splice(d[e], 1)
| + | |
− | }
| + | |
− | return k = null, a
| + | |
− | }, e = ga.getText = function (a) {
| + | |
− | var b, c = "",
| + | |
− | d = 0,
| + | |
− | f = a.nodeType;
| + | |
− | if (f) {
| + | |
− | if (1 === f || 9 === f || 11 === f) {
| + | |
− | if ("string" == typeof a.textContent) return a.textContent;
| + | |
− | for (a = a.firstChild; a; a = a.nextSibling) c += e(a)
| + | |
− | } else if (3 === f || 4 === f) return a.nodeValue
| + | |
− | } else
| + | |
− | while (b = a[d++]) c += e(b);
| + | |
− | return c
| + | |
− | }, d = ga.selectors = {
| + | |
− | cacheLength: 50,
| + | |
− | createPseudo: ia,
| + | |
− | match: V,
| + | |
− | attrHandle: {},
| + | |
− | find: {},
| + | |
− | relative: {
| + | |
− | ">": {
| + | |
− | dir: "parentNode",
| + | |
− | first: !0
| + | |
− | },
| + | |
− | " ": {
| + | |
− | dir: "parentNode"
| + | |
− | },
| + | |
− | "+": {
| + | |
− | dir: "previousSibling",
| + | |
− | first: !0
| + | |
− | },
| + | |
− | "~": {
| + | |
− | dir: "previousSibling"
| + | |
− | }
| + | |
− | },
| + | |
− | preFilter: {
| + | |
− | ATTR: function (a) {
| + | |
− | return a[1] = a[1].replace(_, aa), a[3] = (a[3] || a[4] || a[5] || "").replace(_, aa), "~=" === a[2] && (a[3] = " " + a[3] + " "), a.slice(0, 4)
| + | |
− | },
| + | |
− | CHILD: function (a) {
| + | |
− | return a[1] = a[1].toLowerCase(), "nth" === a[1].slice(0, 3) ? (a[3] || ga.error(a[0]), a[4] = +(a[4] ? a[5] + (a[6] || 1) : 2 * ("even" === a[3] || "odd" === a[3])), a[5] = +(a[7] + a[8] || "odd" === a[3])) : a[3] && ga.error(a[0]), a
| + | |
− | },
| + | |
− | PSEUDO: function (a) {
| + | |
− | var b, c = !a[6] && a[2];
| + | |
− | return V.CHILD.test(a[0]) ? null : (a[3] ? a[2] = a[4] || a[5] || "" : c && T.test(c) && (b = g(c, !0)) && (b = c.indexOf(")", c.length - b) - c.length) && (a[0] = a[0].slice(0, b), a[2] = c.slice(0, b)), a.slice(0, 3))
| + | |
− | }
| + | |
− | },
| + | |
− | filter: {
| + | |
− | TAG: function (a) {
| + | |
− | var b = a.replace(_, aa).toLowerCase();
| + | |
− | return "*" === a ? function () {
| + | |
− | return !0
| + | |
− | } : function (a) {
| + | |
− | return a.nodeName && a.nodeName.toLowerCase() === b
| + | |
− | }
| + | |
− | },
| + | |
− | CLASS: function (a) {
| + | |
− | var b = y[a + " "];
| + | |
− | return b || (b = new RegExp("(^|" + K + ")" + a + "(" + K + "|$)")) && y(a, function (a) {
| + | |
− | return b.test("string" == typeof a.className && a.className || "undefined" != typeof a.getAttribute && a.getAttribute("class") || "")
| + | |
− | })
| + | |
− | },
| + | |
− | ATTR: function (a, b, c) {
| + | |
− | return function (d) {
| + | |
− | var e = ga.attr(d, a);
| + | |
− | return null == e ? "!=" === b : !b || (e += "", "=" === b ? e === c : "!=" === b ? e !== c : "^=" === b ? c && 0 === e.indexOf(c) : "*=" === b ? c && e.indexOf(c) > -1 : "$=" === b ? c && e.slice(-c.length) === c : "~=" === b ? (" " + e.replace(O, " ") + " ").indexOf(c) > -1 : "|=" === b && (e === c || e.slice(0, c.length + 1) === c + "-"))
| + | |
− | }
| + | |
− | },
| + | |
− | CHILD: function (a, b, c, d, e) {
| + | |
− | var f = "nth" !== a.slice(0, 3),
| + | |
− | g = "last" !== a.slice(-4),
| + | |
− | h = "of-type" === b;
| + | |
− | return 1 === d && 0 === e ? function (a) {
| + | |
− | return !!a.parentNode
| + | |
− | } : function (b, c, i) {
| + | |
− | var j, k, l, m, n, o, p = f !== g ? "nextSibling" : "previousSibling",
| + | |
− | q = b.parentNode,
| + | |
− | r = h && b.nodeName.toLowerCase(),
| + | |
− | s = !i && !h,
| + | |
− | t = !1;
| + | |
− | if (q) {
| + | |
− | if (f) {
| + | |
− | while (p) {
| + | |
− | m = b;
| + | |
− | while (m = m[p])
| + | |
− | if (h ? m.nodeName.toLowerCase() === r : 1 === m.nodeType) return !1;
| + | |
− | o = p = "only" === a && !o && "nextSibling"
| + | |
− | }
| + | |
− | return !0
| + | |
− | }
| + | |
− | if (o = [g ? q.firstChild : q.lastChild], g && s) {
| + | |
− | m = q, l = m[u] || (m[u] = {}), k = l[m.uniqueID] || (l[m.uniqueID] = {}), j = k[a] || [], n = j[0] === w && j[1], t = n && j[2], m = n && q.childNodes[n];
| + | |
− | while (m = ++n && m && m[p] || (t = n = 0) || o.pop())
| + | |
− | if (1 === m.nodeType && ++t && m === b) {
| + | |
− | k[a] = [w, n, t];
| + | |
− | break
| + | |
− | }
| + | |
− | } else if (s && (m = b, l = m[u] || (m[u] = {}), k = l[m.uniqueID] || (l[m.uniqueID] = {}), j = k[a] || [], n = j[0] === w && j[1], t = n), t === !1)
| + | |
− | while (m = ++n && m && m[p] || (t = n = 0) || o.pop())
| + | |
− | if ((h ? m.nodeName.toLowerCase() === r : 1 === m.nodeType) && ++t && (s && (l = m[u] || (m[u] = {}), k = l[m.uniqueID] || (l[m.uniqueID] = {}), k[a] = [w, t]), m === b)) break;
| + | |
− | return t -= e, t === d || t % d === 0 && t / d >= 0
| + | |
− | }
| + | |
− | }
| + | |
− | },
| + | |
− | PSEUDO: function (a, b) {
| + | |
− | var c, e = d.pseudos[a] || d.setFilters[a.toLowerCase()] || ga.error("unsupported pseudo: " + a);
| + | |
− | return e[u] ? e(b) : e.length > 1 ? (c = [a, a, "", b], d.setFilters.hasOwnProperty(a.toLowerCase()) ? ia(function (a, c) {
| + | |
− | var d, f = e(a, b),
| + | |
− | g = f.length;
| + | |
− | while (g--) d = I(a, f[g]), a[d] = !(c[d] = f[g])
| + | |
− | }) : function (a) {
| + | |
− | return e(a, 0, c)
| + | |
− | }) : e
| + | |
− | }
| + | |
− | },
| + | |
− | pseudos: {
| + | |
− | not: ia(function (a) {
| + | |
− | var b = [],
| + | |
− | c = [],
| + | |
− | d = h(a.replace(P, "$1"));
| + | |
− | return d[u] ? ia(function (a, b, c, e) {
| + | |
− | var f, g = d(a, null, e, []),
| + | |
− | h = a.length;
| + | |
− | while (h--)(f = g[h]) && (a[h] = !(b[h] = f))
| + | |
− | }) : function (a, e, f) {
| + | |
− | return b[0] = a, d(b, null, f, c), b[0] = null, !c.pop()
| + | |
− | }
| + | |
− | }),
| + | |
− | has: ia(function (a) {
| + | |
− | return function (b) {
| + | |
− | return ga(a, b).length > 0
| + | |
− | }
| + | |
− | }),
| + | |
− | contains: ia(function (a) {
| + | |
− | return a = a.replace(_, aa),
| + | |
− | function (b) {
| + | |
− | return (b.textContent || b.innerText || e(b)).indexOf(a) > -1
| + | |
− | }
| + | |
− | }),
| + | |
− | lang: ia(function (a) {
| + | |
− | return U.test(a || "") || ga.error("unsupported lang: " + a), a = a.replace(_, aa).toLowerCase(),
| + | |
− | function (b) {
| + | |
− | var c;
| + | |
− | do
| + | |
− | if (c = p ? b.lang : b.getAttribute("xml:lang") || b.getAttribute("lang")) return c = c.toLowerCase(), c === a || 0 === c.indexOf(a + "-");
| + | |
− | while ((b = b.parentNode) && 1 === b.nodeType);
| + | |
− | return !1
| + | |
− | }
| + | |
− | }),
| + | |
− | target: function (b) {
| + | |
− | var c = a.location && a.location.hash;
| + | |
− | return c && c.slice(1) === b.id
| + | |
− | },
| + | |
− | root: function (a) {
| + | |
− | return a === o
| + | |
− | },
| + | |
− | focus: function (a) {
| + | |
− | return a === n.activeElement && (!n.hasFocus || n.hasFocus()) && !!(a.type || a.href || ~a.tabIndex)
| + | |
− | },
| + | |
− | enabled: oa(!1),
| + | |
− | disabled: oa(!0),
| + | |
− | checked: function (a) {
| + | |
− | var b = a.nodeName.toLowerCase();
| + | |
− | return "input" === b && !!a.checked || "option" === b && !!a.selected
| + | |
− | },
| + | |
− | selected: function (a) {
| + | |
− | return a.parentNode && a.parentNode.selectedIndex, a.selected === !0
| + | |
− | },
| + | |
− | empty: function (a) {
| + | |
− | for (a = a.firstChild; a; a = a.nextSibling)
| + | |
− | if (a.nodeType < 6) return !1;
| + | |
− | return !0
| + | |
− | },
| + | |
− | parent: function (a) {
| + | |
− | return !d.pseudos.empty(a)
| + | |
− | },
| + | |
− | header: function (a) {
| + | |
− | return X.test(a.nodeName)
| + | |
− | },
| + | |
− | input: function (a) {
| + | |
− | return W.test(a.nodeName)
| + | |
− | },
| + | |
− | button: function (a) {
| + | |
− | var b = a.nodeName.toLowerCase();
| + | |
− | return "input" === b && "button" === a.type || "button" === b
| + | |
− | },
| + | |
− | text: function (a) {
| + | |
− | var b;
| + | |
− | return "input" === a.nodeName.toLowerCase() && "text" === a.type && (null == (b = a.getAttribute("type")) || "text" === b.toLowerCase())
| + | |
− | },
| + | |
− | first: pa(function () {
| + | |
− | return [0]
| + | |
− | }),
| + | |
− | last: pa(function (a, b) {
| + | |
− | return [b - 1]
| + | |
− | }),
| + | |
− | eq: pa(function (a, b, c) {
| + | |
− | return [c < 0 ? c + b : c]
| + | |
− | }),
| + | |
− | even: pa(function (a, b) {
| + | |
− | for (var c = 0; c < b; c += 2) a.push(c);
| + | |
− | return a
| + | |
− | }),
| + | |
− | odd: pa(function (a, b) {
| + | |
− | for (var c = 1; c < b; c += 2) a.push(c);
| + | |
− | return a
| + | |
− | }),
| + | |
− | lt: pa(function (a, b, c) {
| + | |
− | for (var d = c < 0 ? c + b : c; --d >= 0;) a.push(d);
| + | |
− | return a
| + | |
− | }),
| + | |
− | gt: pa(function (a, b, c) {
| + | |
− | for (var d = c < 0 ? c + b : c; ++d < b;) a.push(d);
| + | |
− | return a
| + | |
− | })
| + | |
− | }
| + | |
− | }, d.pseudos.nth = d.pseudos.eq;
| + | |
− | for (b in {
| + | |
− | radio: !0,
| + | |
− | checkbox: !0,
| + | |
− | file: !0,
| + | |
− | password: !0,
| + | |
− | image: !0
| + | |
− | }) d.pseudos[b] = ma(b);
| + | |
− | for (b in {
| + | |
− | submit: !0,
| + | |
− | reset: !0
| + | |
− | }) d.pseudos[b] = na(b);
| + | |
− | | + | |
− | function ra() {}
| + | |
− | ra.prototype = d.filters = d.pseudos, d.setFilters = new ra, g = ga.tokenize = function (a, b) {
| + | |
− | var c, e, f, g, h, i, j, k = z[a + " "];
| + | |
− | if (k) return b ? 0 : k.slice(0);
| + | |
− | h = a, i = [], j = d.preFilter;
| + | |
− | while (h) {
| + | |
− | c && !(e = Q.exec(h)) || (e && (h = h.slice(e[0].length) || h), i.push(f = [])), c = !1, (e = R.exec(h)) && (c = e.shift(), f.push({
| + | |
− | value: c,
| + | |
− | type: e[0].replace(P, " ")
| + | |
− | }), h = h.slice(c.length));
| + | |
− | for (g in d.filter) !(e = V[g].exec(h)) || j[g] && !(e = j[g](e)) || (c = e.shift(), f.push({
| + | |
− | value: c,
| + | |
− | type: g,
| + | |
− | matches: e
| + | |
− | }), h = h.slice(c.length));
| + | |
− | if (!c) break
| + | |
− | }
| + | |
− | return b ? h.length : h ? ga.error(a) : z(a, i).slice(0)
| + | |
− | };
| + | |
− | | + | |
− | function sa(a) {
| + | |
− | for (var b = 0, c = a.length, d = ""; b < c; b++) d += a[b].value;
| + | |
− | return d
| + | |
− | }
| + | |
− | | + | |
− | function ta(a, b, c) {
| + | |
− | var d = b.dir,
| + | |
− | e = b.next,
| + | |
− | f = e || d,
| + | |
− | g = c && "parentNode" === f,
| + | |
− | h = x++;
| + | |
− | return b.first ? function (b, c, e) {
| + | |
− | while (b = b[d])
| + | |
− | if (1 === b.nodeType || g) return a(b, c, e);
| + | |
− | return !1
| + | |
− | } : function (b, c, i) {
| + | |
− | var j, k, l, m = [w, h];
| + | |
− | if (i) {
| + | |
− | while (b = b[d])
| + | |
− | if ((1 === b.nodeType || g) && a(b, c, i)) return !0
| + | |
− | } else
| + | |
− | while (b = b[d])
| + | |
− | if (1 === b.nodeType || g)
| + | |
− | if (l = b[u] || (b[u] = {}), k = l[b.uniqueID] || (l[b.uniqueID] = {}), e && e === b.nodeName.toLowerCase()) b = b[d] || b;
| + | |
− | else {
| + | |
− | if ((j = k[f]) && j[0] === w && j[1] === h) return m[2] = j[2];
| + | |
− | if (k[f] = m, m[2] = a(b, c, i)) return !0
| + | |
− | } return !1
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function ua(a) {
| + | |
− | return a.length > 1 ? function (b, c, d) {
| + | |
− | var e = a.length;
| + | |
− | while (e--)
| + | |
− | if (!a[e](b, c, d)) return !1;
| + | |
− | return !0
| + | |
− | } : a[0]
| + | |
− | }
| + | |
− | | + | |
− | function va(a, b, c) {
| + | |
− | for (var d = 0, e = b.length; d < e; d++) ga(a, b[d], c);
| + | |
− | return c
| + | |
− | }
| + | |
− | | + | |
− | function wa(a, b, c, d, e) {
| + | |
− | for (var f, g = [], h = 0, i = a.length, j = null != b; h < i; h++)(f = a[h]) && (c && !c(f, d, e) || (g.push(f), j && b.push(h)));
| + | |
− | return g
| + | |
− | }
| + | |
− | | + | |
− | function xa(a, b, c, d, e, f) {
| + | |
− | return d && !d[u] && (d = xa(d)), e && !e[u] && (e = xa(e, f)), ia(function (f, g, h, i) {
| + | |
− | var j, k, l, m = [],
| + | |
− | n = [],
| + | |
− | o = g.length,
| + | |
− | p = f || va(b || "*", h.nodeType ? [h] : h, []),
| + | |
− | q = !a || !f && b ? p : wa(p, m, a, h, i),
| + | |
− | r = c ? e || (f ? a : o || d) ? [] : g : q;
| + | |
− | if (c && c(q, r, h, i), d) {
| + | |
− | j = wa(r, n), d(j, [], h, i), k = j.length;
| + | |
− | while (k--)(l = j[k]) && (r[n[k]] = !(q[n[k]] = l))
| + | |
− | }
| + | |
− | if (f) {
| + | |
− | if (e || a) {
| + | |
− | if (e) {
| + | |
− | j = [], k = r.length;
| + | |
− | while (k--)(l = r[k]) && j.push(q[k] = l);
| + | |
− | e(null, r = [], j, i)
| + | |
− | }
| + | |
− | k = r.length;
| + | |
− | while (k--)(l = r[k]) && (j = e ? I(f, l) : m[k]) > -1 && (f[j] = !(g[j] = l))
| + | |
− | }
| + | |
− | } else r = wa(r === g ? r.splice(o, r.length) : r), e ? e(null, g, r, i) : G.apply(g, r)
| + | |
− | })
| + | |
− | }
| + | |
− | | + | |
− | function ya(a) {
| + | |
− | for (var b, c, e, f = a.length, g = d.relative[a[0].type], h = g || d.relative[" "], i = g ? 1 : 0, k = ta(function (a) {
| + | |
− | return a === b
| + | |
− | }, h, !0), l = ta(function (a) {
| + | |
− | return I(b, a) > -1
| + | |
− | }, h, !0), m = [function (a, c, d) {
| + | |
− | var e = !g && (d || c !== j) || ((b = c).nodeType ? k(a, c, d) : l(a, c, d));
| + | |
− | return b = null, e
| + | |
− | }]; i < f; i++)
| + | |
− | if (c = d.relative[a[i].type]) m = [ta(ua(m), c)];
| + | |
− | else {
| + | |
− | if (c = d.filter[a[i].type].apply(null, a[i].matches), c[u]) {
| + | |
− | for (e = ++i; e < f; e++)
| + | |
− | if (d.relative[a[e].type]) break;
| + | |
− | return xa(i > 1 && ua(m), i > 1 && sa(a.slice(0, i - 1).concat({
| + | |
− | value: " " === a[i - 2].type ? "*" : ""
| + | |
− | })).replace(P, "$1"), c, i < e && ya(a.slice(i, e)), e < f && ya(a = a.slice(e)), e < f && sa(a))
| + | |
− | }
| + | |
− | m.push(c)
| + | |
− | }
| + | |
− | return ua(m)
| + | |
− | }
| + | |
− | | + | |
− | function za(a, b) {
| + | |
− | var c = b.length > 0,
| + | |
− | e = a.length > 0,
| + | |
− | f = function (f, g, h, i, k) {
| + | |
− | var l, o, q, r = 0,
| + | |
− | s = "0",
| + | |
− | t = f && [],
| + | |
− | u = [],
| + | |
− | v = j,
| + | |
− | x = f || e && d.find.TAG("*", k),
| + | |
− | y = w += null == v ? 1 : Math.random() || .1,
| + | |
− | z = x.length;
| + | |
− | for (k && (j = g === n || g || k); s !== z && null != (l = x[s]); s++) {
| + | |
− | if (e && l) {
| + | |
− | o = 0, g || l.ownerDocument === n || (m(l), h = !p);
| + | |
− | while (q = a[o++])
| + | |
− | if (q(l, g || n, h)) {
| + | |
− | i.push(l);
| + | |
− | break
| + | |
− | }
| + | |
− | k && (w = y)
| + | |
− | }
| + | |
− | c && ((l = !q && l) && r--, f && t.push(l))
| + | |
− | }
| + | |
− | if (r += s, c && s !== r) {
| + | |
− | o = 0;
| + | |
− | while (q = b[o++]) q(t, u, g, h);
| + | |
− | if (f) {
| + | |
− | if (r > 0)
| + | |
− | while (s--) t[s] || u[s] || (u[s] = E.call(i));
| + | |
− | u = wa(u)
| + | |
− | }
| + | |
− | G.apply(i, u), k && !f && u.length > 0 && r + b.length > 1 && ga.uniqueSort(i)
| + | |
− | }
| + | |
− | return k && (w = y, j = v), t
| + | |
− | };
| + | |
− | return c ? ia(f) : f
| + | |
− | }
| + | |
− | return h = ga.compile = function (a, b) {
| + | |
− | var c, d = [],
| + | |
− | e = [],
| + | |
− | f = A[a + " "];
| + | |
− | if (!f) {
| + | |
− | b || (b = g(a)), c = b.length;
| + | |
− | while (c--) f = ya(b[c]), f[u] ? d.push(f) : e.push(f);
| + | |
− | f = A(a, za(e, d)), f.selector = a
| + | |
− | }
| + | |
− | return f
| + | |
− | }, i = ga.select = function (a, b, c, e) {
| + | |
− | var f, i, j, k, l, m = "function" == typeof a && a,
| + | |
− | n = !e && g(a = m.selector || a);
| + | |
− | if (c = c || [], 1 === n.length) {
| + | |
− | if (i = n[0] = n[0].slice(0), i.length > 2 && "ID" === (j = i[0]).type && 9 === b.nodeType && p && d.relative[i[1].type]) {
| + | |
− | if (b = (d.find.ID(j.matches[0].replace(_, aa), b) || [])[0], !b) return c;
| + | |
− | m && (b = b.parentNode), a = a.slice(i.shift().value.length)
| + | |
− | }
| + | |
− | f = V.needsContext.test(a) ? 0 : i.length;
| + | |
− | while (f--) {
| + | |
− | if (j = i[f], d.relative[k = j.type]) break;
| + | |
− | if ((l = d.find[k]) && (e = l(j.matches[0].replace(_, aa), $.test(i[0].type) && qa(b.parentNode) || b))) {
| + | |
− | if (i.splice(f, 1), a = e.length && sa(i), !a) return G.apply(c, e), c;
| + | |
− | break
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | return (m || h(a, n))(e, b, !p, c, !b || $.test(a) && qa(b.parentNode) || b), c
| + | |
− | }, c.sortStable = u.split("").sort(B).join("") === u, c.detectDuplicates = !!l, m(), c.sortDetached = ja(function (a) {
| + | |
− | return 1 & a.compareDocumentPosition(n.createElement("fieldset"))
| + | |
− | }), ja(function (a) {
| + | |
− | return a.innerHTML = "<a href='#'></a>", "#" === a.firstChild.getAttribute("href")
| + | |
− | }) || ka("type|href|height|width", function (a, b, c) {
| + | |
− | if (!c) return a.getAttribute(b, "type" === b.toLowerCase() ? 1 : 2)
| + | |
− | }), c.attributes && ja(function (a) {
| + | |
− | return a.innerHTML = "<input/>", a.firstChild.setAttribute("value", ""), "" === a.firstChild.getAttribute("value")
| + | |
− | }) || ka("value", function (a, b, c) {
| + | |
− | if (!c && "input" === a.nodeName.toLowerCase()) return a.defaultValue
| + | |
− | }), ja(function (a) {
| + | |
− | return null == a.getAttribute("disabled")
| + | |
− | }) || ka(J, function (a, b, c) {
| + | |
− | var d;
| + | |
− | if (!c) return a[b] === !0 ? b.toLowerCase() : (d = a.getAttributeNode(b)) && d.specified ? d.value : null
| + | |
− | }), ga
| + | |
− | }(a);
| + | |
− | r.find = x, r.expr = x.selectors, r.expr[":"] = r.expr.pseudos, r.uniqueSort = r.unique = x.uniqueSort, r.text = x.getText, r.isXMLDoc = x.isXML, r.contains = x.contains, r.escapeSelector = x.escape;
| + | |
− | var y = function (a, b, c) {
| + | |
− | var d = [],
| + | |
− | e = void 0 !== c;
| + | |
− | while ((a = a[b]) && 9 !== a.nodeType)
| + | |
− | if (1 === a.nodeType) {
| + | |
− | if (e && r(a).is(c)) break;
| + | |
− | d.push(a)
| + | |
− | }
| + | |
− | return d
| + | |
− | },
| + | |
− | z = function (a, b) {
| + | |
− | for (var c = []; a; a = a.nextSibling) 1 === a.nodeType && a !== b && c.push(a);
| + | |
− | return c
| + | |
− | },
| + | |
− | A = r.expr.match.needsContext,
| + | |
− | B = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i,
| + | |
− | C = /^.[^:#\[\.,]*$/;
| + | |
− | | + | |
− | function D(a, b, c) {
| + | |
− | return r.isFunction(b) ? r.grep(a, function (a, d) {
| + | |
− | return !!b.call(a, d, a) !== c
| + | |
− | }) : b.nodeType ? r.grep(a, function (a) {
| + | |
− | return a === b !== c
| + | |
− | }) : "string" != typeof b ? r.grep(a, function (a) {
| + | |
− | return i.call(b, a) > -1 !== c
| + | |
− | }) : C.test(b) ? r.filter(b, a, c) : (b = r.filter(b, a), r.grep(a, function (a) {
| + | |
− | return i.call(b, a) > -1 !== c && 1 === a.nodeType
| + | |
− | }))
| + | |
− | }
| + | |
− | r.filter = function (a, b, c) {
| + | |
− | var d = b[0];
| + | |
− | return c && (a = ":not(" + a + ")"), 1 === b.length && 1 === d.nodeType ? r.find.matchesSelector(d, a) ? [d] : [] : r.find.matches(a, r.grep(b, function (a) {
| + | |
− | return 1 === a.nodeType
| + | |
− | }))
| + | |
− | }, r.fn.extend({
| + | |
− | find: function (a) {
| + | |
− | var b, c, d = this.length,
| + | |
− | e = this;
| + | |
− | if ("string" != typeof a) return this.pushStack(r(a).filter(function () {
| + | |
− | for (b = 0; b < d; b++)
| + | |
− | if (r.contains(e[b], this)) return !0
| + | |
− | }));
| + | |
− | for (c = this.pushStack([]), b = 0; b < d; b++) r.find(a, e[b], c);
| + | |
− | return d > 1 ? r.uniqueSort(c) : c
| + | |
− | },
| + | |
− | filter: function (a) {
| + | |
− | return this.pushStack(D(this, a || [], !1))
| + | |
− | },
| + | |
− | not: function (a) {
| + | |
− | return this.pushStack(D(this, a || [], !0))
| + | |
− | },
| + | |
− | is: function (a) {
| + | |
− | return !!D(this, "string" == typeof a && A.test(a) ? r(a) : a || [], !1).length
| + | |
− | }
| + | |
− | });
| + | |
− | var E, F = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/,
| + | |
− | G = r.fn.init = function (a, b, c) {
| + | |
− | var e, f;
| + | |
− | if (!a) return this;
| + | |
− | if (c = c || E, "string" == typeof a) {
| + | |
− | if (e = "<" === a[0] && ">" === a[a.length - 1] && a.length >= 3 ? [null, a, null] : F.exec(a), !e || !e[1] && b) return !b || b.jquery ? (b || c).find(a) : this.constructor(b).find(a);
| + | |
− | if (e[1]) {
| + | |
− | if (b = b instanceof r ? b[0] : b, r.merge(this, r.parseHTML(e[1], b && b.nodeType ? b.ownerDocument || b : d, !0)), B.test(e[1]) && r.isPlainObject(b))
| + | |
− | for (e in b) r.isFunction(this[e]) ? this[e](b[e]) : this.attr(e, b[e]);
| + | |
− | return this
| + | |
− | }
| + | |
− | return f = d.getElementById(e[2]), f && (this[0] = f, this.length = 1), this
| + | |
− | }
| + | |
− | return a.nodeType ? (this[0] = a, this.length = 1, this) : r.isFunction(a) ? void 0 !== c.ready ? c.ready(a) : a(r) : r.makeArray(a, this)
| + | |
− | };
| + | |
− | G.prototype = r.fn, E = r(d);
| + | |
− | var H = /^(?:parents|prev(?:Until|All))/,
| + | |
− | I = {
| + | |
− | children: !0,
| + | |
− | contents: !0,
| + | |
− | next: !0,
| + | |
− | prev: !0
| + | |
− | };
| + | |
− | r.fn.extend({
| + | |
− | has: function (a) {
| + | |
− | var b = r(a, this),
| + | |
− | c = b.length;
| + | |
− | return this.filter(function () {
| + | |
− | for (var a = 0; a < c; a++)
| + | |
− | if (r.contains(this, b[a])) return !0
| + | |
− | })
| + | |
− | },
| + | |
− | closest: function (a, b) {
| + | |
− | var c, d = 0,
| + | |
− | e = this.length,
| + | |
− | f = [],
| + | |
− | g = "string" != typeof a && r(a);
| + | |
− | if (!A.test(a))
| + | |
− | for (; d < e; d++)
| + | |
− | for (c = this[d]; c && c !== b; c = c.parentNode)
| + | |
− | if (c.nodeType < 11 && (g ? g.index(c) > -1 : 1 === c.nodeType && r.find.matchesSelector(c, a))) {
| + | |
− | f.push(c);
| + | |
− | break
| + | |
− | }
| + | |
− | return this.pushStack(f.length > 1 ? r.uniqueSort(f) : f)
| + | |
− | },
| + | |
− | index: function (a) {
| + | |
− | return a ? "string" == typeof a ? i.call(r(a), this[0]) : i.call(this, a.jquery ? a[0] : a) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1
| + | |
− | },
| + | |
− | add: function (a, b) {
| + | |
− | return this.pushStack(r.uniqueSort(r.merge(this.get(), r(a, b))))
| + | |
− | },
| + | |
− | addBack: function (a) {
| + | |
− | return this.add(null == a ? this.prevObject : this.prevObject.filter(a))
| + | |
− | }
| + | |
− | });
| + | |
− | | + | |
− | function J(a, b) {
| + | |
− | while ((a = a[b]) && 1 !== a.nodeType);
| + | |
− | return a
| + | |
− | }
| + | |
− | r.each({
| + | |
− | parent: function (a) {
| + | |
− | var b = a.parentNode;
| + | |
− | return b && 11 !== b.nodeType ? b : null
| + | |
− | },
| + | |
− | parents: function (a) {
| + | |
− | return y(a, "parentNode")
| + | |
− | },
| + | |
− | parentsUntil: function (a, b, c) {
| + | |
− | return y(a, "parentNode", c)
| + | |
− | },
| + | |
− | next: function (a) {
| + | |
− | return J(a, "nextSibling")
| + | |
− | },
| + | |
− | prev: function (a) {
| + | |
− | return J(a, "previousSibling")
| + | |
− | },
| + | |
− | nextAll: function (a) {
| + | |
− | return y(a, "nextSibling")
| + | |
− | },
| + | |
− | prevAll: function (a) {
| + | |
− | return y(a, "previousSibling")
| + | |
− | },
| + | |
− | nextUntil: function (a, b, c) {
| + | |
− | return y(a, "nextSibling", c)
| + | |
− | },
| + | |
− | prevUntil: function (a, b, c) {
| + | |
− | return y(a, "previousSibling", c)
| + | |
− | },
| + | |
− | siblings: function (a) {
| + | |
− | return z((a.parentNode || {}).firstChild, a)
| + | |
− | },
| + | |
− | children: function (a) {
| + | |
− | return z(a.firstChild)
| + | |
− | },
| + | |
− | contents: function (a) {
| + | |
− | return a.contentDocument || r.merge([], a.childNodes)
| + | |
− | }
| + | |
− | }, function (a, b) {
| + | |
− | r.fn[a] = function (c, d) {
| + | |
− | var e = r.map(this, b, c);
| + | |
− | return "Until" !== a.slice(-5) && (d = c), d && "string" == typeof d && (e = r.filter(d, e)), this.length > 1 && (I[a] || r.uniqueSort(e), H.test(a) && e.reverse()), this.pushStack(e)
| + | |
− | }
| + | |
− | });
| + | |
− | var K = /[^\x20\t\r\n\f]+/g;
| + | |
− | | + | |
− | function L(a) {
| + | |
− | var b = {};
| + | |
− | return r.each(a.match(K) || [], function (a, c) {
| + | |
− | b[c] = !0
| + | |
− | }), b
| + | |
− | }
| + | |
− | r.Callbacks = function (a) {
| + | |
− | a = "string" == typeof a ? L(a) : r.extend({}, a);
| + | |
− | var b, c, d, e, f = [],
| + | |
− | g = [],
| + | |
− | h = -1,
| + | |
− | i = function () {
| + | |
− | for (e = a.once, d = b = !0; g.length; h = -1) {
| + | |
− | c = g.shift();
| + | |
− | while (++h < f.length) f[h].apply(c[0], c[1]) === !1 && a.stopOnFalse && (h = f.length, c = !1)
| + | |
− | }
| + | |
− | a.memory || (c = !1), b = !1, e && (f = c ? [] : "")
| + | |
− | },
| + | |
− | j = {
| + | |
− | add: function () {
| + | |
− | return f && (c && !b && (h = f.length - 1, g.push(c)), function d(b) {
| + | |
− | r.each(b, function (b, c) {
| + | |
− | r.isFunction(c) ? a.unique && j.has(c) || f.push(c) : c && c.length && "string" !== r.type(c) && d(c)
| + | |
− | })
| + | |
− | }(arguments), c && !b && i()), this
| + | |
− | },
| + | |
− | remove: function () {
| + | |
− | return r.each(arguments, function (a, b) {
| + | |
− | var c;
| + | |
− | while ((c = r.inArray(b, f, c)) > -1) f.splice(c, 1), c <= h && h--
| + | |
− | }), this
| + | |
− | },
| + | |
− | has: function (a) {
| + | |
− | return a ? r.inArray(a, f) > -1 : f.length > 0
| + | |
− | },
| + | |
− | empty: function () {
| + | |
− | return f && (f = []), this
| + | |
− | },
| + | |
− | disable: function () {
| + | |
− | return e = g = [], f = c = "", this
| + | |
− | },
| + | |
− | disabled: function () {
| + | |
− | return !f
| + | |
− | },
| + | |
− | lock: function () {
| + | |
− | return e = g = [], c || b || (f = c = ""), this
| + | |
− | },
| + | |
− | locked: function () {
| + | |
− | return !!e
| + | |
− | },
| + | |
− | fireWith: function (a, c) {
| + | |
− | return e || (c = c || [], c = [a, c.slice ? c.slice() : c], g.push(c), b || i()), this
| + | |
− | },
| + | |
− | fire: function () {
| + | |
− | return j.fireWith(this, arguments), this
| + | |
− | },
| + | |
− | fired: function () {
| + | |
− | return !!d
| + | |
− | }
| + | |
− | };
| + | |
− | return j
| + | |
− | };
| + | |
− | | + | |
− | function M(a) {
| + | |
− | return a
| + | |
− | }
| + | |
− | | + | |
− | function N(a) {
| + | |
− | throw a
| + | |
− | }
| + | |
− | | + | |
− | function O(a, b, c) {
| + | |
− | var d;
| + | |
− | try {
| + | |
− | a && r.isFunction(d = a.promise) ? d.call(a).done(b).fail(c) : a && r.isFunction(d = a.then) ? d.call(a, b, c) : b.call(void 0, a)
| + | |
− | } catch (a) {
| + | |
− | c.call(void 0, a)
| + | |
− | }
| + | |
− | }
| + | |
− | r.extend({
| + | |
− | Deferred: function (b) {
| + | |
− | var c = [
| + | |
− | ["notify", "progress", r.Callbacks("memory"), r.Callbacks("memory"), 2],
| + | |
− | ["resolve", "done", r.Callbacks("once memory"), r.Callbacks("once memory"), 0, "resolved"],
| + | |
− | ["reject", "fail", r.Callbacks("once memory"), r.Callbacks("once memory"), 1, "rejected"]
| + | |
− | ],
| + | |
− | d = "pending",
| + | |
− | e = {
| + | |
− | state: function () {
| + | |
− | return d
| + | |
− | },
| + | |
− | always: function () {
| + | |
− | return f.done(arguments).fail(arguments), this
| + | |
− | },
| + | |
− | "catch": function (a) {
| + | |
− | return e.then(null, a)
| + | |
− | },
| + | |
− | pipe: function () {
| + | |
− | var a = arguments;
| + | |
− | return r.Deferred(function (b) {
| + | |
− | r.each(c, function (c, d) {
| + | |
− | var e = r.isFunction(a[d[4]]) && a[d[4]];
| + | |
− | f[d[1]](function () {
| + | |
− | var a = e && e.apply(this, arguments);
| + | |
− | a && r.isFunction(a.promise) ? a.promise().progress(b.notify).done(b.resolve).fail(b.reject) : b[d[0] + "With"](this, e ? [a] : arguments)
| + | |
− | })
| + | |
− | }), a = null
| + | |
− | }).promise()
| + | |
− | },
| + | |
− | then: function (b, d, e) {
| + | |
− | var f = 0;
| + | |
− | | + | |
− | function g(b, c, d, e) {
| + | |
− | return function () {
| + | |
− | var h = this,
| + | |
− | i = arguments,
| + | |
− | j = function () {
| + | |
− | var a, j;
| + | |
− | if (!(b < f)) {
| + | |
− | if (a = d.apply(h, i), a === c.promise()) throw new TypeError("Thenable self-resolution");
| + | |
− | j = a && ("object" == typeof a || "function" == typeof a) && a.then, r.isFunction(j) ? e ? j.call(a, g(f, c, M, e), g(f, c, N, e)) : (f++, j.call(a, g(f, c, M, e), g(f, c, N, e), g(f, c, M, c.notifyWith))) : (d !== M && (h = void 0, i = [a]), (e || c.resolveWith)(h, i))
| + | |
− | }
| + | |
− | },
| + | |
− | k = e ? j : function () {
| + | |
− | try {
| + | |
− | j()
| + | |
− | } catch (a) {
| + | |
− | r.Deferred.exceptionHook && r.Deferred.exceptionHook(a, k.stackTrace), b + 1 >= f && (d !== N && (h = void 0, i = [a]), c.rejectWith(h, i))
| + | |
− | }
| + | |
− | };
| + | |
− | b ? k() : (r.Deferred.getStackHook && (k.stackTrace = r.Deferred.getStackHook()), a.setTimeout(k))
| + | |
− | }
| + | |
− | }
| + | |
− | return r.Deferred(function (a) {
| + | |
− | c[0][3].add(g(0, a, r.isFunction(e) ? e : M, a.notifyWith)), c[1][3].add(g(0, a, r.isFunction(b) ? b : M)), c[2][3].add(g(0, a, r.isFunction(d) ? d : N))
| + | |
− | }).promise()
| + | |
− | },
| + | |
− | promise: function (a) {
| + | |
− | return null != a ? r.extend(a, e) : e
| + | |
− | }
| + | |
− | },
| + | |
− | f = {};
| + | |
− | return r.each(c, function (a, b) {
| + | |
− | var g = b[2],
| + | |
− | h = b[5];
| + | |
− | e[b[1]] = g.add, h && g.add(function () {
| + | |
− | d = h
| + | |
− | }, c[3 - a][2].disable, c[0][2].lock), g.add(b[3].fire), f[b[0]] = function () {
| + | |
− | return f[b[0] + "With"](this === f ? void 0 : this, arguments), this
| + | |
− | }, f[b[0] + "With"] = g.fireWith
| + | |
− | }), e.promise(f), b && b.call(f, f), f
| + | |
− | },
| + | |
− | when: function (a) {
| + | |
− | var b = arguments.length,
| + | |
− | c = b,
| + | |
− | d = Array(c),
| + | |
− | e = f.call(arguments),
| + | |
− | g = r.Deferred(),
| + | |
− | h = function (a) {
| + | |
− | return function (c) {
| + | |
− | d[a] = this, e[a] = arguments.length > 1 ? f.call(arguments) : c, --b || g.resolveWith(d, e)
| + | |
− | }
| + | |
− | };
| + | |
− | if (b <= 1 && (O(a, g.done(h(c)).resolve, g.reject), "pending" === g.state() || r.isFunction(e[c] && e[c].then))) return g.then();
| + | |
− | while (c--) O(e[c], h(c), g.reject);
| + | |
− | return g.promise()
| + | |
− | }
| + | |
− | });
| + | |
− | var P = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;
| + | |
− | r.Deferred.exceptionHook = function (b, c) {
| + | |
− | a.console && a.console.warn && b && P.test(b.name) && a.console.warn("jQuery.Deferred exception: " + b.message, b.stack, c)
| + | |
− | }, r.readyException = function (b) {
| + | |
− | a.setTimeout(function () {
| + | |
− | throw b
| + | |
− | })
| + | |
− | };
| + | |
− | var Q = r.Deferred();
| + | |
− | r.fn.ready = function (a) {
| + | |
− | return Q.then(a)["catch"](function (a) {
| + | |
− | r.readyException(a)
| + | |
− | }), this
| + | |
− | }, r.extend({
| + | |
− | isReady: !1,
| + | |
− | readyWait: 1,
| + | |
− | holdReady: function (a) {
| + | |
− | a ? r.readyWait++ : r.ready(!0)
| + | |
− | },
| + | |
− | ready: function (a) {
| + | |
− | (a === !0 ? --r.readyWait : r.isReady) || (r.isReady = !0, a !== !0 && --r.readyWait > 0 || Q.resolveWith(d, [r]))
| + | |
− | }
| + | |
− | }), r.ready.then = Q.then;
| + | |
− | | + | |
− | function R() {
| + | |
− | d.removeEventListener("DOMContentLoaded", R),
| + | |
− | a.removeEventListener("load", R), r.ready()
| + | |
− | }
| + | |
− | "complete" === d.readyState || "loading" !== d.readyState && !d.documentElement.doScroll ? a.setTimeout(r.ready) : (d.addEventListener("DOMContentLoaded", R), a.addEventListener("load", R));
| + | |
− | var S = function (a, b, c, d, e, f, g) {
| + | |
− | var h = 0,
| + | |
− | i = a.length,
| + | |
− | j = null == c;
| + | |
− | if ("object" === r.type(c)) {
| + | |
− | e = !0;
| + | |
− | for (h in c) S(a, b, h, c[h], !0, f, g)
| + | |
− | } else if (void 0 !== d && (e = !0, r.isFunction(d) || (g = !0), j && (g ? (b.call(a, d), b = null) : (j = b, b = function (a, b, c) {
| + | |
− | return j.call(r(a), c)
| + | |
− | })), b))
| + | |
− | for (; h < i; h++) b(a[h], c, g ? d : d.call(a[h], h, b(a[h], c)));
| + | |
− | return e ? a : j ? b.call(a) : i ? b(a[0], c) : f
| + | |
− | },
| + | |
− | T = function (a) {
| + | |
− | return 1 === a.nodeType || 9 === a.nodeType || !+a.nodeType
| + | |
− | };
| + | |
− | | + | |
− | function U() {
| + | |
− | this.expando = r.expando + U.uid++
| + | |
− | }
| + | |
− | U.uid = 1, U.prototype = {
| + | |
− | cache: function (a) {
| + | |
− | var b = a[this.expando];
| + | |
− | return b || (b = {}, T(a) && (a.nodeType ? a[this.expando] = b : Object.defineProperty(a, this.expando, {
| + | |
− | value: b,
| + | |
− | configurable: !0
| + | |
− | }))), b
| + | |
− | },
| + | |
− | set: function (a, b, c) {
| + | |
− | var d, e = this.cache(a);
| + | |
− | if ("string" == typeof b) e[r.camelCase(b)] = c;
| + | |
− | else
| + | |
− | for (d in b) e[r.camelCase(d)] = b[d];
| + | |
− | return e
| + | |
− | },
| + | |
− | get: function (a, b) {
| + | |
− | return void 0 === b ? this.cache(a) : a[this.expando] && a[this.expando][r.camelCase(b)]
| + | |
− | },
| + | |
− | access: function (a, b, c) {
| + | |
− | return void 0 === b || b && "string" == typeof b && void 0 === c ? this.get(a, b) : (this.set(a, b, c), void 0 !== c ? c : b)
| + | |
− | },
| + | |
− | remove: function (a, b) {
| + | |
− | var c, d = a[this.expando];
| + | |
− | if (void 0 !== d) {
| + | |
− | if (void 0 !== b) {
| + | |
− | r.isArray(b) ? b = b.map(r.camelCase) : (b = r.camelCase(b), b = b in d ? [b] : b.match(K) || []), c = b.length;
| + | |
− | while (c--) delete d[b[c]]
| + | |
− | }(void 0 === b || r.isEmptyObject(d)) && (a.nodeType ? a[this.expando] = void 0 : delete a[this.expando])
| + | |
− | }
| + | |
− | },
| + | |
− | hasData: function (a) {
| + | |
− | var b = a[this.expando];
| + | |
− | return void 0 !== b && !r.isEmptyObject(b)
| + | |
− | }
| + | |
− | };
| + | |
− | var V = new U,
| + | |
− | W = new U,
| + | |
− | X = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
| + | |
− | Y = /[A-Z]/g;
| + | |
− | | + | |
− | function Z(a) {
| + | |
− | return "true" === a || "false" !== a && ("null" === a ? null : a === +a + "" ? +a : X.test(a) ? JSON.parse(a) : a)
| + | |
− | }
| + | |
− | | + | |
− | function $(a, b, c) {
| + | |
− | var d;
| + | |
− | if (void 0 === c && 1 === a.nodeType)
| + | |
− | if (d = "data-" + b.replace(Y, "-$&").toLowerCase(), c = a.getAttribute(d), "string" == typeof c) {
| + | |
− | try {
| + | |
− | c = Z(c)
| + | |
− | } catch (e) {}
| + | |
− | W.set(a, b, c)
| + | |
− | } else c = void 0;
| + | |
− | return c
| + | |
− | }
| + | |
− | r.extend({
| + | |
− | hasData: function (a) {
| + | |
− | return W.hasData(a) || V.hasData(a)
| + | |
− | },
| + | |
− | data: function (a, b, c) {
| + | |
− | return W.access(a, b, c)
| + | |
− | },
| + | |
− | removeData: function (a, b) {
| + | |
− | W.remove(a, b)
| + | |
− | },
| + | |
− | _data: function (a, b, c) {
| + | |
− | return V.access(a, b, c)
| + | |
− | },
| + | |
− | _removeData: function (a, b) {
| + | |
− | V.remove(a, b)
| + | |
− | }
| + | |
− | }), r.fn.extend({
| + | |
− | data: function (a, b) {
| + | |
− | var c, d, e, f = this[0],
| + | |
− | g = f && f.attributes;
| + | |
− | if (void 0 === a) {
| + | |
− | if (this.length && (e = W.get(f), 1 === f.nodeType && !V.get(f, "hasDataAttrs"))) {
| + | |
− | c = g.length;
| + | |
− | while (c--) g[c] && (d = g[c].name, 0 === d.indexOf("data-") && (d = r.camelCase(d.slice(5)), $(f, d, e[d])));
| + | |
− | V.set(f, "hasDataAttrs", !0)
| + | |
− | }
| + | |
− | return e
| + | |
− | }
| + | |
− | return "object" == typeof a ? this.each(function () {
| + | |
− | W.set(this, a)
| + | |
− | }) : S(this, function (b) {
| + | |
− | var c;
| + | |
− | if (f && void 0 === b) {
| + | |
− | if (c = W.get(f, a), void 0 !== c) return c;
| + | |
− | if (c = $(f, a), void 0 !== c) return c
| + | |
− | } else this.each(function () {
| + | |
− | W.set(this, a, b)
| + | |
− | })
| + | |
− | }, null, b, arguments.length > 1, null, !0)
| + | |
− | },
| + | |
− | removeData: function (a) {
| + | |
− | return this.each(function () {
| + | |
− | W.remove(this, a)
| + | |
− | })
| + | |
− | }
| + | |
− | }), r.extend({
| + | |
− | queue: function (a, b, c) {
| + | |
− | var d;
| + | |
− | if (a) return b = (b || "fx") + "queue", d = V.get(a, b), c && (!d || r.isArray(c) ? d = V.access(a, b, r.makeArray(c)) : d.push(c)), d || []
| + | |
− | },
| + | |
− | dequeue: function (a, b) {
| + | |
− | b = b || "fx";
| + | |
− | var c = r.queue(a, b),
| + | |
− | d = c.length,
| + | |
− | e = c.shift(),
| + | |
− | f = r._queueHooks(a, b),
| + | |
− | g = function () {
| + | |
− | r.dequeue(a, b)
| + | |
− | };
| + | |
− | "inprogress" === e && (e = c.shift(), d--), e && ("fx" === b && c.unshift("inprogress"), delete f.stop, e.call(a, g, f)), !d && f && f.empty.fire()
| + | |
− | },
| + | |
− | _queueHooks: function (a, b) {
| + | |
− | var c = b + "queueHooks";
| + | |
− | return V.get(a, c) || V.access(a, c, {
| + | |
− | empty: r.Callbacks("once memory").add(function () {
| + | |
− | V.remove(a, [b + "queue", c])
| + | |
− | })
| + | |
− | })
| + | |
− | }
| + | |
− | }), r.fn.extend({
| + | |
− | queue: function (a, b) {
| + | |
− | var c = 2;
| + | |
− | return "string" != typeof a && (b = a, a = "fx", c--), arguments.length < c ? r.queue(this[0], a) : void 0 === b ? this : this.each(function () {
| + | |
− | var c = r.queue(this, a, b);
| + | |
− | r._queueHooks(this, a), "fx" === a && "inprogress" !== c[0] && r.dequeue(this, a)
| + | |
− | })
| + | |
− | },
| + | |
− | dequeue: function (a) {
| + | |
− | return this.each(function () {
| + | |
− | r.dequeue(this, a)
| + | |
− | })
| + | |
− | },
| + | |
− | clearQueue: function (a) {
| + | |
− | return this.queue(a || "fx", [])
| + | |
− | },
| + | |
− | promise: function (a, b) {
| + | |
− | var c, d = 1,
| + | |
− | e = r.Deferred(),
| + | |
− | f = this,
| + | |
− | g = this.length,
| + | |
− | h = function () {
| + | |
− | --d || e.resolveWith(f, [f])
| + | |
− | };
| + | |
− | "string" != typeof a && (b = a, a = void 0), a = a || "fx";
| + | |
− | while (g--) c = V.get(f[g], a + "queueHooks"), c && c.empty && (d++, c.empty.add(h));
| + | |
− | return h(), e.promise(b)
| + | |
− | }
| + | |
− | });
| + | |
− | var _ = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
| + | |
− | aa = new RegExp("^(?:([+-])=|)(" + _ + ")([a-z%]*)$", "i"),
| + | |
− | ba = ["Top", "Right", "Bottom", "Left"],
| + | |
− | ca = function (a, b) {
| + | |
− | return a = b || a, "none" === a.style.display || "" === a.style.display && r.contains(a.ownerDocument, a) && "none" === r.css(a, "display")
| + | |
− | },
| + | |
− | da = function (a, b, c, d) {
| + | |
− | var e, f, g = {};
| + | |
− | for (f in b) g[f] = a.style[f], a.style[f] = b[f];
| + | |
− | e = c.apply(a, d || []);
| + | |
− | for (f in b) a.style[f] = g[f];
| + | |
− | return e
| + | |
− | };
| + | |
− | | + | |
− | function ea(a, b, c, d) {
| + | |
− | var e, f = 1,
| + | |
− | g = 20,
| + | |
− | h = d ? function () {
| + | |
− | return d.cur()
| + | |
− | } : function () {
| + | |
− | return r.css(a, b, "")
| + | |
− | },
| + | |
− | i = h(),
| + | |
− | j = c && c[3] || (r.cssNumber[b] ? "" : "px"),
| + | |
− | k = (r.cssNumber[b] || "px" !== j && +i) && aa.exec(r.css(a, b));
| + | |
− | if (k && k[3] !== j) {
| + | |
− | j = j || k[3], c = c || [], k = +i || 1;
| + | |
− | do f = f || ".5", k /= f, r.style(a, b, k + j); while (f !== (f = h() / i) && 1 !== f && --g)
| + | |
− | }
| + | |
− | return c && (k = +k || +i || 0, e = c[1] ? k + (c[1] + 1) * c[2] : +c[2], d && (d.unit = j, d.start = k, d.end = e)), e
| + | |
− | }
| + | |
− | var fa = {};
| + | |
− | | + | |
− | function ga(a) {
| + | |
− | var b, c = a.ownerDocument,
| + | |
− | d = a.nodeName,
| + | |
− | e = fa[d];
| + | |
− | return e ? e : (b = c.body.appendChild(c.createElement(d)), e = r.css(b, "display"), b.parentNode.removeChild(b), "none" === e && (e = "block"), fa[d] = e, e)
| + | |
− | }
| + | |
− | | + | |
− | function ha(a, b) {
| + | |
− | for (var c, d, e = [], f = 0, g = a.length; f < g; f++) d = a[f], d.style && (c = d.style.display, b ? ("none" === c && (e[f] = V.get(d, "display") || null, e[f] || (d.style.display = "")), "" === d.style.display && ca(d) && (e[f] = ga(d))) : "none" !== c && (e[f] = "none", V.set(d, "display", c)));
| + | |
− | for (f = 0; f < g; f++) null != e[f] && (a[f].style.display = e[f]);
| + | |
− | return a
| + | |
− | }
| + | |
− | r.fn.extend({
| + | |
− | show: function () {
| + | |
− | return ha(this, !0)
| + | |
− | },
| + | |
− | hide: function () {
| + | |
− | return ha(this)
| + | |
− | },
| + | |
− | toggle: function (a) {
| + | |
− | return "boolean" == typeof a ? a ? this.show() : this.hide() : this.each(function () {
| + | |
− | ca(this) ? r(this).show() : r(this).hide()
| + | |
− | })
| + | |
− | }
| + | |
− | });
| + | |
− | var ia = /^(?:checkbox|radio)$/i,
| + | |
− | ja = /<([a-z][^\/\0>\x20\t\r\n\f]+)/i,
| + | |
− | ka = /^$|\/(?:java|ecma)script/i,
| + | |
− | la = {
| + | |
− | option: [1, "<select multiple='multiple'>", "</select>"],
| + | |
− | thead: [1, "<table>", "</table>"],
| + | |
− | col: [2, "<table><colgroup>", "</colgroup></table>"],
| + | |
− | tr: [2, "<table><tbody>", "</tbody></table>"],
| + | |
− | td: [3, "<table><tbody><tr>", "</tr></tbody></table>"],
| + | |
− | _default: [0, "", ""]
| + | |
− | };
| + | |
− | la.optgroup = la.option, la.tbody = la.tfoot = la.colgroup = la.caption = la.thead, la.th = la.td;
| + | |
− | | + | |
− | function ma(a, b) {
| + | |
− | var c;
| + | |
− | return c = "undefined" != typeof a.getElementsByTagName ? a.getElementsByTagName(b || "*") : "undefined" != typeof a.querySelectorAll ? a.querySelectorAll(b || "*") : [], void 0 === b || b && r.nodeName(a, b) ? r.merge([a], c) : c
| + | |
− | }
| + | |
− | | + | |
− | function na(a, b) {
| + | |
− | for (var c = 0, d = a.length; c < d; c++) V.set(a[c], "globalEval", !b || V.get(b[c], "globalEval"))
| + | |
− | }
| + | |
− | var oa = /<|&#?\w+;/;
| + | |
− | | + | |
− | function pa(a, b, c, d, e) {
| + | |
− | for (var f, g, h, i, j, k, l = b.createDocumentFragment(), m = [], n = 0, o = a.length; n < o; n++)
| + | |
− | if (f = a[n], f || 0 === f)
| + | |
− | if ("object" === r.type(f)) r.merge(m, f.nodeType ? [f] : f);
| + | |
− | else if (oa.test(f)) {
| + | |
− | g = g || l.appendChild(b.createElement("div")), h = (ja.exec(f) || ["", ""])[1].toLowerCase(), i = la[h] || la._default, g.innerHTML = i[1] + r.htmlPrefilter(f) + i[2], k = i[0];
| + | |
− | while (k--) g = g.lastChild;
| + | |
− | r.merge(m, g.childNodes), g = l.firstChild, g.textContent = ""
| + | |
− | } else m.push(b.createTextNode(f));
| + | |
− | l.textContent = "", n = 0;
| + | |
− | while (f = m[n++])
| + | |
− | if (d && r.inArray(f, d) > -1) e && e.push(f);
| + | |
− | else if (j = r.contains(f.ownerDocument, f), g = ma(l.appendChild(f), "script"), j && na(g), c) {
| + | |
− | k = 0;
| + | |
− | while (f = g[k++]) ka.test(f.type || "") && c.push(f)
| + | |
− | }
| + | |
− | return l
| + | |
− | }! function () {
| + | |
− | var a = d.createDocumentFragment(),
| + | |
− | b = a.appendChild(d.createElement("div")),
| + | |
− | c = d.createElement("input");
| + | |
− | c.setAttribute("type", "radio"), c.setAttribute("checked", "checked"), c.setAttribute("name", "t"), b.appendChild(c), o.checkClone = b.cloneNode(!0).cloneNode(!0).lastChild.checked, b.innerHTML = "<textarea>x</textarea>", o.noCloneChecked = !!b.cloneNode(!0).lastChild.defaultValue
| + | |
− | }();
| + | |
− | var qa = d.documentElement,
| + | |
− | ra = /^key/,
| + | |
− | sa = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,
| + | |
− | ta = /^([^.]*)(?:\.(.+)|)/;
| + | |
− | | + | |
− | function ua() {
| + | |
− | return !0
| + | |
− | }
| + | |
− | | + | |
− | function va() {
| + | |
− | return !1
| + | |
− | }
| + | |
− | | + | |
− | function wa() {
| + | |
− | try {
| + | |
− | return d.activeElement
| + | |
− | } catch (a) {}
| + | |
− | }
| + | |
− | | + | |
− | function xa(a, b, c, d, e, f) {
| + | |
− | var g, h;
| + | |
− | if ("object" == typeof b) {
| + | |
− | "string" != typeof c && (d = d || c, c = void 0);
| + | |
− | for (h in b) xa(a, h, c, d, b[h], f);
| + | |
− | return a
| + | |
− | }
| + | |
− | if (null == d && null == e ? (e = c, d = c = void 0) : null == e && ("string" == typeof c ? (e = d, d = void 0) : (e = d, d = c, c = void 0)), e === !1) e = va;
| + | |
− | else if (!e) return a;
| + | |
− | return 1 === f && (g = e, e = function (a) {
| + | |
− | return r().off(a), g.apply(this, arguments)
| + | |
− | }, e.guid = g.guid || (g.guid = r.guid++)), a.each(function () {
| + | |
− | r.event.add(this, b, e, d, c)
| + | |
− | })
| + | |
− | }
| + | |
− | r.event = {
| + | |
− | global: {},
| + | |
− | add: function (a, b, c, d, e) {
| + | |
− | var f, g, h, i, j, k, l, m, n, o, p, q = V.get(a);
| + | |
− | if (q) {
| + | |
− | c.handler && (f = c, c = f.handler, e = f.selector), e && r.find.matchesSelector(qa, e), c.guid || (c.guid = r.guid++), (i = q.events) || (i = q.events = {}), (g = q.handle) || (g = q.handle = function (b) {
| + | |
− | return "undefined" != typeof r && r.event.triggered !== b.type ? r.event.dispatch.apply(a, arguments) : void 0
| + | |
− | }), b = (b || "").match(K) || [""], j = b.length;
| + | |
− | while (j--) h = ta.exec(b[j]) || [], n = p = h[1], o = (h[2] || "").split(".").sort(), n && (l = r.event.special[n] || {}, n = (e ? l.delegateType : l.bindType) || n, l = r.event.special[n] || {}, k = r.extend({
| + | |
− | type: n,
| + | |
− | origType: p,
| + | |
− | data: d,
| + | |
− | handler: c,
| + | |
− | guid: c.guid,
| + | |
− | selector: e,
| + | |
− | needsContext: e && r.expr.match.needsContext.test(e),
| + | |
− | namespace: o.join(".")
| + | |
− | }, f), (m = i[n]) || (m = i[n] = [], m.delegateCount = 0, l.setup && l.setup.call(a, d, o, g) !== !1 || a.addEventListener && a.addEventListener(n, g)), l.add && (l.add.call(a, k), k.handler.guid || (k.handler.guid = c.guid)), e ? m.splice(m.delegateCount++, 0, k) : m.push(k), r.event.global[n] = !0)
| + | |
− | }
| + | |
− | },
| + | |
− | remove: function (a, b, c, d, e) {
| + | |
− | var f, g, h, i, j, k, l, m, n, o, p, q = V.hasData(a) && V.get(a);
| + | |
− | if (q && (i = q.events)) {
| + | |
− | b = (b || "").match(K) || [""], j = b.length;
| + | |
− | while (j--)
| + | |
− | if (h = ta.exec(b[j]) || [], n = p = h[1], o = (h[2] || "").split(".").sort(), n) {
| + | |
− | l = r.event.special[n] || {}, n = (d ? l.delegateType : l.bindType) || n, m = i[n] || [], h = h[2] && new RegExp("(^|\\.)" + o.join("\\.(?:.*\\.|)") + "(\\.|$)"), g = f = m.length;
| + | |
− | while (f--) k = m[f], !e && p !== k.origType || c && c.guid !== k.guid || h && !h.test(k.namespace) || d && d !== k.selector && ("**" !== d || !k.selector) || (m.splice(f, 1), k.selector && m.delegateCount--, l.remove && l.remove.call(a, k));
| + | |
− | g && !m.length && (l.teardown && l.teardown.call(a, o, q.handle) !== !1 || r.removeEvent(a, n, q.handle), delete i[n])
| + | |
− | } else
| + | |
− | for (n in i) r.event.remove(a, n + b[j], c, d, !0);
| + | |
− | r.isEmptyObject(i) && V.remove(a, "handle events")
| + | |
− | }
| + | |
− | },
| + | |
− | dispatch: function (a) {
| + | |
− | var b = r.event.fix(a),
| + | |
− | c, d, e, f, g, h, i = new Array(arguments.length),
| + | |
− | j = (V.get(this, "events") || {})[b.type] || [],
| + | |
− | k = r.event.special[b.type] || {};
| + | |
− | for (i[0] = b, c = 1; c < arguments.length; c++) i[c] = arguments[c];
| + | |
− | if (b.delegateTarget = this, !k.preDispatch || k.preDispatch.call(this, b) !== !1) {
| + | |
− | h = r.event.handlers.call(this, b, j), c = 0;
| + | |
− | while ((f = h[c++]) && !b.isPropagationStopped()) {
| + | |
− | b.currentTarget = f.elem, d = 0;
| + | |
− | while ((g = f.handlers[d++]) && !b.isImmediatePropagationStopped()) b.rnamespace && !b.rnamespace.test(g.namespace) || (b.handleObj = g, b.data = g.data, e = ((r.event.special[g.origType] || {}).handle || g.handler).apply(f.elem, i), void 0 !== e && (b.result = e) === !1 && (b.preventDefault(), b.stopPropagation()))
| + | |
− | }
| + | |
− | return k.postDispatch && k.postDispatch.call(this, b), b.result
| + | |
− | }
| + | |
− | },
| + | |
− | handlers: function (a, b) {
| + | |
− | var c, d, e, f, g, h = [],
| + | |
− | i = b.delegateCount,
| + | |
− | j = a.target;
| + | |
− | if (i && j.nodeType && !("click" === a.type && a.button >= 1))
| + | |
− | for (; j !== this; j = j.parentNode || this)
| + | |
− | if (1 === j.nodeType && ("click" !== a.type || j.disabled !== !0)) {
| + | |
− | for (f = [], g = {}, c = 0; c < i; c++) d = b[c], e = d.selector + " ", void 0 === g[e] && (g[e] = d.needsContext ? r(e, this).index(j) > -1 : r.find(e, this, null, [j]).length), g[e] && f.push(d);
| + | |
− | f.length && h.push({
| + | |
− | elem: j,
| + | |
− | handlers: f
| + | |
− | })
| + | |
− | }
| + | |
− | return j = this, i < b.length && h.push({
| + | |
− | elem: j,
| + | |
− | handlers: b.slice(i)
| + | |
− | }), h
| + | |
− | },
| + | |
− | addProp: function (a, b) {
| + | |
− | Object.defineProperty(r.Event.prototype, a, {
| + | |
− | enumerable: !0,
| + | |
− | configurable: !0,
| + | |
− | get: r.isFunction(b) ? function () {
| + | |
− | if (this.originalEvent) return b(this.originalEvent)
| + | |
− | } : function () {
| + | |
− | if (this.originalEvent) return this.originalEvent[a]
| + | |
− | },
| + | |
− | set: function (b) {
| + | |
− | Object.defineProperty(this, a, {
| + | |
− | enumerable: !0,
| + | |
− | configurable: !0,
| + | |
− | writable: !0,
| + | |
− | value: b
| + | |
− | })
| + | |
− | }
| + | |
− | })
| + | |
− | },
| + | |
− | fix: function (a) {
| + | |
− | return a[r.expando] ? a : new r.Event(a)
| + | |
− | },
| + | |
− | special: {
| + | |
− | load: {
| + | |
− | noBubble: !0
| + | |
− | },
| + | |
− | focus: {
| + | |
− | trigger: function () {
| + | |
− | if (this !== wa() && this.focus) return this.focus(), !1
| + | |
− | },
| + | |
− | delegateType: "focusin"
| + | |
− | },
| + | |
− | blur: {
| + | |
− | trigger: function () {
| + | |
− | if (this === wa() && this.blur) return this.blur(), !1
| + | |
− | },
| + | |
− | delegateType: "focusout"
| + | |
− | },
| + | |
− | click: {
| + | |
− | trigger: function () {
| + | |
− | if ("checkbox" === this.type && this.click && r.nodeName(this, "input")) return this.click(), !1
| + | |
− | },
| + | |
− | _default: function (a) {
| + | |
− | return r.nodeName(a.target, "a")
| + | |
− | }
| + | |
− | },
| + | |
− | beforeunload: {
| + | |
− | postDispatch: function (a) {
| + | |
− | void 0 !== a.result && a.originalEvent && (a.originalEvent.returnValue = a.result)
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | }, r.removeEvent = function (a, b, c) {
| + | |
− | a.removeEventListener && a.removeEventListener(b, c)
| + | |
− | }, r.Event = function (a, b) {
| + | |
− | return this instanceof r.Event ? (a && a.type ? (this.originalEvent = a, this.type = a.type, this.isDefaultPrevented = a.defaultPrevented || void 0 === a.defaultPrevented && a.returnValue === !1 ? ua : va, this.target = a.target && 3 === a.target.nodeType ? a.target.parentNode : a.target, this.currentTarget = a.currentTarget, this.relatedTarget = a.relatedTarget) : this.type = a, b && r.extend(this, b), this.timeStamp = a && a.timeStamp || r.now(), void(this[r.expando] = !0)) : new r.Event(a, b)
| + | |
− | }, r.Event.prototype = {
| + | |
− | constructor: r.Event,
| + | |
− | isDefaultPrevented: va,
| + | |
− | isPropagationStopped: va,
| + | |
− | isImmediatePropagationStopped: va,
| + | |
− | isSimulated: !1,
| + | |
− | preventDefault: function () {
| + | |
− | var a = this.originalEvent;
| + | |
− | this.isDefaultPrevented = ua, a && !this.isSimulated && a.preventDefault()
| + | |
− | },
| + | |
− | stopPropagation: function () {
| + | |
− | var a = this.originalEvent;
| + | |
− | this.isPropagationStopped = ua, a && !this.isSimulated && a.stopPropagation()
| + | |
− | },
| + | |
− | stopImmediatePropagation: function () {
| + | |
− | var a = this.originalEvent;
| + | |
− | this.isImmediatePropagationStopped = ua, a && !this.isSimulated && a.stopImmediatePropagation(), this.stopPropagation()
| + | |
− | }
| + | |
− | }, r.each({
| + | |
− | altKey: !0,
| + | |
− | bubbles: !0,
| + | |
− | cancelable: !0,
| + | |
− | changedTouches: !0,
| + | |
− | ctrlKey: !0,
| + | |
− | detail: !0,
| + | |
− | eventPhase: !0,
| + | |
− | metaKey: !0,
| + | |
− | pageX: !0,
| + | |
− | pageY: !0,
| + | |
− | shiftKey: !0,
| + | |
− | view: !0,
| + | |
− | "char": !0,
| + | |
− | charCode: !0,
| + | |
− | key: !0,
| + | |
− | keyCode: !0,
| + | |
− | button: !0,
| + | |
− | buttons: !0,
| + | |
− | clientX: !0,
| + | |
− | clientY: !0,
| + | |
− | offsetX: !0,
| + | |
− | offsetY: !0,
| + | |
− | pointerId: !0,
| + | |
− | pointerType: !0,
| + | |
− | screenX: !0,
| + | |
− | screenY: !0,
| + | |
− | targetTouches: !0,
| + | |
− | toElement: !0,
| + | |
− | touches: !0,
| + | |
− | which: function (a) {
| + | |
− | var b = a.button;
| + | |
− | return null == a.which && ra.test(a.type) ? null != a.charCode ? a.charCode : a.keyCode : !a.which && void 0 !== b && sa.test(a.type) ? 1 & b ? 1 : 2 & b ? 3 : 4 & b ? 2 : 0 : a.which
| + | |
− | }
| + | |
− | }, r.event.addProp), r.each({
| + | |
− | mouseenter: "mouseover",
| + | |
− | mouseleave: "mouseout",
| + | |
− | pointerenter: "pointerover",
| + | |
− | pointerleave: "pointerout"
| + | |
− | }, function (a, b) {
| + | |
− | r.event.special[a] = {
| + | |
− | delegateType: b,
| + | |
− | bindType: b,
| + | |
− | handle: function (a) {
| + | |
− | var c, d = this,
| + | |
− | e = a.relatedTarget,
| + | |
− | f = a.handleObj;
| + | |
− | return e && (e === d || r.contains(d, e)) || (a.type = f.origType, c = f.handler.apply(this, arguments), a.type = b), c
| + | |
− | }
| + | |
− | }
| + | |
− | }), r.fn.extend({
| + | |
− | on: function (a, b, c, d) {
| + | |
− | return xa(this, a, b, c, d)
| + | |
− | },
| + | |
− | one: function (a, b, c, d) {
| + | |
− | return xa(this, a, b, c, d, 1)
| + | |
− | },
| + | |
− | off: function (a, b, c) {
| + | |
− | var d, e;
| + | |
− | if (a && a.preventDefault && a.handleObj) return d = a.handleObj, r(a.delegateTarget).off(d.namespace ? d.origType + "." + d.namespace : d.origType, d.selector, d.handler), this;
| + | |
− | if ("object" == typeof a) {
| + | |
− | for (e in a) this.off(e, b, a[e]);
| + | |
− | return this
| + | |
− | }
| + | |
− | return b !== !1 && "function" != typeof b || (c = b, b = void 0), c === !1 && (c = va), this.each(function () {
| + | |
− | r.event.remove(this, a, c, b)
| + | |
− | })
| + | |
− | }
| + | |
− | });
| + | |
− | var ya = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([a-z][^\/\0>\x20\t\r\n\f]*)[^>]*)\/>/gi,
| + | |
− | za = /<script|<style|<link/i,
| + | |
− | Aa = /checked\s*(?:[^=]|=\s*.checked.)/i,
| + | |
− | Ba = /^true\/(.*)/,
| + | |
− | Ca = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;
| + | |
− | | + | |
− | function Da(a, b) {
| + | |
− | return r.nodeName(a, "table") && r.nodeName(11 !== b.nodeType ? b : b.firstChild, "tr") ? a.getElementsByTagName("tbody")[0] || a : a
| + | |
− | }
| + | |
− | | + | |
− | function Ea(a) {
| + | |
− | return a.type = (null !== a.getAttribute("type")) + "/" + a.type, a
| + | |
− | }
| + | |
− | | + | |
− | function Fa(a) {
| + | |
− | var b = Ba.exec(a.type);
| + | |
− | return b ? a.type = b[1] : a.removeAttribute("type"), a
| + | |
− | }
| + | |
− | | + | |
− | function Ga(a, b) {
| + | |
− | var c, d, e, f, g, h, i, j;
| + | |
− | if (1 === b.nodeType) {
| + | |
− | if (V.hasData(a) && (f = V.access(a), g = V.set(b, f), j = f.events)) {
| + | |
− | delete g.handle, g.events = {};
| + | |
− | for (e in j)
| + | |
− | for (c = 0, d = j[e].length; c < d; c++) r.event.add(b, e, j[e][c])
| + | |
− | }
| + | |
− | W.hasData(a) && (h = W.access(a), i = r.extend({}, h), W.set(b, i))
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function Ha(a, b) {
| + | |
− | var c = b.nodeName.toLowerCase();
| + | |
− | "input" === c && ia.test(a.type) ? b.checked = a.checked : "input" !== c && "textarea" !== c || (b.defaultValue = a.defaultValue)
| + | |
− | }
| + | |
− | | + | |
− | function Ia(a, b, c, d) {
| + | |
− | b = g.apply([], b);
| + | |
− | var e, f, h, i, j, k, l = 0,
| + | |
− | m = a.length,
| + | |
− | n = m - 1,
| + | |
− | q = b[0],
| + | |
− | s = r.isFunction(q);
| + | |
− | if (s || m > 1 && "string" == typeof q && !o.checkClone && Aa.test(q)) return a.each(function (e) {
| + | |
− | var f = a.eq(e);
| + | |
− | s && (b[0] = q.call(this, e, f.html())), Ia(f, b, c, d)
| + | |
− | });
| + | |
− | if (m && (e = pa(b, a[0].ownerDocument, !1, a, d), f = e.firstChild, 1 === e.childNodes.length && (e = f), f || d)) {
| + | |
− | for (h = r.map(ma(e, "script"), Ea), i = h.length; l < m; l++) j = e, l !== n && (j = r.clone(j, !0, !0), i && r.merge(h, ma(j, "script"))), c.call(a[l], j, l);
| + | |
− | if (i)
| + | |
− | for (k = h[h.length - 1].ownerDocument, r.map(h, Fa), l = 0; l < i; l++) j = h[l], ka.test(j.type || "") && !V.access(j, "globalEval") && r.contains(k, j) && (j.src ? r._evalUrl && r._evalUrl(j.src) : p(j.textContent.replace(Ca, ""), k))
| + | |
− | }
| + | |
− | return a
| + | |
− | }
| + | |
− | | + | |
− | function Ja(a, b, c) {
| + | |
− | for (var d, e = b ? r.filter(b, a) : a, f = 0; null != (d = e[f]); f++) c || 1 !== d.nodeType || r.cleanData(ma(d)), d.parentNode && (c && r.contains(d.ownerDocument, d) && na(ma(d, "script")), d.parentNode.removeChild(d));
| + | |
− | return a
| + | |
− | }
| + | |
− | r.extend({
| + | |
− | htmlPrefilter: function (a) {
| + | |
− | return a.replace(ya, "<$1></$2>")
| + | |
− | },
| + | |
− | clone: function (a, b, c) {
| + | |
− | var d, e, f, g, h = a.cloneNode(!0),
| + | |
− | i = r.contains(a.ownerDocument, a);
| + | |
− | if (!(o.noCloneChecked || 1 !== a.nodeType && 11 !== a.nodeType || r.isXMLDoc(a)))
| + | |
− | for (g = ma(h), f = ma(a), d = 0, e = f.length; d < e; d++) Ha(f[d], g[d]);
| + | |
− | if (b)
| + | |
− | if (c)
| + | |
− | for (f = f || ma(a), g = g || ma(h), d = 0, e = f.length; d < e; d++) Ga(f[d], g[d]);
| + | |
− | else Ga(a, h);
| + | |
− | return g = ma(h, "script"), g.length > 0 && na(g, !i && ma(a, "script")), h
| + | |
− | },
| + | |
− | cleanData: function (a) {
| + | |
− | for (var b, c, d, e = r.event.special, f = 0; void 0 !== (c = a[f]); f++)
| + | |
− | if (T(c)) {
| + | |
− | if (b = c[V.expando]) {
| + | |
− | if (b.events)
| + | |
− | for (d in b.events) e[d] ? r.event.remove(c, d) : r.removeEvent(c, d, b.handle);
| + | |
− | c[V.expando] = void 0
| + | |
− | }
| + | |
− | c[W.expando] && (c[W.expando] = void 0)
| + | |
− | }
| + | |
− | }
| + | |
− | }), r.fn.extend({
| + | |
− | detach: function (a) {
| + | |
− | return Ja(this, a, !0)
| + | |
− | },
| + | |
− | remove: function (a) {
| + | |
− | return Ja(this, a)
| + | |
− | },
| + | |
− | text: function (a) {
| + | |
− | return S(this, function (a) {
| + | |
− | return void 0 === a ? r.text(this) : this.empty().each(function () {
| + | |
− | 1 !== this.nodeType && 11 !== this.nodeType && 9 !== this.nodeType || (this.textContent = a)
| + | |
− | })
| + | |
− | }, null, a, arguments.length)
| + | |
− | },
| + | |
− | append: function () {
| + | |
− | return Ia(this, arguments, function (a) {
| + | |
− | if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
| + | |
− | var b = Da(this, a);
| + | |
− | b.appendChild(a)
| + | |
− | }
| + | |
− | })
| + | |
− | },
| + | |
− | prepend: function () {
| + | |
− | return Ia(this, arguments, function (a) {
| + | |
− | if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
| + | |
− | var b = Da(this, a);
| + | |
− | b.insertBefore(a, b.firstChild)
| + | |
− | }
| + | |
− | })
| + | |
− | },
| + | |
− | before: function () {
| + | |
− | return Ia(this, arguments, function (a) {
| + | |
− | this.parentNode && this.parentNode.insertBefore(a, this)
| + | |
− | })
| + | |
− | },
| + | |
− | after: function () {
| + | |
− | return Ia(this, arguments, function (a) {
| + | |
− | this.parentNode && this.parentNode.insertBefore(a, this.nextSibling)
| + | |
− | })
| + | |
− | },
| + | |
− | empty: function () {
| + | |
− | for (var a, b = 0; null != (a = this[b]); b++) 1 === a.nodeType && (r.cleanData(ma(a, !1)), a.textContent = "");
| + | |
− | return this
| + | |
− | },
| + | |
− | clone: function (a, b) {
| + | |
− | return a = null != a && a, b = null == b ? a : b, this.map(function () {
| + | |
− | return r.clone(this, a, b)
| + | |
− | })
| + | |
− | },
| + | |
− | html: function (a) {
| + | |
− | return S(this, function (a) {
| + | |
− | var b = this[0] || {},
| + | |
− | c = 0,
| + | |
− | d = this.length;
| + | |
− | if (void 0 === a && 1 === b.nodeType) return b.innerHTML;
| + | |
− | if ("string" == typeof a && !za.test(a) && !la[(ja.exec(a) || ["", ""])[1].toLowerCase()]) {
| + | |
− | a = r.htmlPrefilter(a);
| + | |
− | try {
| + | |
− | for (; c < d; c++) b = this[c] || {}, 1 === b.nodeType && (r.cleanData(ma(b, !1)), b.innerHTML = a);
| + | |
− | b = 0
| + | |
− | } catch (e) {}
| + | |
− | }
| + | |
− | b && this.empty().append(a)
| + | |
− | }, null, a, arguments.length)
| + | |
− | },
| + | |
− | replaceWith: function () {
| + | |
− | var a = [];
| + | |
− | return Ia(this, arguments, function (b) {
| + | |
− | var c = this.parentNode;
| + | |
− | r.inArray(this, a) < 0 && (r.cleanData(ma(this)), c && c.replaceChild(b, this))
| + | |
− | }, a)
| + | |
− | }
| + | |
− | }), r.each({
| + | |
− | appendTo: "append",
| + | |
− | prependTo: "prepend",
| + | |
− | insertBefore: "before",
| + | |
− | insertAfter: "after",
| + | |
− | replaceAll: "replaceWith"
| + | |
− | }, function (a, b) {
| + | |
− | r.fn[a] = function (a) {
| + | |
− | for (var c, d = [], e = r(a), f = e.length - 1, g = 0; g <= f; g++) c = g === f ? this : this.clone(!0), r(e[g])[b](c), h.apply(d, c.get());
| + | |
− | return this.pushStack(d)
| + | |
− | }
| + | |
− | });
| + | |
− | var Ka = /^margin/,
| + | |
− | La = new RegExp("^(" + _ + ")(?!px)[a-z%]+$", "i"),
| + | |
− | Ma = function (b) {
| + | |
− | var c = b.ownerDocument.defaultView;
| + | |
− | return c && c.opener || (c = a), c.getComputedStyle(b)
| + | |
− | };
| + | |
− | ! function () {
| + | |
− | function b() {
| + | |
− | if (i) {
| + | |
− | i.style.cssText = "box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%", i.innerHTML = "", qa.appendChild(h);
| + | |
− | var b = a.getComputedStyle(i);
| + | |
− | c = "1%" !== b.top, g = "2px" === b.marginLeft, e = "4px" === b.width, i.style.marginRight = "50%", f = "4px" === b.marginRight, qa.removeChild(h), i = null
| + | |
− | }
| + | |
− | }
| + | |
− | var c, e, f, g, h = d.createElement("div"),
| + | |
− | i = d.createElement("div");
| + | |
− | i.style && (i.style.backgroundClip = "content-box", i.cloneNode(!0).style.backgroundClip = "", o.clearCloneStyle = "content-box" === i.style.backgroundClip, h.style.cssText = "border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute", h.appendChild(i), r.extend(o, {
| + | |
− | pixelPosition: function () {
| + | |
− | return b(), c
| + | |
− | },
| + | |
− | boxSizingReliable: function () {
| + | |
− | return b(), e
| + | |
− | },
| + | |
− | pixelMarginRight: function () {
| + | |
− | return b(), f
| + | |
− | },
| + | |
− | reliableMarginLeft: function () {
| + | |
− | return b(), g
| + | |
− | }
| + | |
− | }))
| + | |
− | }();
| + | |
− | | + | |
− | function Na(a, b, c) {
| + | |
− | var d, e, f, g, h = a.style;
| + | |
− | return c = c || Ma(a), c && (g = c.getPropertyValue(b) || c[b], "" !== g || r.contains(a.ownerDocument, a) || (g = r.style(a, b)), !o.pixelMarginRight() && La.test(g) && Ka.test(b) && (d = h.width, e = h.minWidth, f = h.maxWidth, h.minWidth = h.maxWidth = h.width = g, g = c.width, h.width = d, h.minWidth = e, h.maxWidth = f)), void 0 !== g ? g + "" : g
| + | |
− | }
| + | |
− | | + | |
− | function Oa(a, b) {
| + | |
− | return {
| + | |
− | get: function () {
| + | |
− | return a() ? void delete this.get : (this.get = b).apply(this, arguments)
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | var Pa = /^(none|table(?!-c[ea]).+)/,
| + | |
− | Qa = {
| + | |
− | position: "absolute",
| + | |
− | visibility: "hidden",
| + | |
− | display: "block"
| + | |
− | },
| + | |
− | Ra = {
| + | |
− | letterSpacing: "0",
| + | |
− | fontWeight: "400"
| + | |
− | },
| + | |
− | Sa = ["Webkit", "Moz", "ms"],
| + | |
− | Ta = d.createElement("div").style;
| + | |
− | | + | |
− | function Ua(a) {
| + | |
− | if (a in Ta) return a;
| + | |
− | var b = a[0].toUpperCase() + a.slice(1),
| + | |
− | c = Sa.length;
| + | |
− | while (c--)
| + | |
− | if (a = Sa[c] + b, a in Ta) return a
| + | |
− | }
| + | |
− | | + | |
− | function Va(a, b, c) {
| + | |
− | var d = aa.exec(b);
| + | |
− | return d ? Math.max(0, d[2] - (c || 0)) + (d[3] || "px") : b
| + | |
− | }
| + | |
− | | + | |
− | function Wa(a, b, c, d, e) {
| + | |
− | var f, g = 0;
| + | |
− | for (f = c === (d ? "border" : "content") ? 4 : "width" === b ? 1 : 0; f < 4; f += 2) "margin" === c && (g += r.css(a, c + ba[f], !0, e)), d ? ("content" === c && (g -= r.css(a, "padding" + ba[f], !0, e)), "margin" !== c && (g -= r.css(a, "border" + ba[f] + "Width", !0, e))) : (g += r.css(a, "padding" + ba[f], !0, e), "padding" !== c && (g += r.css(a, "border" + ba[f] + "Width", !0, e)));
| + | |
− | return g
| + | |
− | }
| + | |
− | | + | |
− | function Xa(a, b, c) {
| + | |
− | var d, e = !0,
| + | |
− | f = Ma(a),
| + | |
− | g = "border-box" === r.css(a, "boxSizing", !1, f);
| + | |
− | if (a.getClientRects().length && (d = a.getBoundingClientRect()[b]), d <= 0 || null == d) {
| + | |
− | if (d = Na(a, b, f), (d < 0 || null == d) && (d = a.style[b]), La.test(d)) return d;
| + | |
− | e = g && (o.boxSizingReliable() || d === a.style[b]), d = parseFloat(d) || 0
| + | |
− | }
| + | |
− | return d + Wa(a, b, c || (g ? "border" : "content"), e, f) + "px"
| + | |
− | }
| + | |
− | r.extend({
| + | |
− | cssHooks: {
| + | |
− | opacity: {
| + | |
− | get: function (a, b) {
| + | |
− | if (b) {
| + | |
− | var c = Na(a, "opacity");
| + | |
− | return "" === c ? "1" : c
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | },
| + | |
− | cssNumber: {
| + | |
− | animationIterationCount: !0,
| + | |
− | columnCount: !0,
| + | |
− | fillOpacity: !0,
| + | |
− | flexGrow: !0,
| + | |
− | flexShrink: !0,
| + | |
− | fontWeight: !0,
| + | |
− | lineHeight: !0,
| + | |
− | opacity: !0,
| + | |
− | order: !0,
| + | |
− | orphans: !0,
| + | |
− | widows: !0,
| + | |
− | zIndex: !0,
| + | |
− | zoom: !0
| + | |
− | },
| + | |
− | cssProps: {
| + | |
− | "float": "cssFloat"
| + | |
− | },
| + | |
− | style: function (a, b, c, d) {
| + | |
− | if (a && 3 !== a.nodeType && 8 !== a.nodeType && a.style) {
| + | |
− | var e, f, g, h = r.camelCase(b),
| + | |
− | i = a.style;
| + | |
− | return b = r.cssProps[h] || (r.cssProps[h] = Ua(h) || h), g = r.cssHooks[b] || r.cssHooks[h], void 0 === c ? g && "get" in g && void 0 !== (e = g.get(a, !1, d)) ? e : i[b] : (f = typeof c, "string" === f && (e = aa.exec(c)) && e[1] && (c = ea(a, b, e), f = "number"), null != c && c === c && ("number" === f && (c += e && e[3] || (r.cssNumber[h] ? "" : "px")), o.clearCloneStyle || "" !== c || 0 !== b.indexOf("background") || (i[b] = "inherit"), g && "set" in g && void 0 === (c = g.set(a, c, d)) || (i[b] = c)), void 0)
| + | |
− | }
| + | |
− | },
| + | |
− | css: function (a, b, c, d) {
| + | |
− | var e, f, g, h = r.camelCase(b);
| + | |
− | return b = r.cssProps[h] || (r.cssProps[h] = Ua(h) || h), g = r.cssHooks[b] || r.cssHooks[h], g && "get" in g && (e = g.get(a, !0, c)), void 0 === e && (e = Na(a, b, d)), "normal" === e && b in Ra && (e = Ra[b]), "" === c || c ? (f = parseFloat(e), c === !0 || isFinite(f) ? f || 0 : e) : e
| + | |
− | }
| + | |
− | }), r.each(["height", "width"], function (a, b) {
| + | |
− | r.cssHooks[b] = {
| + | |
− | get: function (a, c, d) {
| + | |
− | if (c) return !Pa.test(r.css(a, "display")) || a.getClientRects().length && a.getBoundingClientRect().width ? Xa(a, b, d) : da(a, Qa, function () {
| + | |
− | return Xa(a, b, d)
| + | |
− | })
| + | |
− | },
| + | |
− | set: function (a, c, d) {
| + | |
− | var e, f = d && Ma(a),
| + | |
− | g = d && Wa(a, b, d, "border-box" === r.css(a, "boxSizing", !1, f), f);
| + | |
− | return g && (e = aa.exec(c)) && "px" !== (e[3] || "px") && (a.style[b] = c, c = r.css(a, b)), Va(a, c, g)
| + | |
− | }
| + | |
− | }
| + | |
− | }), r.cssHooks.marginLeft = Oa(o.reliableMarginLeft, function (a, b) {
| + | |
− | if (b) return (parseFloat(Na(a, "marginLeft")) || a.getBoundingClientRect().left - da(a, {
| + | |
− | marginLeft: 0
| + | |
− | }, function () {
| + | |
− | return a.getBoundingClientRect().left
| + | |
− | })) + "px"
| + | |
− | }), r.each({
| + | |
− | margin: "",
| + | |
− | padding: "",
| + | |
− | border: "Width"
| + | |
− | }, function (a, b) {
| + | |
− | r.cssHooks[a + b] = {
| + | |
− | expand: function (c) {
| + | |
− | for (var d = 0, e = {}, f = "string" == typeof c ? c.split(" ") : [c]; d < 4; d++) e[a + ba[d] + b] = f[d] || f[d - 2] || f[0];
| + | |
− | return e
| + | |
− | }
| + | |
− | }, Ka.test(a) || (r.cssHooks[a + b].set = Va)
| + | |
− | }), r.fn.extend({
| + | |
− | css: function (a, b) {
| + | |
− | return S(this, function (a, b, c) {
| + | |
− | var d, e, f = {},
| + | |
− | g = 0;
| + | |
− | if (r.isArray(b)) {
| + | |
− | for (d = Ma(a), e = b.length; g < e; g++) f[b[g]] = r.css(a, b[g], !1, d);
| + | |
− | return f
| + | |
− | }
| + | |
− | return void 0 !== c ? r.style(a, b, c) : r.css(a, b)
| + | |
− | }, a, b, arguments.length > 1)
| + | |
− | }
| + | |
− | });
| + | |
− | | + | |
− | function Ya(a, b, c, d, e) {
| + | |
− | return new Ya.prototype.init(a, b, c, d, e)
| + | |
− | }
| + | |
− | r.Tween = Ya, Ya.prototype = {
| + | |
− | constructor: Ya,
| + | |
− | init: function (a, b, c, d, e, f) {
| + | |
− | this.elem = a, this.prop = c, this.easing = e || r.easing._default, this.options = b, this.start = this.now = this.cur(), this.end = d, this.unit = f || (r.cssNumber[c] ? "" : "px")
| + | |
− | },
| + | |
− | cur: function () {
| + | |
− | var a = Ya.propHooks[this.prop];
| + | |
− | return a && a.get ? a.get(this) : Ya.propHooks._default.get(this)
| + | |
− | },
| + | |
− | run: function (a) {
| + | |
− | var b, c = Ya.propHooks[this.prop];
| + | |
− | return this.options.duration ? this.pos = b = r.easing[this.easing](a, this.options.duration * a, 0, 1, this.options.duration) : this.pos = b = a, this.now = (this.end - this.start) * b + this.start, this.options.step && this.options.step.call(this.elem, this.now, this), c && c.set ? c.set(this) : Ya.propHooks._default.set(this), this
| + | |
− | }
| + | |
− | }, Ya.prototype.init.prototype = Ya.prototype, Ya.propHooks = {
| + | |
− | _default: {
| + | |
− | get: function (a) {
| + | |
− | var b;
| + | |
− | return 1 !== a.elem.nodeType || null != a.elem[a.prop] && null == a.elem.style[a.prop] ? a.elem[a.prop] : (b = r.css(a.elem, a.prop, ""), b && "auto" !== b ? b : 0)
| + | |
− | },
| + | |
− | set: function (a) {
| + | |
− | r.fx.step[a.prop] ? r.fx.step[a.prop](a) : 1 !== a.elem.nodeType || null == a.elem.style[r.cssProps[a.prop]] && !r.cssHooks[a.prop] ? a.elem[a.prop] = a.now : r.style(a.elem, a.prop, a.now + a.unit)
| + | |
− | }
| + | |
− | }
| + | |
− | }, Ya.propHooks.scrollTop = Ya.propHooks.scrollLeft = {
| + | |
− | set: function (a) {
| + | |
− | a.elem.nodeType && a.elem.parentNode && (a.elem[a.prop] = a.now)
| + | |
− | }
| + | |
− | }, r.easing = {
| + | |
− | linear: function (a) {
| + | |
− | return a
| + | |
− | },
| + | |
− | swing: function (a) {
| + | |
− | return .5 - Math.cos(a * Math.PI) / 2
| + | |
− | },
| + | |
− | _default: "swing"
| + | |
− | }, r.fx = Ya.prototype.init, r.fx.step = {};
| + | |
− | var Za, $a, _a = /^(?:toggle|show|hide)$/,
| + | |
− | ab = /queueHooks$/;
| + | |
− | | + | |
− | function bb() {
| + | |
− | $a && (a.requestAnimationFrame(bb), r.fx.tick())
| + | |
− | }
| + | |
− | | + | |
− | function cb() {
| + | |
− | return a.setTimeout(function () {
| + | |
− | Za = void 0
| + | |
− | }), Za = r.now()
| + | |
− | }
| + | |
− | | + | |
− | function db(a, b) {
| + | |
− | var c, d = 0,
| + | |
− | e = {
| + | |
− | height: a
| + | |
− | };
| + | |
− | for (b = b ? 1 : 0; d < 4; d += 2 - b) c = ba[d], e["margin" + c] = e["padding" + c] = a;
| + | |
− | return b && (e.opacity = e.width = a), e
| + | |
− | }
| + | |
− | | + | |
− | function eb(a, b, c) {
| + | |
− | for (var d, e = (hb.tweeners[b] || []).concat(hb.tweeners["*"]), f = 0, g = e.length; f < g; f++)
| + | |
− | if (d = e[f].call(c, b, a)) return d
| + | |
− | }
| + | |
− | | + | |
− | function fb(a, b, c) {
| + | |
− | var d, e, f, g, h, i, j, k, l = "width" in b || "height" in b,
| + | |
− | m = this,
| + | |
− | n = {},
| + | |
− | o = a.style,
| + | |
− | p = a.nodeType && ca(a),
| + | |
− | q = V.get(a, "fxshow");
| + | |
− | c.queue || (g = r._queueHooks(a, "fx"), null == g.unqueued && (g.unqueued = 0, h = g.empty.fire, g.empty.fire = function () {
| + | |
− | g.unqueued || h()
| + | |
− | }), g.unqueued++, m.always(function () {
| + | |
− | m.always(function () {
| + | |
− | g.unqueued--, r.queue(a, "fx").length || g.empty.fire()
| + | |
− | })
| + | |
− | }));
| + | |
− | for (d in b)
| + | |
− | if (e = b[d], _a.test(e)) {
| + | |
− | if (delete b[d], f = f || "toggle" === e, e === (p ? "hide" : "show")) {
| + | |
− | if ("show" !== e || !q || void 0 === q[d]) continue;
| + | |
− | p = !0
| + | |
− | }
| + | |
− | n[d] = q && q[d] || r.style(a, d)
| + | |
− | }
| + | |
− | if (i = !r.isEmptyObject(b), i || !r.isEmptyObject(n)) {
| + | |
− | l && 1 === a.nodeType && (c.overflow = [o.overflow, o.overflowX, o.overflowY], j = q && q.display, null == j && (j = V.get(a, "display")), k = r.css(a, "display"), "none" === k && (j ? k = j : (ha([a], !0), j = a.style.display || j, k = r.css(a, "display"), ha([a]))), ("inline" === k || "inline-block" === k && null != j) && "none" === r.css(a, "float") && (i || (m.done(function () {
| + | |
− | o.display = j
| + | |
− | }), null == j && (k = o.display, j = "none" === k ? "" : k)), o.display = "inline-block")), c.overflow && (o.overflow = "hidden", m.always(function () {
| + | |
− | o.overflow = c.overflow[0], o.overflowX = c.overflow[1], o.overflowY = c.overflow[2]
| + | |
− | })), i = !1;
| + | |
− | for (d in n) i || (q ? "hidden" in q && (p = q.hidden) : q = V.access(a, "fxshow", {
| + | |
− | display: j
| + | |
− | }), f && (q.hidden = !p), p && ha([a], !0), m.done(function () {
| + | |
− | p || ha([a]), V.remove(a, "fxshow");
| + | |
− | for (d in n) r.style(a, d, n[d])
| + | |
− | })), i = eb(p ? q[d] : 0, d, m), d in q || (q[d] = i.start, p && (i.end = i.start, i.start = 0))
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function gb(a, b) {
| + | |
− | var c, d, e, f, g;
| + | |
− | for (c in a)
| + | |
− | if (d = r.camelCase(c), e = b[d], f = a[c], r.isArray(f) && (e = f[1], f = a[c] = f[0]), c !== d && (a[d] = f, delete a[c]), g = r.cssHooks[d], g && "expand" in g) {
| + | |
− | f = g.expand(f), delete a[d];
| + | |
− | for (c in f) c in a || (a[c] = f[c], b[c] = e)
| + | |
− | } else b[d] = e
| + | |
− | }
| + | |
− | | + | |
− | function hb(a, b, c) {
| + | |
− | var d, e, f = 0,
| + | |
− | g = hb.prefilters.length,
| + | |
− | h = r.Deferred().always(function () {
| + | |
− | delete i.elem
| + | |
− | }),
| + | |
− | i = function () {
| + | |
− | if (e) return !1;
| + | |
− | for (var b = Za || cb(), c = Math.max(0, j.startTime + j.duration - b), d = c / j.duration || 0, f = 1 - d, g = 0, i = j.tweens.length; g < i; g++) j.tweens[g].run(f);
| + | |
− | return h.notifyWith(a, [j, f, c]), f < 1 && i ? c : (h.resolveWith(a, [j]), !1)
| + | |
− | },
| + | |
− | j = h.promise({
| + | |
− | elem: a,
| + | |
− | props: r.extend({}, b),
| + | |
− | opts: r.extend(!0, {
| + | |
− | specialEasing: {},
| + | |
− | easing: r.easing._default
| + | |
− | }, c),
| + | |
− | originalProperties: b,
| + | |
− | originalOptions: c,
| + | |
− | startTime: Za || cb(),
| + | |
− | duration: c.duration,
| + | |
− | tweens: [],
| + | |
− | createTween: function (b, c) {
| + | |
− | var d = r.Tween(a, j.opts, b, c, j.opts.specialEasing[b] || j.opts.easing);
| + | |
− | return j.tweens.push(d), d
| + | |
− | },
| + | |
− | stop: function (b) {
| + | |
− | var c = 0,
| + | |
− | d = b ? j.tweens.length : 0;
| + | |
− | if (e) return this;
| + | |
− | for (e = !0; c < d; c++) j.tweens[c].run(1);
| + | |
− | return b ? (h.notifyWith(a, [j, 1, 0]), h.resolveWith(a, [j, b])) : h.rejectWith(a, [j, b]), this
| + | |
− | }
| + | |
− | }),
| + | |
− | k = j.props;
| + | |
− | for (gb(k, j.opts.specialEasing); f < g; f++)
| + | |
− | if (d = hb.prefilters[f].call(j, a, k, j.opts)) return r.isFunction(d.stop) && (r._queueHooks(j.elem, j.opts.queue).stop = r.proxy(d.stop, d)), d;
| + | |
− | return r.map(k, eb, j), r.isFunction(j.opts.start) && j.opts.start.call(a, j), r.fx.timer(r.extend(i, {
| + | |
− | elem: a,
| + | |
− | anim: j,
| + | |
− | queue: j.opts.queue
| + | |
− | })), j.progress(j.opts.progress).done(j.opts.done, j.opts.complete).fail(j.opts.fail).always(j.opts.always)
| + | |
− | }
| + | |
− | r.Animation = r.extend(hb, {
| + | |
− | tweeners: {
| + | |
− | "*": [function (a, b) {
| + | |
− | var c = this.createTween(a, b);
| + | |
− | return ea(c.elem, a, aa.exec(b), c), c
| + | |
− | }]
| + | |
− | },
| + | |
− | tweener: function (a, b) {
| + | |
− | r.isFunction(a) ? (b = a, a = ["*"]) : a = a.match(K);
| + | |
− | for (var c, d = 0, e = a.length; d < e; d++) c = a[d], hb.tweeners[c] = hb.tweeners[c] || [], hb.tweeners[c].unshift(b)
| + | |
− | },
| + | |
− | prefilters: [fb],
| + | |
− | prefilter: function (a, b) {
| + | |
− | b ? hb.prefilters.unshift(a) : hb.prefilters.push(a)
| + | |
− | }
| + | |
− | }), r.speed = function (a, b, c) {
| + | |
− | var e = a && "object" == typeof a ? r.extend({}, a) : {
| + | |
− | complete: c || !c && b || r.isFunction(a) && a,
| + | |
− | duration: a,
| + | |
− | easing: c && b || b && !r.isFunction(b) && b
| + | |
− | };
| + | |
− | return r.fx.off || d.hidden ? e.duration = 0 : "number" != typeof e.duration && (e.duration in r.fx.speeds ? e.duration = r.fx.speeds[e.duration] : e.duration = r.fx.speeds._default), null != e.queue && e.queue !== !0 || (e.queue = "fx"), e.old = e.complete, e.complete = function () {
| + | |
− | r.isFunction(e.old) && e.old.call(this), e.queue && r.dequeue(this, e.queue)
| + | |
− | }, e
| + | |
− | }, r.fn.extend({
| + | |
− | fadeTo: function (a, b, c, d) {
| + | |
− | return this.filter(ca).css("opacity", 0).show().end().animate({
| + | |
− | opacity: b
| + | |
− | }, a, c, d)
| + | |
− | },
| + | |
− | animate: function (a, b, c, d) {
| + | |
− | var e = r.isEmptyObject(a),
| + | |
− | f = r.speed(b, c, d),
| + | |
− | g = function () {
| + | |
− | var b = hb(this, r.extend({}, a), f);
| + | |
− | (e || V.get(this, "finish")) && b.stop(!0)
| + | |
− | };
| + | |
− | return g.finish = g, e || f.queue === !1 ? this.each(g) : this.queue(f.queue, g)
| + | |
− | },
| + | |
− | stop: function (a, b, c) {
| + | |
− | var d = function (a) {
| + | |
− | var b = a.stop;
| + | |
− | delete a.stop, b(c)
| + | |
− | };
| + | |
− | return "string" != typeof a && (c = b, b = a, a = void 0), b && a !== !1 && this.queue(a || "fx", []), this.each(function () {
| + | |
− | var b = !0,
| + | |
− | e = null != a && a + "queueHooks",
| + | |
− | f = r.timers,
| + | |
− | g = V.get(this);
| + | |
− | if (e) g[e] && g[e].stop && d(g[e]);
| + | |
− | else
| + | |
− | for (e in g) g[e] && g[e].stop && ab.test(e) && d(g[e]);
| + | |
− | for (e = f.length; e--;) f[e].elem !== this || null != a && f[e].queue !== a || (f[e].anim.stop(c), b = !1, f.splice(e, 1));
| + | |
− | !b && c || r.dequeue(this, a)
| + | |
− | })
| + | |
− | },
| + | |
− | finish: function (a) {
| + | |
− | return a !== !1 && (a = a || "fx"), this.each(function () {
| + | |
− | var b, c = V.get(this),
| + | |
− | d = c[a + "queue"],
| + | |
− | e = c[a + "queueHooks"],
| + | |
− | f = r.timers,
| + | |
− | g = d ? d.length : 0;
| + | |
− | for (c.finish = !0, r.queue(this, a, []), e && e.stop && e.stop.call(this, !0), b = f.length; b--;) f[b].elem === this && f[b].queue === a && (f[b].anim.stop(!0), f.splice(b, 1));
| + | |
− | for (b = 0; b < g; b++) d[b] && d[b].finish && d[b].finish.call(this);
| + | |
− | delete c.finish
| + | |
− | })
| + | |
− | }
| + | |
− | }), r.each(["toggle", "show", "hide"], function (a, b) {
| + | |
− | var c = r.fn[b];
| + | |
− | r.fn[b] = function (a, d, e) {
| + | |
− | return null == a || "boolean" == typeof a ? c.apply(this, arguments) : this.animate(db(b, !0), a, d, e)
| + | |
− | }
| + | |
− | }), r.each({
| + | |
− | slideDown: db("show"),
| + | |
− | slideUp: db("hide"),
| + | |
− | slideToggle: db("toggle"),
| + | |
− | fadeIn: {
| + | |
− | opacity: "show"
| + | |
− | },
| + | |
− | fadeOut: {
| + | |
− | opacity: "hide"
| + | |
− | },
| + | |
− | fadeToggle: {
| + | |
− | opacity: "toggle"
| + | |
− | }
| + | |
− | }, function (a, b) {
| + | |
− | r.fn[a] = function (a, c, d) {
| + | |
− | return this.animate(b, a, c, d)
| + | |
− | }
| + | |
− | }), r.timers = [], r.fx.tick = function () {
| + | |
− | var a, b = 0,
| + | |
− | c = r.timers;
| + | |
− | for (Za = r.now(); b < c.length; b++) a = c[b], a() || c[b] !== a || c.splice(b--, 1);
| + | |
− | c.length || r.fx.stop(), Za = void 0
| + | |
− | }, r.fx.timer = function (a) {
| + | |
− | r.timers.push(a), a() ? r.fx.start() : r.timers.pop()
| + | |
− | }, r.fx.interval = 13, r.fx.start = function () {
| + | |
− | $a || ($a = a.requestAnimationFrame ? a.requestAnimationFrame(bb) : a.setInterval(r.fx.tick, r.fx.interval))
| + | |
− | }, r.fx.stop = function () {
| + | |
− | a.cancelAnimationFrame ? a.cancelAnimationFrame($a) : a.clearInterval($a), $a = null
| + | |
− | }, r.fx.speeds = {
| + | |
− | slow: 600,
| + | |
− | fast: 200,
| + | |
− | _default: 400
| + | |
− | }, r.fn.delay = function (b, c) {
| + | |
− | return b = r.fx ? r.fx.speeds[b] || b : b, c = c || "fx", this.queue(c, function (c, d) {
| + | |
− | var e = a.setTimeout(c, b);
| + | |
− | d.stop = function () {
| + | |
− | a.clearTimeout(e)
| + | |
− | }
| + | |
− | })
| + | |
− | },
| + | |
− | function () {
| + | |
− | var a = d.createElement("input"),
| + | |
− | b = d.createElement("select"),
| + | |
− | c = b.appendChild(d.createElement("option"));
| + | |
− | a.type = "checkbox", o.checkOn = "" !== a.value, o.optSelected = c.selected, a = d.createElement("input"), a.value = "t", a.type = "radio", o.radioValue = "t" === a.value
| + | |
− | }();
| + | |
− | var ib, jb = r.expr.attrHandle;
| + | |
− | r.fn.extend({
| + | |
− | attr: function (a, b) {
| + | |
− | return S(this, r.attr, a, b, arguments.length > 1)
| + | |
− | },
| + | |
− | removeAttr: function (a) {
| + | |
− | return this.each(function () {
| + | |
− | r.removeAttr(this, a)
| + | |
− | })
| + | |
− | }
| + | |
− | }), r.extend({
| + | |
− | attr: function (a, b, c) {
| + | |
− | var d, e, f = a.nodeType;
| + | |
− | if (3 !== f && 8 !== f && 2 !== f) return "undefined" == typeof a.getAttribute ? r.prop(a, b, c) : (1 === f && r.isXMLDoc(a) || (e = r.attrHooks[b.toLowerCase()] || (r.expr.match.bool.test(b) ? ib : void 0)),
| + | |
− | void 0 !== c ? null === c ? void r.removeAttr(a, b) : e && "set" in e && void 0 !== (d = e.set(a, c, b)) ? d : (a.setAttribute(b, c + ""), c) : e && "get" in e && null !== (d = e.get(a, b)) ? d : (d = r.find.attr(a, b), null == d ? void 0 : d))
| + | |
− | },
| + | |
− | attrHooks: {
| + | |
− | type: {
| + | |
− | set: function (a, b) {
| + | |
− | if (!o.radioValue && "radio" === b && r.nodeName(a, "input")) {
| + | |
− | var c = a.value;
| + | |
− | return a.setAttribute("type", b), c && (a.value = c), b
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | },
| + | |
− | removeAttr: function (a, b) {
| + | |
− | var c, d = 0,
| + | |
− | e = b && b.match(K);
| + | |
− | if (e && 1 === a.nodeType)
| + | |
− | while (c = e[d++]) a.removeAttribute(c)
| + | |
− | }
| + | |
− | }), ib = {
| + | |
− | set: function (a, b, c) {
| + | |
− | return b === !1 ? r.removeAttr(a, c) : a.setAttribute(c, c), c
| + | |
− | }
| + | |
− | }, r.each(r.expr.match.bool.source.match(/\w+/g), function (a, b) {
| + | |
− | var c = jb[b] || r.find.attr;
| + | |
− | jb[b] = function (a, b, d) {
| + | |
− | var e, f, g = b.toLowerCase();
| + | |
− | return d || (f = jb[g], jb[g] = e, e = null != c(a, b, d) ? g : null, jb[g] = f), e
| + | |
− | }
| + | |
− | });
| + | |
− | var kb = /^(?:input|select|textarea|button)$/i,
| + | |
− | lb = /^(?:a|area)$/i;
| + | |
− | r.fn.extend({
| + | |
− | prop: function (a, b) {
| + | |
− | return S(this, r.prop, a, b, arguments.length > 1)
| + | |
− | },
| + | |
− | removeProp: function (a) {
| + | |
− | return this.each(function () {
| + | |
− | delete this[r.propFix[a] || a]
| + | |
− | })
| + | |
− | }
| + | |
− | }), r.extend({
| + | |
− | prop: function (a, b, c) {
| + | |
− | var d, e, f = a.nodeType;
| + | |
− | if (3 !== f && 8 !== f && 2 !== f) return 1 === f && r.isXMLDoc(a) || (b = r.propFix[b] || b, e = r.propHooks[b]), void 0 !== c ? e && "set" in e && void 0 !== (d = e.set(a, c, b)) ? d : a[b] = c : e && "get" in e && null !== (d = e.get(a, b)) ? d : a[b]
| + | |
− | },
| + | |
− | propHooks: {
| + | |
− | tabIndex: {
| + | |
− | get: function (a) {
| + | |
− | var b = r.find.attr(a, "tabindex");
| + | |
− | return b ? parseInt(b, 10) : kb.test(a.nodeName) || lb.test(a.nodeName) && a.href ? 0 : -1
| + | |
− | }
| + | |
− | }
| + | |
− | },
| + | |
− | propFix: {
| + | |
− | "for": "htmlFor",
| + | |
− | "class": "className"
| + | |
− | }
| + | |
− | }), o.optSelected || (r.propHooks.selected = {
| + | |
− | get: function (a) {
| + | |
− | var b = a.parentNode;
| + | |
− | return b && b.parentNode && b.parentNode.selectedIndex, null
| + | |
− | },
| + | |
− | set: function (a) {
| + | |
− | var b = a.parentNode;
| + | |
− | b && (b.selectedIndex, b.parentNode && b.parentNode.selectedIndex)
| + | |
− | }
| + | |
− | }), r.each(["tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable"], function () {
| + | |
− | r.propFix[this.toLowerCase()] = this
| + | |
− | });
| + | |
− | | + | |
− | function mb(a) {
| + | |
− | var b = a.match(K) || [];
| + | |
− | return b.join(" ")
| + | |
− | }
| + | |
− | | + | |
− | function nb(a) {
| + | |
− | return a.getAttribute && a.getAttribute("class") || ""
| + | |
− | }
| + | |
− | r.fn.extend({
| + | |
− | addClass: function (a) {
| + | |
− | var b, c, d, e, f, g, h, i = 0;
| + | |
− | if (r.isFunction(a)) return this.each(function (b) {
| + | |
− | r(this).addClass(a.call(this, b, nb(this)))
| + | |
− | });
| + | |
− | if ("string" == typeof a && a) {
| + | |
− | b = a.match(K) || [];
| + | |
− | while (c = this[i++])
| + | |
− | if (e = nb(c), d = 1 === c.nodeType && " " + mb(e) + " ") {
| + | |
− | g = 0;
| + | |
− | while (f = b[g++]) d.indexOf(" " + f + " ") < 0 && (d += f + " ");
| + | |
− | h = mb(d), e !== h && c.setAttribute("class", h)
| + | |
− | }
| + | |
− | }
| + | |
− | return this
| + | |
− | },
| + | |
− | removeClass: function (a) {
| + | |
− | var b, c, d, e, f, g, h, i = 0;
| + | |
− | if (r.isFunction(a)) return this.each(function (b) {
| + | |
− | r(this).removeClass(a.call(this, b, nb(this)))
| + | |
− | });
| + | |
− | if (!arguments.length) return this.attr("class", "");
| + | |
− | if ("string" == typeof a && a) {
| + | |
− | b = a.match(K) || [];
| + | |
− | while (c = this[i++])
| + | |
− | if (e = nb(c), d = 1 === c.nodeType && " " + mb(e) + " ") {
| + | |
− | g = 0;
| + | |
− | while (f = b[g++])
| + | |
− | while (d.indexOf(" " + f + " ") > -1) d = d.replace(" " + f + " ", " ");
| + | |
− | h = mb(d), e !== h && c.setAttribute("class", h)
| + | |
− | }
| + | |
− | }
| + | |
− | return this
| + | |
− | },
| + | |
− | toggleClass: function (a, b) {
| + | |
− | var c = typeof a;
| + | |
− | return "boolean" == typeof b && "string" === c ? b ? this.addClass(a) : this.removeClass(a) : r.isFunction(a) ? this.each(function (c) {
| + | |
− | r(this).toggleClass(a.call(this, c, nb(this), b), b)
| + | |
− | }) : this.each(function () {
| + | |
− | var b, d, e, f;
| + | |
− | if ("string" === c) {
| + | |
− | d = 0, e = r(this), f = a.match(K) || [];
| + | |
− | while (b = f[d++]) e.hasClass(b) ? e.removeClass(b) : e.addClass(b)
| + | |
− | } else void 0 !== a && "boolean" !== c || (b = nb(this), b && V.set(this, "__className__", b), this.setAttribute && this.setAttribute("class", b || a === !1 ? "" : V.get(this, "__className__") || ""))
| + | |
− | })
| + | |
− | },
| + | |
− | hasClass: function (a) {
| + | |
− | var b, c, d = 0;
| + | |
− | b = " " + a + " ";
| + | |
− | while (c = this[d++])
| + | |
− | if (1 === c.nodeType && (" " + mb(nb(c)) + " ").indexOf(b) > -1) return !0;
| + | |
− | return !1
| + | |
− | }
| + | |
− | });
| + | |
− | var ob = /\r/g;
| + | |
− | r.fn.extend({
| + | |
− | val: function (a) {
| + | |
− | var b, c, d, e = this[0]; {
| + | |
− | if (arguments.length) return d = r.isFunction(a), this.each(function (c) {
| + | |
− | var e;
| + | |
− | 1 === this.nodeType && (e = d ? a.call(this, c, r(this).val()) : a, null == e ? e = "" : "number" == typeof e ? e += "" : r.isArray(e) && (e = r.map(e, function (a) {
| + | |
− | return null == a ? "" : a + ""
| + | |
− | })), b = r.valHooks[this.type] || r.valHooks[this.nodeName.toLowerCase()], b && "set" in b && void 0 !== b.set(this, e, "value") || (this.value = e))
| + | |
− | });
| + | |
− | if (e) return b = r.valHooks[e.type] || r.valHooks[e.nodeName.toLowerCase()], b && "get" in b && void 0 !== (c = b.get(e, "value")) ? c : (c = e.value, "string" == typeof c ? c.replace(ob, "") : null == c ? "" : c)
| + | |
− | }
| + | |
− | }
| + | |
− | }), r.extend({
| + | |
− | valHooks: {
| + | |
− | option: {
| + | |
− | get: function (a) {
| + | |
− | var b = r.find.attr(a, "value");
| + | |
− | return null != b ? b : mb(r.text(a))
| + | |
− | }
| + | |
− | },
| + | |
− | select: {
| + | |
− | get: function (a) {
| + | |
− | var b, c, d, e = a.options,
| + | |
− | f = a.selectedIndex,
| + | |
− | g = "select-one" === a.type,
| + | |
− | h = g ? null : [],
| + | |
− | i = g ? f + 1 : e.length;
| + | |
− | for (d = f < 0 ? i : g ? f : 0; d < i; d++)
| + | |
− | if (c = e[d], (c.selected || d === f) && !c.disabled && (!c.parentNode.disabled || !r.nodeName(c.parentNode, "optgroup"))) {
| + | |
− | if (b = r(c).val(), g) return b;
| + | |
− | h.push(b)
| + | |
− | }
| + | |
− | return h
| + | |
− | },
| + | |
− | set: function (a, b) {
| + | |
− | var c, d, e = a.options,
| + | |
− | f = r.makeArray(b),
| + | |
− | g = e.length;
| + | |
− | while (g--) d = e[g], (d.selected = r.inArray(r.valHooks.option.get(d), f) > -1) && (c = !0);
| + | |
− | return c || (a.selectedIndex = -1), f
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | }), r.each(["radio", "checkbox"], function () {
| + | |
− | r.valHooks[this] = {
| + | |
− | set: function (a, b) {
| + | |
− | if (r.isArray(b)) return a.checked = r.inArray(r(a).val(), b) > -1
| + | |
− | }
| + | |
− | }, o.checkOn || (r.valHooks[this].get = function (a) {
| + | |
− | return null === a.getAttribute("value") ? "on" : a.value
| + | |
− | })
| + | |
− | });
| + | |
− | var pb = /^(?:focusinfocus|focusoutblur)$/;
| + | |
− | r.extend(r.event, {
| + | |
− | trigger: function (b, c, e, f) {
| + | |
− | var g, h, i, j, k, m, n, o = [e || d],
| + | |
− | p = l.call(b, "type") ? b.type : b,
| + | |
− | q = l.call(b, "namespace") ? b.namespace.split(".") : [];
| + | |
− | if (h = i = e = e || d, 3 !== e.nodeType && 8 !== e.nodeType && !pb.test(p + r.event.triggered) && (p.indexOf(".") > -1 && (q = p.split("."), p = q.shift(), q.sort()), k = p.indexOf(":") < 0 && "on" + p, b = b[r.expando] ? b : new r.Event(p, "object" == typeof b && b), b.isTrigger = f ? 2 : 3, b.namespace = q.join("."), b.rnamespace = b.namespace ? new RegExp("(^|\\.)" + q.join("\\.(?:.*\\.|)") + "(\\.|$)") : null, b.result = void 0, b.target || (b.target = e), c = null == c ? [b] : r.makeArray(c, [b]), n = r.event.special[p] || {}, f || !n.trigger || n.trigger.apply(e, c) !== !1)) {
| + | |
− | if (!f && !n.noBubble && !r.isWindow(e)) {
| + | |
− | for (j = n.delegateType || p, pb.test(j + p) || (h = h.parentNode); h; h = h.parentNode) o.push(h), i = h;
| + | |
− | i === (e.ownerDocument || d) && o.push(i.defaultView || i.parentWindow || a)
| + | |
− | }
| + | |
− | g = 0;
| + | |
− | while ((h = o[g++]) && !b.isPropagationStopped()) b.type = g > 1 ? j : n.bindType || p, m = (V.get(h, "events") || {})[b.type] && V.get(h, "handle"), m && m.apply(h, c), m = k && h[k], m && m.apply && T(h) && (b.result = m.apply(h, c), b.result === !1 && b.preventDefault());
| + | |
− | return b.type = p, f || b.isDefaultPrevented() || n._default && n._default.apply(o.pop(), c) !== !1 || !T(e) || k && r.isFunction(e[p]) && !r.isWindow(e) && (i = e[k], i && (e[k] = null), r.event.triggered = p, e[p](), r.event.triggered = void 0, i && (e[k] = i)), b.result
| + | |
− | }
| + | |
− | },
| + | |
− | simulate: function (a, b, c) {
| + | |
− | var d = r.extend(new r.Event, c, {
| + | |
− | type: a,
| + | |
− | isSimulated: !0
| + | |
− | });
| + | |
− | r.event.trigger(d, null, b)
| + | |
− | }
| + | |
− | }), r.fn.extend({
| + | |
− | trigger: function (a, b) {
| + | |
− | return this.each(function () {
| + | |
− | r.event.trigger(a, b, this)
| + | |
− | })
| + | |
− | },
| + | |
− | triggerHandler: function (a, b) {
| + | |
− | var c = this[0];
| + | |
− | if (c) return r.event.trigger(a, b, c, !0)
| + | |
− | }
| + | |
− | }), r.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "), function (a, b) {
| + | |
− | r.fn[b] = function (a, c) {
| + | |
− | return arguments.length > 0 ? this.on(b, null, a, c) : this.trigger(b)
| + | |
− | }
| + | |
− | }), r.fn.extend({
| + | |
− | hover: function (a, b) {
| + | |
− | return this.mouseenter(a).mouseleave(b || a)
| + | |
− | }
| + | |
− | }), o.focusin = "onfocusin" in a, o.focusin || r.each({
| + | |
− | focus: "focusin",
| + | |
− | blur: "focusout"
| + | |
− | }, function (a, b) {
| + | |
− | var c = function (a) {
| + | |
− | r.event.simulate(b, a.target, r.event.fix(a))
| + | |
− | };
| + | |
− | r.event.special[b] = {
| + | |
− | setup: function () {
| + | |
− | var d = this.ownerDocument || this,
| + | |
− | e = V.access(d, b);
| + | |
− | e || d.addEventListener(a, c, !0), V.access(d, b, (e || 0) + 1)
| + | |
− | },
| + | |
− | teardown: function () {
| + | |
− | var d = this.ownerDocument || this,
| + | |
− | e = V.access(d, b) - 1;
| + | |
− | e ? V.access(d, b, e) : (d.removeEventListener(a, c, !0), V.remove(d, b))
| + | |
− | }
| + | |
− | }
| + | |
− | });
| + | |
− | var qb = a.location,
| + | |
− | rb = r.now(),
| + | |
− | sb = /\?/;
| + | |
− | r.parseXML = function (b) {
| + | |
− | var c;
| + | |
− | if (!b || "string" != typeof b) return null;
| + | |
− | try {
| + | |
− | c = (new a.DOMParser).parseFromString(b, "text/xml")
| + | |
− | } catch (d) {
| + | |
− | c = void 0
| + | |
− | }
| + | |
− | return c && !c.getElementsByTagName("parsererror").length || r.error("Invalid XML: " + b), c
| + | |
− | };
| + | |
− | var tb = /\[\]$/,
| + | |
− | ub = /\r?\n/g,
| + | |
− | vb = /^(?:submit|button|image|reset|file)$/i,
| + | |
− | wb = /^(?:input|select|textarea|keygen)/i;
| + | |
− | | + | |
− | function xb(a, b, c, d) {
| + | |
− | var e;
| + | |
− | if (r.isArray(b)) r.each(b, function (b, e) {
| + | |
− | c || tb.test(a) ? d(a, e) : xb(a + "[" + ("object" == typeof e && null != e ? b : "") + "]", e, c, d)
| + | |
− | });
| + | |
− | else if (c || "object" !== r.type(b)) d(a, b);
| + | |
− | else
| + | |
− | for (e in b) xb(a + "[" + e + "]", b[e], c, d)
| + | |
− | }
| + | |
− | r.param = function (a, b) {
| + | |
− | var c, d = [],
| + | |
− | e = function (a, b) {
| + | |
− | var c = r.isFunction(b) ? b() : b;
| + | |
− | d[d.length] = encodeURIComponent(a) + "=" + encodeURIComponent(null == c ? "" : c)
| + | |
− | };
| + | |
− | if (r.isArray(a) || a.jquery && !r.isPlainObject(a)) r.each(a, function () {
| + | |
− | e(this.name, this.value)
| + | |
− | });
| + | |
− | else
| + | |
− | for (c in a) xb(c, a[c], b, e);
| + | |
− | return d.join("&")
| + | |
− | }, r.fn.extend({
| + | |
− | serialize: function () {
| + | |
− | return r.param(this.serializeArray())
| + | |
− | },
| + | |
− | serializeArray: function () {
| + | |
− | return this.map(function () {
| + | |
− | var a = r.prop(this, "elements");
| + | |
− | return a ? r.makeArray(a) : this
| + | |
− | }).filter(function () {
| + | |
− | var a = this.type;
| + | |
− | return this.name && !r(this).is(":disabled") && wb.test(this.nodeName) && !vb.test(a) && (this.checked || !ia.test(a))
| + | |
− | }).map(function (a, b) {
| + | |
− | var c = r(this).val();
| + | |
− | return null == c ? null : r.isArray(c) ? r.map(c, function (a) {
| + | |
− | return {
| + | |
− | name: b.name,
| + | |
− | value: a.replace(ub, "\r\n")
| + | |
− | }
| + | |
− | }) : {
| + | |
− | name: b.name,
| + | |
− | value: c.replace(ub, "\r\n")
| + | |
− | }
| + | |
− | }).get()
| + | |
− | }
| + | |
− | });
| + | |
− | var yb = /%20/g,
| + | |
− | zb = /#.*$/,
| + | |
− | Ab = /([?&])_=[^&]*/,
| + | |
− | Bb = /^(.*?):[ \t]*([^\r\n]*)$/gm,
| + | |
− | Cb = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,
| + | |
− | Db = /^(?:GET|HEAD)$/,
| + | |
− | Eb = /^\/\//,
| + | |
− | Fb = {},
| + | |
− | Gb = {},
| + | |
− | Hb = "*/".concat("*"),
| + | |
− | Ib = d.createElement("a");
| + | |
− | Ib.href = qb.href;
| + | |
− | | + | |
− | function Jb(a) {
| + | |
− | return function (b, c) {
| + | |
− | "string" != typeof b && (c = b, b = "*");
| + | |
− | var d, e = 0,
| + | |
− | f = b.toLowerCase().match(K) || [];
| + | |
− | if (r.isFunction(c))
| + | |
− | while (d = f[e++]) "+" === d[0] ? (d = d.slice(1) || "*", (a[d] = a[d] || []).unshift(c)) : (a[d] = a[d] || []).push(c)
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | function Kb(a, b, c, d) {
| + | |
− | var e = {},
| + | |
− | f = a === Gb;
| + | |
− | | + | |
− | function g(h) {
| + | |
− | var i;
| + | |
− | return e[h] = !0, r.each(a[h] || [], function (a, h) {
| + | |
− | var j = h(b, c, d);
| + | |
− | return "string" != typeof j || f || e[j] ? f ? !(i = j) : void 0 : (b.dataTypes.unshift(j), g(j), !1)
| + | |
− | }), i
| + | |
− | }
| + | |
− | return g(b.dataTypes[0]) || !e["*"] && g("*")
| + | |
− | }
| + | |
− | | + | |
− | function Lb(a, b) {
| + | |
− | var c, d, e = r.ajaxSettings.flatOptions || {};
| + | |
− | for (c in b) void 0 !== b[c] && ((e[c] ? a : d || (d = {}))[c] = b[c]);
| + | |
− | return d && r.extend(!0, a, d), a
| + | |
− | }
| + | |
− | | + | |
− | function Mb(a, b, c) {
| + | |
− | var d, e, f, g, h = a.contents,
| + | |
− | i = a.dataTypes;
| + | |
− | while ("*" === i[0]) i.shift(), void 0 === d && (d = a.mimeType || b.getResponseHeader("Content-Type"));
| + | |
− | if (d)
| + | |
− | for (e in h)
| + | |
− | if (h[e] && h[e].test(d)) {
| + | |
− | i.unshift(e);
| + | |
− | break
| + | |
− | }
| + | |
− | if (i[0] in c) f = i[0];
| + | |
− | else {
| + | |
− | for (e in c) {
| + | |
− | if (!i[0] || a.converters[e + " " + i[0]]) {
| + | |
− | f = e;
| + | |
− | break
| + | |
− | }
| + | |
− | g || (g = e)
| + | |
− | }
| + | |
− | f = f || g
| + | |
− | }
| + | |
− | if (f) return f !== i[0] && i.unshift(f), c[f]
| + | |
− | }
| + | |
− | | + | |
− | function Nb(a, b, c, d) {
| + | |
− | var e, f, g, h, i, j = {},
| + | |
− | k = a.dataTypes.slice();
| + | |
− | if (k[1])
| + | |
− | for (g in a.converters) j[g.toLowerCase()] = a.converters[g];
| + | |
− | f = k.shift();
| + | |
− | while (f)
| + | |
− | if (a.responseFields[f] && (c[a.responseFields[f]] = b), !i && d && a.dataFilter && (b = a.dataFilter(b, a.dataType)), i = f, f = k.shift())
| + | |
− | if ("*" === f) f = i;
| + | |
− | else if ("*" !== i && i !== f) {
| + | |
− | if (g = j[i + " " + f] || j["* " + f], !g)
| + | |
− | for (e in j)
| + | |
− | if (h = e.split(" "), h[1] === f && (g = j[i + " " + h[0]] || j["* " + h[0]])) {
| + | |
− | g === !0 ? g = j[e] : j[e] !== !0 && (f = h[0], k.unshift(h[1]));
| + | |
− | break
| + | |
− | }
| + | |
− | if (g !== !0)
| + | |
− | if (g && a["throws"]) b = g(b);
| + | |
− | else try {
| + | |
− | b = g(b)
| + | |
− | } catch (l) {
| + | |
− | return {
| + | |
− | state: "parsererror",
| + | |
− | error: g ? l : "No conversion from " + i + " to " + f
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | return {
| + | |
− | state: "success",
| + | |
− | data: b
| + | |
− | }
| + | |
− | }
| + | |
− | r.extend({
| + | |
− | active: 0,
| + | |
− | lastModified: {},
| + | |
− | etag: {},
| + | |
− | ajaxSettings: {
| + | |
− | url: qb.href,
| + | |
− | type: "GET",
| + | |
− | isLocal: Cb.test(qb.protocol),
| + | |
− | global: !0,
| + | |
− | processData: !0,
| + | |
− | async: !0,
| + | |
− | contentType: "application/x-www-form-urlencoded; charset=UTF-8",
| + | |
− | accepts: {
| + | |
− | "*": Hb,
| + | |
− | text: "text/plain",
| + | |
− | html: "text/html",
| + | |
− | xml: "application/xml, text/xml",
| + | |
− | json: "application/json, text/javascript"
| + | |
− | },
| + | |
− | contents: {
| + | |
− | xml: /\bxml\b/,
| + | |
− | html: /\bhtml/,
| + | |
− | json: /\bjson\b/
| + | |
− | },
| + | |
− | responseFields: {
| + | |
− | xml: "responseXML",
| + | |
− | text: "responseText",
| + | |
− | json: "responseJSON"
| + | |
− | },
| + | |
− | converters: {
| + | |
− | "* text": String,
| + | |
− | "text html": !0,
| + | |
− | "text json": JSON.parse,
| + | |
− | "text xml": r.parseXML
| + | |
− | },
| + | |
− | flatOptions: {
| + | |
− | url: !0,
| + | |
− | context: !0
| + | |
− | }
| + | |
− | },
| + | |
− | ajaxSetup: function (a, b) {
| + | |
− | return b ? Lb(Lb(a, r.ajaxSettings), b) : Lb(r.ajaxSettings, a)
| + | |
− | },
| + | |
− | ajaxPrefilter: Jb(Fb),
| + | |
− | ajaxTransport: Jb(Gb),
| + | |
− | ajax: function (b, c) {
| + | |
− | "object" == typeof b && (c = b, b = void 0), c = c || {};
| + | |
− | var e, f, g, h, i, j, k, l, m, n, o = r.ajaxSetup({}, c),
| + | |
− | p = o.context || o,
| + | |
− | q = o.context && (p.nodeType || p.jquery) ? r(p) : r.event,
| + | |
− | s = r.Deferred(),
| + | |
− | t = r.Callbacks("once memory"),
| + | |
− | u = o.statusCode || {},
| + | |
− | v = {},
| + | |
− | w = {},
| + | |
− | x = "canceled",
| + | |
− | y = {
| + | |
− | readyState: 0,
| + | |
− | getResponseHeader: function (a) {
| + | |
− | var b;
| + | |
− | if (k) {
| + | |
− | if (!h) {
| + | |
− | h = {};
| + | |
− | while (b = Bb.exec(g)) h[b[1].toLowerCase()] = b[2]
| + | |
− | }
| + | |
− | b = h[a.toLowerCase()]
| + | |
− | }
| + | |
− | return null == b ? null : b
| + | |
− | },
| + | |
− | getAllResponseHeaders: function () {
| + | |
− | return k ? g : null
| + | |
− | },
| + | |
− | setRequestHeader: function (a, b) {
| + | |
− | return null == k && (a = w[a.toLowerCase()] = w[a.toLowerCase()] || a, v[a] = b), this
| + | |
− | },
| + | |
− | overrideMimeType: function (a) {
| + | |
− | return null == k && (o.mimeType = a), this
| + | |
− | },
| + | |
− | statusCode: function (a) {
| + | |
− | var b;
| + | |
− | if (a)
| + | |
− | if (k) y.always(a[y.status]);
| + | |
− | else
| + | |
− | for (b in a) u[b] = [u[b], a[b]];
| + | |
− | return this
| + | |
− | },
| + | |
− | abort: function (a) {
| + | |
− | var b = a || x;
| + | |
− | return e && e.abort(b), A(0, b), this
| + | |
− | }
| + | |
− | };
| + | |
− | if (s.promise(y), o.url = ((b || o.url || qb.href) + "").replace(Eb, qb.protocol + "//"), o.type = c.method || c.type || o.method || o.type, o.dataTypes = (o.dataType || "*").toLowerCase().match(K) || [""], null == o.crossDomain) {
| + | |
− | j = d.createElement("a");
| + | |
− | try {
| + | |
− | j.href = o.url, j.href = j.href, o.crossDomain = Ib.protocol + "//" + Ib.host != j.protocol + "//" + j.host
| + | |
− | } catch (z) {
| + | |
− | o.crossDomain = !0
| + | |
− | }
| + | |
− | }
| + | |
− | if (o.data && o.processData && "string" != typeof o.data && (o.data = r.param(o.data, o.traditional)), Kb(Fb, o, c, y), k) return y;
| + | |
− | l = r.event && o.global, l && 0 === r.active++ && r.event.trigger("ajaxStart"), o.type = o.type.toUpperCase(), o.hasContent = !Db.test(o.type), f = o.url.replace(zb, ""), o.hasContent ? o.data && o.processData && 0 === (o.contentType || "").indexOf("application/x-www-form-urlencoded") && (o.data = o.data.replace(yb, "+")) : (n = o.url.slice(f.length), o.data && (f += (sb.test(f) ? "&" : "?") + o.data, delete o.data), o.cache === !1 && (f = f.replace(Ab, "$1"), n = (sb.test(f) ? "&" : "?") + "_=" + rb++ + n), o.url = f + n), o.ifModified && (r.lastModified[f] && y.setRequestHeader("If-Modified-Since", r.lastModified[f]), r.etag[f] && y.setRequestHeader("If-None-Match", r.etag[f])), (o.data && o.hasContent && o.contentType !== !1 || c.contentType) && y.setRequestHeader("Content-Type", o.contentType), y.setRequestHeader("Accept", o.dataTypes[0] && o.accepts[o.dataTypes[0]] ? o.accepts[o.dataTypes[0]] + ("*" !== o.dataTypes[0] ? ", " + Hb + "; q=0.01" : "") : o.accepts["*"]);
| + | |
− | for (m in o.headers) y.setRequestHeader(m, o.headers[m]);
| + | |
− | if (o.beforeSend && (o.beforeSend.call(p, y, o) === !1 || k)) return y.abort();
| + | |
− | if (x = "abort", t.add(o.complete), y.done(o.success), y.fail(o.error), e = Kb(Gb, o, c, y)) {
| + | |
− | if (y.readyState = 1, l && q.trigger("ajaxSend", [y, o]), k) return y;
| + | |
− | o.async && o.timeout > 0 && (i = a.setTimeout(function () {
| + | |
− | y.abort("timeout")
| + | |
− | }, o.timeout));
| + | |
− | try {
| + | |
− | k = !1, e.send(v, A)
| + | |
− | } catch (z) {
| + | |
− | if (k) throw z;
| + | |
− | A(-1, z)
| + | |
− | }
| + | |
− | } else A(-1, "No Transport");
| + | |
− | | + | |
− | function A(b, c, d, h) {
| + | |
− | var j, m, n, v, w, x = c;
| + | |
− | k || (k = !0, i && a.clearTimeout(i), e = void 0, g = h || "", y.readyState = b > 0 ? 4 : 0, j = b >= 200 && b < 300 || 304 === b, d && (v = Mb(o, y, d)), v = Nb(o, v, y, j), j ? (o.ifModified && (w = y.getResponseHeader("Last-Modified"), w && (r.lastModified[f] = w), w = y.getResponseHeader("etag"), w && (r.etag[f] = w)), 204 === b || "HEAD" === o.type ? x = "nocontent" : 304 === b ? x = "notmodified" : (x = v.state, m = v.data, n = v.error, j = !n)) : (n = x, !b && x || (x = "error", b < 0 && (b = 0))), y.status = b, y.statusText = (c || x) + "", j ? s.resolveWith(p, [m, x, y]) : s.rejectWith(p, [y, x, n]), y.statusCode(u), u = void 0, l && q.trigger(j ? "ajaxSuccess" : "ajaxError", [y, o, j ? m : n]), t.fireWith(p, [y, x]), l && (q.trigger("ajaxComplete", [y, o]), --r.active || r.event.trigger("ajaxStop")))
| + | |
− | }
| + | |
− | return y
| + | |
− | },
| + | |
− | getJSON: function (a, b, c) {
| + | |
− | return r.get(a, b, c, "json")
| + | |
− | },
| + | |
− | getScript: function (a, b) {
| + | |
− | return r.get(a, void 0, b, "script")
| + | |
− | }
| + | |
− | }), r.each(["get", "post"], function (a, b) {
| + | |
− | r[b] = function (a, c, d, e) {
| + | |
− | return r.isFunction(c) && (e = e || d, d = c, c = void 0), r.ajax(r.extend({
| + | |
− | url: a,
| + | |
− | type: b,
| + | |
− | dataType: e,
| + | |
− | data: c,
| + | |
− | success: d
| + | |
− | }, r.isPlainObject(a) && a))
| + | |
− | }
| + | |
− | }), r._evalUrl = function (a) {
| + | |
− | return r.ajax({
| + | |
− | url: a,
| + | |
− | type: "GET",
| + | |
− | dataType: "script",
| + | |
− | cache: !0,
| + | |
− | async: !1,
| + | |
− | global: !1,
| + | |
− | "throws": !0
| + | |
− | })
| + | |
− | }, r.fn.extend({
| + | |
− | wrapAll: function (a) {
| + | |
− | var b;
| + | |
− | return this[0] && (r.isFunction(a) && (a = a.call(this[0])), b = r(a, this[0].ownerDocument).eq(0).clone(!0), this[0].parentNode && b.insertBefore(this[0]), b.map(function () {
| + | |
− | var a = this;
| + | |
− | while (a.firstElementChild) a = a.firstElementChild;
| + | |
− | return a
| + | |
− | }).append(this)), this
| + | |
− | },
| + | |
− | wrapInner: function (a) {
| + | |
− | return r.isFunction(a) ? this.each(function (b) {
| + | |
− | r(this).wrapInner(a.call(this, b))
| + | |
− | }) : this.each(function () {
| + | |
− | var b = r(this),
| + | |
− | c = b.contents();
| + | |
− | c.length ? c.wrapAll(a) : b.append(a)
| + | |
− | })
| + | |
− | },
| + | |
− | wrap: function (a) {
| + | |
− | var b = r.isFunction(a);
| + | |
− | return this.each(function (c) {
| + | |
− | r(this).wrapAll(b ? a.call(this, c) : a)
| + | |
− | })
| + | |
− | },
| + | |
− | unwrap: function (a) {
| + | |
− | return this.parent(a).not("body").each(function () {
| + | |
− | r(this).replaceWith(this.childNodes)
| + | |
− | }), this
| + | |
− | }
| + | |
− | }), r.expr.pseudos.hidden = function (a) {
| + | |
− | return !r.expr.pseudos.visible(a)
| + | |
− | }, r.expr.pseudos.visible = function (a) {
| + | |
− | return !!(a.offsetWidth || a.offsetHeight || a.getClientRects().length)
| + | |
− | }, r.ajaxSettings.xhr = function () {
| + | |
− | try {
| + | |
− | return new a.XMLHttpRequest
| + | |
− | } catch (b) {}
| + | |
− | };
| + | |
− | var Ob = {
| + | |
− | 0: 200,
| + | |
− | 1223: 204
| + | |
− | },
| + | |
− | Pb = r.ajaxSettings.xhr();
| + | |
− | o.cors = !!Pb && "withCredentials" in Pb, o.ajax = Pb = !!Pb, r.ajaxTransport(function (b) {
| + | |
− | var c, d;
| + | |
− | if (o.cors || Pb && !b.crossDomain) return {
| + | |
− | send: function (e, f) {
| + | |
− | var g, h = b.xhr();
| + | |
− | if (h.open(b.type, b.url, b.async, b.username, b.password), b.xhrFields)
| + | |
− | for (g in b.xhrFields) h[g] = b.xhrFields[g];
| + | |
− | b.mimeType && h.overrideMimeType && h.overrideMimeType(b.mimeType), b.crossDomain || e["X-Requested-With"] || (e["X-Requested-With"] = "XMLHttpRequest");
| + | |
− | for (g in e) h.setRequestHeader(g, e[g]);
| + | |
− | c = function (a) {
| + | |
− | return function () {
| + | |
− | c && (c = d = h.onload = h.onerror = h.onabort = h.onreadystatechange = null, "abort" === a ? h.abort() : "error" === a ? "number" != typeof h.status ? f(0, "error") : f(h.status, h.statusText) : f(Ob[h.status] || h.status, h.statusText, "text" !== (h.responseType || "text") || "string" != typeof h.responseText ? {
| + | |
− | binary: h.response
| + | |
− | } : {
| + | |
− | text: h.responseText
| + | |
− | }, h.getAllResponseHeaders()))
| + | |
− | }
| + | |
− | }, h.onload = c(), d = h.onerror = c("error"), void 0 !== h.onabort ? h.onabort = d : h.onreadystatechange = function () {
| + | |
− | 4 === h.readyState && a.setTimeout(function () {
| + | |
− | c && d()
| + | |
− | })
| + | |
− | }, c = c("abort");
| + | |
− | try {
| + | |
− | h.send(b.hasContent && b.data || null)
| + | |
− | } catch (i) {
| + | |
− | if (c) throw i
| + | |
− | }
| + | |
− | },
| + | |
− | abort: function () {
| + | |
− | c && c()
| + | |
− | }
| + | |
− | }
| + | |
− | }), r.ajaxPrefilter(function (a) {
| + | |
− | a.crossDomain && (a.contents.script = !1)
| + | |
− | }), r.ajaxSetup({
| + | |
− | accepts: {
| + | |
− | script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"
| + | |
− | },
| + | |
− | contents: {
| + | |
− | script: /\b(?:java|ecma)script\b/
| + | |
− | },
| + | |
− | converters: {
| + | |
− | "text script": function (a) {
| + | |
− | return r.globalEval(a), a
| + | |
− | }
| + | |
− | }
| + | |
− | }), r.ajaxPrefilter("script", function (a) {
| + | |
− | void 0 === a.cache && (a.cache = !1), a.crossDomain && (a.type = "GET")
| + | |
− | }), r.ajaxTransport("script", function (a) {
| + | |
− | if (a.crossDomain) {
| + | |
− | var b, c;
| + | |
− | return {
| + | |
− | send: function (e, f) {
| + | |
− | b = r("<script>").prop({
| + | |
− | charset: a.scriptCharset,
| + | |
− | src: a.url
| + | |
− | }).on("load error", c = function (a) {
| + | |
− | b.remove(), c = null, a && f("error" === a.type ? 404 : 200, a.type)
| + | |
− | }), d.head.appendChild(b[0])
| + | |
− | },
| + | |
− | abort: function () {
| + | |
− | c && c()
| + | |
− | }
| + | |
− | }
| + | |
− | }
| + | |
− | });
| + | |
− | var Qb = [],
| + | |
− | Rb = /(=)\?(?=&|$)|\?\?/;
| + | |
− | r.ajaxSetup({
| + | |
− | jsonp: "callback",
| + | |
− | jsonpCallback: function () {
| + | |
− | var a = Qb.pop() || r.expando + "_" + rb++;
| + | |
− | return this[a] = !0, a
| + | |
− | }
| + | |
− | }), r.ajaxPrefilter("json jsonp", function (b, c, d) {
| + | |
− | var e, f, g, h = b.jsonp !== !1 && (Rb.test(b.url) ? "url" : "string" == typeof b.data && 0 === (b.contentType || "").indexOf("application/x-www-form-urlencoded") && Rb.test(b.data) && "data");
| + | |
− | if (h || "jsonp" === b.dataTypes[0]) return e = b.jsonpCallback = r.isFunction(b.jsonpCallback) ? b.jsonpCallback() : b.jsonpCallback, h ? b[h] = b[h].replace(Rb, "$1" + e) : b.jsonp !== !1 && (b.url += (sb.test(b.url) ? "&" : "?") + b.jsonp + "=" + e), b.converters["script json"] = function () {
| + | |
− | return g || r.error(e + " was not called"), g[0]
| + | |
− | }, b.dataTypes[0] = "json", f = a[e], a[e] = function () {
| + | |
− | g = arguments
| + | |
− | }, d.always(function () {
| + | |
− | void 0 === f ? r(a).removeProp(e) : a[e] = f, b[e] && (b.jsonpCallback = c.jsonpCallback, Qb.push(e)), g && r.isFunction(f) && f(g[0]), g = f = void 0
| + | |
− | }), "script"
| + | |
− | }), o.createHTMLDocument = function () {
| + | |
− | var a = d.implementation.createHTMLDocument("").body;
| + | |
− | return a.innerHTML = "<form></form><form></form>", 2 === a.childNodes.length
| + | |
− | }(), r.parseHTML = function (a, b, c) {
| + | |
− | if ("string" != typeof a) return [];
| + | |
− | "boolean" == typeof b && (c = b, b = !1);
| + | |
− | var e, f, g;
| + | |
− | return b || (o.createHTMLDocument ? (b = d.implementation.createHTMLDocument(""), e = b.createElement("base"), e.href = d.location.href, b.head.appendChild(e)) : b = d), f = B.exec(a), g = !c && [], f ? [b.createElement(f[1])] : (f = pa([a], b, g), g && g.length && r(g).remove(), r.merge([], f.childNodes))
| + | |
− | }, r.fn.load = function (a, b, c) {
| + | |
− | var d, e, f, g = this,
| + | |
− | h = a.indexOf(" ");
| + | |
− | return h > -1 && (d = mb(a.slice(h)), a = a.slice(0, h)), r.isFunction(b) ? (c = b, b = void 0) : b && "object" == typeof b && (e = "POST"), g.length > 0 && r.ajax({
| + | |
− | url: a,
| + | |
− | type: e || "GET",
| + | |
− | dataType: "html",
| + | |
− | data: b
| + | |
− | }).done(function (a) {
| + | |
− | f = arguments, g.html(d ? r("<div>").append(r.parseHTML(a)).find(d) : a)
| + | |
− | }).always(c && function (a, b) {
| + | |
− | g.each(function () {
| + | |
− | c.apply(this, f || [a.responseText, b, a])
| + | |
− | })
| + | |
− | }), this
| + | |
− | }, r.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"], function (a, b) {
| + | |
− | r.fn[b] = function (a) {
| + | |
− | return this.on(b, a)
| + | |
− | }
| + | |
− | }), r.expr.pseudos.animated = function (a) {
| + | |
− | return r.grep(r.timers, function (b) {
| + | |
− | return a === b.elem
| + | |
− | }).length
| + | |
− | };
| + | |
− | | + | |
− | function Sb(a) {
| + | |
− | return r.isWindow(a) ? a : 9 === a.nodeType && a.defaultView
| + | |
− | }
| + | |
− | r.offset = {
| + | |
− | setOffset: function (a, b, c) {
| + | |
− | var d, e, f, g, h, i, j, k = r.css(a, "position"),
| + | |
− | l = r(a),
| + | |
− | m = {};
| + | |
− | "static" === k && (a.style.position = "relative"), h = l.offset(), f = r.css(a, "top"), i = r.css(a, "left"), j = ("absolute" === k || "fixed" === k) && (f + i).indexOf("auto") > -1, j ? (d = l.position(), g = d.top, e = d.left) : (g = parseFloat(f) || 0, e = parseFloat(i) || 0), r.isFunction(b) && (b = b.call(a, c, r.extend({}, h))), null != b.top && (m.top = b.top - h.top + g), null != b.left && (m.left = b.left - h.left + e), "using" in b ? b.using.call(a, m) : l.css(m)
| + | |
− | }
| + | |
− | }, r.fn.extend({
| + | |
− | offset: function (a) {
| + | |
− | if (arguments.length) return void 0 === a ? this : this.each(function (b) {
| + | |
− | r.offset.setOffset(this, a, b)
| + | |
− | });
| + | |
− | var b, c, d, e, f = this[0];
| + | |
− | if (f) return f.getClientRects().length ? (d = f.getBoundingClientRect(), d.width || d.height ? (e = f.ownerDocument, c = Sb(e), b = e.documentElement, {
| + | |
− | top: d.top + c.pageYOffset - b.clientTop,
| + | |
− | left: d.left + c.pageXOffset - b.clientLeft
| + | |
− | }) : d) : {
| + | |
− | top: 0,
| + | |
− | left: 0
| + | |
− | }
| + | |
− | },
| + | |
− | position: function () {
| + | |
− | if (this[0]) {
| + | |
− | var a, b, c = this[0],
| + | |
− | d = {
| + | |
− | top: 0,
| + | |
− | left: 0
| + | |
− | };
| + | |
− | return "fixed" === r.css(c, "position") ? b = c.getBoundingClientRect() : (a = this.offsetParent(), b = this.offset(), r.nodeName(a[0], "html") || (d = a.offset()), d = {
| + | |
− | top: d.top + r.css(a[0], "borderTopWidth", !0),
| + | |
− | left: d.left + r.css(a[0], "borderLeftWidth", !0)
| + | |
− | }), {
| + | |
− | top: b.top - d.top - r.css(c, "marginTop", !0),
| + | |
− | left: b.left - d.left - r.css(c, "marginLeft", !0)
| + | |
− | }
| + | |
− | }
| + | |
− | },
| + | |
− | offsetParent: function () {
| + | |
− | return this.map(function () {
| + | |
− | var a = this.offsetParent;
| + | |
− | while (a && "static" === r.css(a, "position")) a = a.offsetParent;
| + | |
− | return a || qa
| + | |
− | })
| + | |
− | }
| + | |
− | }), r.each({
| + | |
− | scrollLeft: "pageXOffset",
| + | |
− | scrollTop: "pageYOffset"
| + | |
− | }, function (a, b) {
| + | |
− | var c = "pageYOffset" === b;
| + | |
− | r.fn[a] = function (d) {
| + | |
− | return S(this, function (a, d, e) {
| + | |
− | var f = Sb(a);
| + | |
− | return void 0 === e ? f ? f[b] : a[d] : void(f ? f.scrollTo(c ? f.pageXOffset : e, c ? e : f.pageYOffset) : a[d] = e)
| + | |
− | }, a, d, arguments.length)
| + | |
− | }
| + | |
− | }), r.each(["top", "left"], function (a, b) {
| + | |
− | r.cssHooks[b] = Oa(o.pixelPosition, function (a, c) {
| + | |
− | if (c) return c = Na(a, b), La.test(c) ? r(a).position()[b] + "px" : c
| + | |
− | })
| + | |
− | }), r.each({
| + | |
− | Height: "height",
| + | |
− | Width: "width"
| + | |
− | }, function (a, b) {
| + | |
− | r.each({
| + | |
− | padding: "inner" + a,
| + | |
− | content: b,
| + | |
− | "": "outer" + a
| + | |
− | }, function (c, d) {
| + | |
− | r.fn[d] = function (e, f) {
| + | |
− | var g = arguments.length && (c || "boolean" != typeof e),
| + | |
− | h = c || (e === !0 || f === !0 ? "margin" : "border");
| + | |
− | return S(this, function (b, c, e) {
| + | |
− | var f;
| + | |
− | return r.isWindow(b) ? 0 === d.indexOf("outer") ? b["inner" + a] : b.document.documentElement["client" + a] : 9 === b.nodeType ? (f = b.documentElement, Math.max(b.body["scroll" + a], f["scroll" + a], b.body["offset" + a], f["offset" + a], f["client" + a])) : void 0 === e ? r.css(b, c, h) : r.style(b, c, e, h)
| + | |
− | }, b, g ? e : void 0, g)
| + | |
− | }
| + | |
− | })
| + | |
− | }), r.fn.extend({
| + | |
− | bind: function (a, b, c) {
| + | |
− | return this.on(a, null, b, c)
| + | |
− | },
| + | |
− | unbind: function (a, b) {
| + | |
− | return this.off(a, null, b)
| + | |
− | },
| + | |
− | delegate: function (a, b, c, d) {
| + | |
− | return this.on(b, a, c, d)
| + | |
− | },
| + | |
− | undelegate: function (a, b, c) {
| + | |
− | return 1 === arguments.length ? this.off(a, "**") : this.off(b, a || "**", c)
| + | |
− | }
| + | |
− | }), r.parseJSON = JSON.parse, "function" == typeof define && define.amd && define("jquery", [], function () {
| + | |
− | return r
| + | |
− | });
| + | |
− | var Tb = a.jQuery,
| + | |
− | Ub = a.$;
| + | |
− | return r.noConflict = function (b) {
| + | |
− | return a.$ === r && (a.$ = Ub), b && a.jQuery === r && (a.jQuery = Tb), r
| + | |
− | }, b || (a.jQuery = a.$ = r), r
| + | |
− | });
| + | |
− | | + | |
− | </script>
| + | |
− | <script>
| + | |
− | /*!
| + | |
− | * Lightbox v2.9.0
| + | |
− | * by Lokesh Dhakar
| + | |
− | *
| + | |
− | * More info:
| + | |
− | * http://lokeshdhakar.com/projects/lightbox2/
| + | |
− | *
| + | |
− | * Copyright 2007, 2015 Lokesh Dhakar
| + | |
− | * Released under the MIT license
| + | |
− | * https://github.com/lokesh/lightbox2/blob/master/LICENSE
| + | |
− | */
| + | |
− | ! function (a, b) {
| + | |
− | "function" == typeof define && define.amd ? define(["jquery"], b) : "object" == typeof exports ? module.exports = b(require("jquery")) : a.lightbox = b(a.jQuery)
| + | |
− | }(this, function (a) {
| + | |
− | function b(b) {
| + | |
− | this.album = [], this.currentImageIndex = void 0, this.init(), this.options = a.extend({}, this.constructor.defaults), this.option(b)
| + | |
− | }
| + | |
− | return b.defaults = {
| + | |
− | albumLabel: "Image %1 of %2",
| + | |
− | alwaysShowNavOnTouchDevices: !1,
| + | |
− | fadeDuration: 600,
| + | |
− | fitImagesInViewport: !0,
| + | |
− | imageFadeDuration: 600,
| + | |
− | positionFromTop: 50,
| + | |
− | resizeDuration: 700,
| + | |
− | showImageNumberLabel: !0,
| + | |
− | wrapAround: !1,
| + | |
− | disableScrolling: !1,
| + | |
− | sanitizeTitle: !1
| + | |
− | }, b.prototype.option = function (b) {
| + | |
− | a.extend(this.options, b)
| + | |
− | }, b.prototype.imageCountLabel = function (a, b) {
| + | |
− | return this.options.albumLabel.replace(/%1/g, a).replace(/%2/g, b)
| + | |
− | }, b.prototype.init = function () {
| + | |
− | var b = this;
| + | |
− | a(document).ready(function () {
| + | |
− | b.enable(), b.build()
| + | |
− | })
| + | |
− | }, b.prototype.enable = function () {
| + | |
− | var b = this;
| + | |
− | a("body").on("click", "a[rel^=lightbox], area[rel^=lightbox], a[data-lightbox], area[data-lightbox]", function (c) {
| + | |
− | return b.start(a(c.currentTarget)), !1
| + | |
− | })
| + | |
− | }, b.prototype.build = function () {
| + | |
− | var b = this;
| + | |
− | a('<div id="lightboxOverlay" class="lightboxOverlay"></div><div id="lightbox" class="lightbox"><div class="lb-outerContainer"><div class="lb-container"><img class="lb-image" src="data:image/gif;base64,R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==" /><div class="lb-nav"><a class="lb-prev" href="" ></a><a class="lb-next" href="" ></a></div><div class="lb-loader"><a class="lb-cancel"></a></div></div></div><div class="lb-dataContainer"><div class="lb-data"><div class="lb-details"><span class="lb-caption"></span><span class="lb-number"></span></div><div class="lb-closeContainer"><a class="lb-close"></a></div></div></div></div>').appendTo(a("body")), this.$lightbox = a("#lightbox"), this.$overlay = a("#lightboxOverlay"), this.$outerContainer = this.$lightbox.find(".lb-outerContainer"), this.$container = this.$lightbox.find(".lb-container"), this.$image = this.$lightbox.find(".lb-image"), this.$nav = this.$lightbox.find(".lb-nav"), this.containerPadding = {
| + | |
− | top: parseInt(this.$container.css("padding-top"), 10),
| + | |
− | right: parseInt(this.$container.css("padding-right"), 10),
| + | |
− | bottom: parseInt(this.$container.css("padding-bottom"), 10),
| + | |
− | left: parseInt(this.$container.css("padding-left"), 10)
| + | |
− | }, this.imageBorderWidth = {
| + | |
− | top: parseInt(this.$image.css("border-top-width"), 10),
| + | |
− | right: parseInt(this.$image.css("border-right-width"), 10),
| + | |
− | bottom: parseInt(this.$image.css("border-bottom-width"), 10),
| + | |
− | left: parseInt(this.$image.css("border-left-width"), 10)
| + | |
− | }, this.$overlay.hide().on("click", function () {
| + | |
− | return b.end(), !1
| + | |
− | }), this.$lightbox.hide().on("click", function (c) {
| + | |
− | return "lightbox" === a(c.target).attr("id") && b.end(), !1
| + | |
− | }), this.$outerContainer.on("click", function (c) {
| + | |
− | return "lightbox" === a(c.target).attr("id") && b.end(), !1
| + | |
− | }), this.$lightbox.find(".lb-prev").on("click", function () {
| + | |
− | return 0 === b.currentImageIndex ? b.changeImage(b.album.length - 1) : b.changeImage(b.currentImageIndex - 1), !1
| + | |
− | }), this.$lightbox.find(".lb-next").on("click", function () {
| + | |
− | return b.currentImageIndex === b.album.length - 1 ? b.changeImage(0) : b.changeImage(b.currentImageIndex + 1), !1
| + | |
− | }), this.$nav.on("mousedown", function (a) {
| + | |
− | 3 === a.which && (b.$nav.css("pointer-events", "none"), b.$lightbox.one("contextmenu", function () {
| + | |
− | setTimeout(function () {
| + | |
− | this.$nav.css("pointer-events", "auto")
| + | |
− | }.bind(b), 0)
| + | |
− | }))
| + | |
− | }), this.$lightbox.find(".lb-loader, .lb-close").on("click", function () {
| + | |
− | return b.end(), !1
| + | |
− | })
| + | |
− | }, b.prototype.start = function (b) {
| + | |
− | function c(a) {
| + | |
− | d.album.push({
| + | |
− | link: a.attr("href"),
| + | |
− | title: a.attr("data-title") || a.attr("title")
| + | |
− | })
| + | |
− | }
| + | |
− | var d = this,
| + | |
− | e = a(window);
| + | |
− | e.on("resize", a.proxy(this.sizeOverlay, this)), a("select, object, embed").css({
| + | |
− | visibility: "hidden"
| + | |
− | }), this.sizeOverlay(), this.album = [];
| + | |
− | var f, g = 0,
| + | |
− | h = b.attr("data-lightbox");
| + | |
− | if (h) {
| + | |
− | f = a(b.prop("tagName") + '[data-lightbox="' + h + '"]');
| + | |
− | for (var i = 0; i < f.length; i = ++i) c(a(f[i])), f[i] === b[0] && (g = i)
| + | |
− | } else if ("lightbox" === b.attr("rel")) c(b);
| + | |
− | else {
| + | |
− | f = a(b.prop("tagName") + '[rel="' + b.attr("rel") + '"]');
| + | |
− | for (var j = 0; j < f.length; j = ++j) c(a(f[j])), f[j] === b[0] && (g = j)
| + | |
− | }
| + | |
− | var k = e.scrollTop() + this.options.positionFromTop,
| + | |
− | l = e.scrollLeft();
| + | |
− | this.$lightbox.css({
| + | |
− | top: k + "px",
| + | |
− | left: l + "px"
| + | |
− | }).fadeIn(this.options.fadeDuration), this.options.disableScrolling && a("body").addClass("lb-disable-scrolling"), this.changeImage(g)
| + | |
− | }, b.prototype.changeImage = function (b) {
| + | |
− | var c = this;
| + | |
− | this.disableKeyboardNav();
| + | |
− | var d = this.$lightbox.find(".lb-image");
| + | |
− | this.$overlay.fadeIn(this.options.fadeDuration), a(".lb-loader").fadeIn("slow"), this.$lightbox.find(".lb-image, .lb-nav, .lb-prev, .lb-next, .lb-dataContainer, .lb-numbers, .lb-caption").hide(), this.$outerContainer.addClass("animating");
| + | |
− | var e = new Image;
| + | |
− | e.onload = function () {
| + | |
− | var f, g, h, i, j, k, l;
| + | |
− | d.attr("src", c.album[b].link), f = a(e), d.width(e.width), d.height(e.height), c.options.fitImagesInViewport && (l = a(window).width(), k = a(window).height(), j = l - c.containerPadding.left - c.containerPadding.right - c.imageBorderWidth.left - c.imageBorderWidth.right - 20, i = k - c.containerPadding.top - c.containerPadding.bottom - c.imageBorderWidth.top - c.imageBorderWidth.bottom - 120, c.options.maxWidth && c.options.maxWidth < j && (j = c.options.maxWidth), c.options.maxHeight && c.options.maxHeight < j && (i = c.options.maxHeight), (e.width > j || e.height > i) && (e.width / j > e.height / i ? (h = j, g = parseInt(e.height / (e.width / h), 10), d.width(h), d.height(g)) : (g = i, h = parseInt(e.width / (e.height / g), 10), d.width(h), d.height(g)))), c.sizeContainer(d.width(), d.height())
| + | |
− | }, e.src = this.album[b].link, this.currentImageIndex = b
| + | |
− | }, b.prototype.sizeOverlay = function () {
| + | |
− | this.$overlay.width(a(document).width()).height(a(document).height())
| + | |
− | }, b.prototype.sizeContainer = function (a, b) {
| + | |
− | function c() {
| + | |
− | d.$lightbox.find(".lb-dataContainer").width(g), d.$lightbox.find(".lb-prevLink").height(h), d.$lightbox.find(".lb-nextLink").height(h), d.showImage()
| + | |
− | }
| + | |
− | var d = this,
| + | |
− | e = this.$outerContainer.outerWidth(),
| + | |
− | f = this.$outerContainer.outerHeight(),
| + | |
− | g = a + this.containerPadding.left + this.containerPadding.right + this.imageBorderWidth.left + this.imageBorderWidth.right,
| + | |
− | h = b + this.containerPadding.top + this.containerPadding.bottom + this.imageBorderWidth.top + this.imageBorderWidth.bottom;
| + | |
− | e !== g || f !== h ? this.$outerContainer.animate({
| + | |
− | width: g,
| + | |
− | height: h
| + | |
− | }, this.options.resizeDuration, "swing", function () {
| + | |
− | c()
| + | |
− | }) : c()
| + | |
− | }, b.prototype.showImage = function () {
| + | |
− | this.$lightbox.find(".lb-loader").stop(!0).hide(), this.$lightbox.find(".lb-image").fadeIn(this.options.imageFadeDuration), this.updateNav(), this.updateDetails(), this.preloadNeighboringImages(), this.enableKeyboardNav()
| + | |
− | }, b.prototype.updateNav = function () {
| + | |
− | var a = !1;
| + | |
− | try {
| + | |
− | document.createEvent("TouchEvent"), a = this.options.alwaysShowNavOnTouchDevices ? !0 : !1
| + | |
− | } catch (b) {}
| + | |
− | this.$lightbox.find(".lb-nav").show(), this.album.length > 1 && (this.options.wrapAround ? (a && this.$lightbox.find(".lb-prev, .lb-next").css("opacity", "1"), this.$lightbox.find(".lb-prev, .lb-next").show()) : (this.currentImageIndex > 0 && (this.$lightbox.find(".lb-prev").show(), a && this.$lightbox.find(".lb-prev").css("opacity", "1")), this.currentImageIndex < this.album.length - 1 && (this.$lightbox.find(".lb-next").show(), a && this.$lightbox.find(".lb-next").css("opacity", "1"))))
| + | |
− | }, b.prototype.updateDetails = function () {
| + | |
− | var b = this;
| + | |
− | if ("undefined" != typeof this.album[this.currentImageIndex].title && "" !== this.album[this.currentImageIndex].title) {
| + | |
− | var c = this.$lightbox.find(".lb-caption");
| + | |
− | this.options.sanitizeTitle ? c.text(this.album[this.currentImageIndex].title) : c.html(this.album[this.currentImageIndex].title), c.fadeIn("fast").find("a").on("click", function (b) {
| + | |
− | void 0 !== a(this).attr("target") ? window.open(a(this).attr("href"), a(this).attr("target")) : location.href = a(this).attr("href")
| + | |
− | })
| + | |
− | }
| + | |
− | if (this.album.length > 1 && this.options.showImageNumberLabel) {
| + | |
− | var d = this.imageCountLabel(this.currentImageIndex + 1, this.album.length);
| + | |
− | this.$lightbox.find(".lb-number").text(d).fadeIn("fast")
| + | |
− | } else this.$lightbox.find(".lb-number").hide();
| + | |
− | this.$outerContainer.removeClass("animating"), this.$lightbox.find(".lb-dataContainer").fadeIn(this.options.resizeDuration, function () {
| + | |
− | return b.sizeOverlay()
| + | |
− | })
| + | |
− | }, b.prototype.preloadNeighboringImages = function () {
| + | |
− | if (this.album.length > this.currentImageIndex + 1) {
| + | |
− | var a = new Image;
| + | |
− | a.src = this.album[this.currentImageIndex + 1].link
| + | |
− | }
| + | |
− | if (this.currentImageIndex > 0) {
| + | |
− | var b = new Image;
| + | |
− | b.src = this.album[this.currentImageIndex - 1].link
| + | |
− | }
| + | |
− | }, b.prototype.enableKeyboardNav = function () {
| + | |
− | a(document).on("keyup.keyboard", a.proxy(this.keyboardAction, this))
| + | |
− | }, b.prototype.disableKeyboardNav = function () {
| + | |
− | a(document).off(".keyboard")
| + | |
− | }, b.prototype.keyboardAction = function (a) {
| + | |
− | var b = 27,
| + | |
− | c = 37,
| + | |
− | d = 39,
| + | |
− | e = a.keyCode,
| + | |
− | f = String.fromCharCode(e).toLowerCase();
| + | |
− | e === b || f.match(/x|o|c/) ? this.end() : "p" === f || e === c ? 0 !== this.currentImageIndex ? this.changeImage(this.currentImageIndex - 1) : this.options.wrapAround && this.album.length > 1 && this.changeImage(this.album.length - 1) : ("n" === f || e === d) && (this.currentImageIndex !== this.album.length - 1 ? this.changeImage(this.currentImageIndex + 1) : this.options.wrapAround && this.album.length > 1 && this.changeImage(0))
| + | |
− | }, b.prototype.end = function () {
| + | |
− | this.disableKeyboardNav(), a(window).off("resize", this.sizeOverlay), this.$lightbox.fadeOut(this.options.fadeDuration), this.$overlay.fadeOut(this.options.fadeDuration), a("select, object, embed").css({
| + | |
− | visibility: "visible"
| + | |
− | }), this.options.disableScrolling && a("body").removeClass("lb-disable-scrolling")
| + | |
− | }, new b
| + | |
− | });
| + | |
− | //# sourceMappingURL=lightbox.min.map
| + | |
− | | + | |
− | </script>
| + | |
− | <script>
| + | |
− | /* --------------------------------------------------
| + | |
− | Initialization
| + | |
− | -------------------------------------------------- */
| + | |
− | | + | |
− | // Initialize all functions when the document is ready.
| + | |
− | $(document).ready(function () {
| + | |
− | initResize();
| + | |
− | initScroller();
| + | |
− | initAnimation();
| + | |
− | initIsotope();
| + | |
− | initContactAjax();
| + | |
− | });
| + | |
− | | + | |
− | /* --------------------------------------------------
| + | |
− | Resize
| + | |
− | -------------------------------------------------- */
| + | |
− | | + | |
− | function initResize() {
| + | |
− | var header = $(".header-text");
| + | |
− | $(window).scroll(function () {
| + | |
− | var scroll = $(window).scrollTop();
| + | |
− | if ($(".index-page").length > 0) {
| + | |
− | if (scroll >= 270) {
| + | |
− | header.addClass("remove");
| + | |
− | } else {
| + | |
− | header.removeClass("remove");
| + | |
− | }
| + | |
− | } else {
| + | |
− | if (scroll >= 120) {
| + | |
− | header.addClass("remove");
| + | |
− | } else {
| + | |
− | header.removeClass("remove");
| + | |
− | }
| + | |
− | }
| + | |
− | });
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /* --------------------------------------------------
| + | |
− | Scroll Nav
| + | |
− | -------------------------------------------------- */
| + | |
− | | + | |
− | function initScroller() {
| + | |
− | $('#scroll-page-content').localScroll({
| + | |
− | target: '#page-content'
| + | |
− | });
| + | |
− | $('#page-top').localScroll({
| + | |
− | target: 'body'
| + | |
− | });
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /* --------------------------------------------------
| + | |
− | Animation
| + | |
− | -------------------------------------------------- */
| + | |
− | | + | |
− | function initAnimation() {
| + | |
− | new WOW().init();
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /* --------------------------------------------------
| + | |
− | Isotope
| + | |
− | -------------------------------------------------- */
| + | |
− | | + | |
− | function initIsotope() {
| + | |
− | var initial_items = 5;
| + | |
− | var next_items = 3;
| + | |
− | // init Isotope
| + | |
− | var $isotopeContainer = $('.isotopeContainer').isotope({
| + | |
− | itemSelector: '.isotopeSelector',
| + | |
− | layoutMode: 'masonry'
| + | |
− | });
| + | |
− | // filter functions
| + | |
− | var filterFns = {};
| + | |
− | | + | |
− | // bind filter button click
| + | |
− | $('.isotopeFilters').on('click', 'button', function () {
| + | |
− | var filterValue = $(this).attr('data-filter');
| + | |
− | // use filterFn if matches value
| + | |
− | filterValue = filterFns[filterValue] || filterValue;
| + | |
− | $isotopeContainer.isotope({
| + | |
− | filter: filterValue
| + | |
− | });
| + | |
− | | + | |
− | updateFilterCounts();
| + | |
− | });
| + | |
− | | + | |
− | function updateFilterCounts() {
| + | |
− | // get filtered item elements
| + | |
− | var itemElems = $isotopeContainer.isotope('getFilteredItemElements');
| + | |
− | var count_items = $(itemElems).length;
| + | |
− | if (count_items > initial_items) {
| + | |
− | $('#isotopeShowMore').show();
| + | |
− | } else {
| + | |
− | $('#isotopeShowMore').hide();
| + | |
− | }
| + | |
− | if ($('.isotopeSelector').hasClass('visible-xs')) {
| + | |
− | $('.isotopeSelector').removeClass('visible-xs');
| + | |
− | }
| + | |
− | var index = 0;
| + | |
− | | + | |
− | $(itemElems).each(function () {
| + | |
− | if (index >= initial_items) {
| + | |
− | $(this).addClass('visible-xs');
| + | |
− | }
| + | |
− | index++;
| + | |
− | });
| + | |
− | $isotopeContainer.isotope('layout');
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | // change active class on buttons
| + | |
− | $('.filter-container').each(function (i, filterContainer) {
| + | |
− | var $filterContainer = $(filterContainer);
| + | |
− | $filterContainer.on('click', 'button', function () {
| + | |
− | $filterContainer.find('.active').removeClass('active');
| + | |
− | $(this).addClass('active');
| + | |
− | });
| + | |
− | });
| + | |
− | | + | |
− | // function load more item
| + | |
− | function showNextItems(pagination) {
| + | |
− | var itemsMax = $('.visible-xs').length;
| + | |
− | var itemsCount = 0;
| + | |
− | $('.visible-xs').each(function () {
| + | |
− | if (itemsCount < pagination) {
| + | |
− | $(this).removeClass('visible-xs');
| + | |
− | itemsCount++;
| + | |
− | }
| + | |
− | });
| + | |
− | if (itemsCount >= itemsMax) {
| + | |
− | $('#isotopeShowMore').hide();
| + | |
− | }
| + | |
− | $isotopeContainer.isotope('layout');
| + | |
− | }
| + | |
− | // function that hides items when page is loaded
| + | |
− | function hideItems(pagination) {
| + | |
− | var itemsMax = $('.isotopeSelector').length;
| + | |
− | var itemsCount = 0;
| + | |
− | $('.isotopeSelector').each(function () {
| + | |
− | if (itemsCount >= pagination) {
| + | |
− | $(this).addClass('visible-xs');
| + | |
− | }
| + | |
− | itemsCount++;
| + | |
− | });
| + | |
− | if (itemsCount < itemsMax || initial_items >= itemsMax) {
| + | |
− | $('#isotopeShowMore').hide();
| + | |
− | }
| + | |
− | $isotopeContainer.isotope('layout');
| + | |
− | }
| + | |
− | $('#isotopeShowMore').on('click', function (e) {
| + | |
− | e.preventDefault();
| + | |
− | showNextItems(next_items);
| + | |
− | });
| + | |
− | hideItems(initial_items);
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /* --------------------------------------------------
| + | |
− | Ajax Contact Form
| + | |
− | -------------------------------------------------- */
| + | |
− | | + | |
− | function initContactAjax() {
| + | |
− | $("#submit_btn").click(function () {
| + | |
− | | + | |
− | var proceed = true;
| + | |
− | //simple validation at client's end
| + | |
− | //loop through each field and we simply change border color to red for invalid fields
| + | |
− | $("#contact_form input[required=true], #contact_form textarea[required=true]").each(function () {
| + | |
− | $(this).css('border-color', '');
| + | |
− | if (!$.trim($(this).val())) { //if this field is empty
| + | |
− | $(this).css('border-color', 'red'); //change border color to red
| + | |
− | proceed = false; //set do not proceed flag
| + | |
− | }
| + | |
− | //check invalid email
| + | |
− | var email_reg = /^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/;
| + | |
− | if ($(this).attr("type") == "email" && !email_reg.test($.trim($(this).val()))) {
| + | |
− | $(this).css('border-color', 'red'); //change border color to red
| + | |
− | proceed = false; //set do not proceed flag
| + | |
− | }
| + | |
− | });
| + | |
− | | + | |
− | if (proceed) //everything looks good! proceed...
| + | |
− | {
| + | |
− | //get input field values data to be sent to server
| + | |
− | post_data = {
| + | |
− | 'user_name': $('input[name=name]').val(),
| + | |
− | 'user_email': $('input[name=email]').val(),
| + | |
− | <!-- 'country_code' : $('input[name=phone1]').val(), -->
| + | |
− | <!-- 'phone_number' : $('input[name=phone2]').val(), -->
| + | |
− | 'subject': $('select[name=subject]').val(),
| + | |
− | 'msg': $('textarea[name=message]').val()
| + | |
− | };
| + | |
− | | + | |
− | //Ajax post data to server
| + | |
− | $.post('contact.php', post_data, function (response) {
| + | |
− | if (response.type == 'error') { //load json data from server and output message
| + | |
− | output = '<div class="error">' + response.text + '</div>';
| + | |
− | } else {
| + | |
− | output = '<div class="success">' + response.text + '</div>';
| + | |
− | //reset values in all input fields
| + | |
− | $("#contact_form input[required=true], #contact_form textarea[required=true]").val('');
| + | |
− | $("#contact_form #contact_body").slideUp(); //hide form after success
| + | |
− | }
| + | |
− | $("#contact_form #contact_results").hide().html(output).slideDown();
| + | |
− | }, 'json');
| + | |
− | }
| + | |
− | });
| + | |
− | | + | |
− | //reset previously set border colors and hide all message on .keyup()
| + | |
− | $("#contact_form input[required=true], #contact_form textarea[required=true]").keyup(function () {
| + | |
− | $(this).css('border-color', '');
| + | |
− | $("#result").slideUp();
| + | |
− | });
| + | |
− | }
| + | |
− | | + | |
− | </script>
| + | |
− | <script>
| + | |
− | /*! Respond.js v1.4.2: min/max-width media query polyfill * Copyright 2013 Scott Jehl
| + | |
− | * Licensed under https://github.com/scottjehl/Respond/blob/master/LICENSE-MIT
| + | |
− | * */
| + | |
− | | + | |
− | ! function (a) {
| + | |
− | "use strict";
| + | |
− | a.matchMedia = a.matchMedia || function (a) {
| + | |
− | var b, c = a.documentElement,
| + | |
− | d = c.firstElementChild || c.firstChild,
| + | |
− | e = a.createElement("body"),
| + | |
− | f = a.createElement("div");
| + | |
− | return f.id = "mq-test-1", f.style.cssText = "position:absolute;top:-100em", e.style.background = "none", e.appendChild(f),
| + | |
− | function (a) {
| + | |
− | return f.innerHTML = '­<style media="' + a + '"> #mq-test-1 { width: 42px; }</style>', c.insertBefore(e, d), b = 42 === f.offsetWidth, c.removeChild(e), {
| + | |
− | matches: b,
| + | |
− | media: a
| + | |
− | }
| + | |
− | }
| + | |
− | }(a.document)
| + | |
− | }(this),
| + | |
− | function (a) {
| + | |
− | "use strict";
| + | |
− | | + | |
− | function b() {
| + | |
− | u(!0)
| + | |
− | }
| + | |
− | var c = {};
| + | |
− | a.respond = c, c.update = function () {};
| + | |
− | var d = [],
| + | |
− | e = function () {
| + | |
− | var b = !1;
| + | |
− | try {
| + | |
− | b = new a.XMLHttpRequest
| + | |
− | } catch (c) {
| + | |
− | b = new a.ActiveXObject("Microsoft.XMLHTTP")
| + | |
− | }
| + | |
− | return function () {
| + | |
− | return b
| + | |
− | }
| + | |
− | }(),
| + | |
− | f = function (a, b) {
| + | |
− | var c = e();
| + | |
− | c && (c.open("GET", a, !0), c.onreadystatechange = function () {
| + | |
− | 4 !== c.readyState || 200 !== c.status && 304 !== c.status || b(c.responseText)
| + | |
− | }, 4 !== c.readyState && c.send(null))
| + | |
− | };
| + | |
− | if (c.ajax = f, c.queue = d, c.regex = {
| + | |
− | media: /@media[^\{]+\{([^\{\}]*\{[^\}\{]*\})+/gi,
| + | |
− | keyframes: /@(?:\-(?:o|moz|webkit)\-)?keyframes[^\{]+\{(?:[^\{\}]*\{[^\}\{]*\})+[^\}]*\}/gi,
| + | |
− | urls: /(url\()['"]?([^\/\)'"][^:\)'"]+)['"]?(\))/g,
| + | |
− | findStyles: /@media *([^\{]+)\{([\S\s]+?)$/,
| + | |
− | only: /(only\s+)?([a-zA-Z]+)\s?/,
| + | |
− | minw: /\([\s]*min\-width\s*:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/,
| + | |
− | maxw: /\([\s]*max\-width\s*:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/
| + | |
− | }, c.mediaQueriesSupported = a.matchMedia && null !== a.matchMedia("only all") && a.matchMedia("only all").matches, !c.mediaQueriesSupported) {
| + | |
− | var g, h, i, j = a.document,
| + | |
− | k = j.documentElement,
| + | |
− | l = [],
| + | |
− | m = [],
| + | |
− | n = [],
| + | |
− | o = {},
| + | |
− | p = 30,
| + | |
− | q = j.getElementsByTagName("head")[0] || k,
| + | |
− | r = j.getElementsByTagName("base")[0],
| + | |
− | s = q.getElementsByTagName("link"),
| + | |
− | t = function () {
| + | |
− | var a, b = j.createElement("div"),
| + | |
− | c = j.body,
| + | |
− | d = k.style.fontSize,
| + | |
− | e = c && c.style.fontSize,
| + | |
− | f = !1;
| + | |
− | return b.style.cssText = "position:absolute;font-size:1em;width:1em", c || (c = f = j.createElement("body"), c.style.background = "none"), k.style.fontSize = "100%", c.style.fontSize = "100%", c.appendChild(b), f && k.insertBefore(c, k.firstChild), a = b.offsetWidth, f ? k.removeChild(c) : c.removeChild(b), k.style.fontSize = d, e && (c.style.fontSize = e), a = i = parseFloat(a)
| + | |
− | },
| + | |
− | u = function (b) {
| + | |
− | var c = "clientWidth",
| + | |
− | d = k[c],
| + | |
− | e = "CSS1Compat" === j.compatMode && d || j.body[c] || d,
| + | |
− | f = {},
| + | |
− | o = s[s.length - 1],
| + | |
− | r = (new Date).getTime();
| + | |
− | if (b && g && p > r - g) return a.clearTimeout(h), h = a.setTimeout(u, p), void 0;
| + | |
− | g = r;
| + | |
− | for (var v in l)
| + | |
− | if (l.hasOwnProperty(v)) {
| + | |
− | var w = l[v],
| + | |
− | x = w.minw,
| + | |
− | y = w.maxw,
| + | |
− | z = null === x,
| + | |
− | A = null === y,
| + | |
− | B = "em";
| + | |
− | x && (x = parseFloat(x) * (x.indexOf(B) > -1 ? i || t() : 1)), y && (y = parseFloat(y) * (y.indexOf(B) > -1 ? i || t() : 1)), w.hasquery && (z && A || !(z || e >= x) || !(A || y >= e)) || (f[w.media] || (f[w.media] = []), f[w.media].push(m[w.rules]))
| + | |
− | }
| + | |
− | for (var C in n) n.hasOwnProperty(C) && n[C] && n[C].parentNode === q && q.removeChild(n[C]);
| + | |
− | n.length = 0;
| + | |
− | for (var D in f)
| + | |
− | if (f.hasOwnProperty(D)) {
| + | |
− | var E = j.createElement("style"),
| + | |
− | F = f[D].join("\n");
| + | |
− | E.type = "text/css", E.media = D, q.insertBefore(E, o.nextSibling), E.styleSheet ? E.styleSheet.cssText = F : E.appendChild(j.createTextNode(F)), n.push(E)
| + | |
− | }
| + | |
− | },
| + | |
− | v = function (a, b, d) {
| + | |
− | var e = a.replace(c.regex.keyframes, "").match(c.regex.media),
| + | |
− | f = e && e.length || 0;
| + | |
− | b = b.substring(0, b.lastIndexOf("/"));
| + | |
− | var g = function (a) {
| + | |
− | return a.replace(c.regex.urls, "$1" + b + "$2$3")
| + | |
− | },
| + | |
− | h = !f && d;
| + | |
− | b.length && (b += "/"), h && (f = 1);
| + | |
− | for (var i = 0; f > i; i++) {
| + | |
− | var j, k, n, o;
| + | |
− | h ? (j = d, m.push(g(a))) : (j = e[i].match(c.regex.findStyles) && RegExp.$1, m.push(RegExp.$2 && g(RegExp.$2))), n = j.split(","), o = n.length;
| + | |
− | for (var p = 0; o > p; p++) k = n[p], l.push({
| + | |
− | media: k.split("(")[0].match(c.regex.only) && RegExp.$2 || "all",
| + | |
− | rules: m.length - 1,
| + | |
− | hasquery: k.indexOf("(") > -1,
| + | |
− | minw: k.match(c.regex.minw) && parseFloat(RegExp.$1) + (RegExp.$2 || ""),
| + | |
− | maxw: k.match(c.regex.maxw) && parseFloat(RegExp.$1) + (RegExp.$2 || "")
| + | |
− | })
| + | |
− | }
| + | |
− | u()
| + | |
− | },
| + | |
− | w = function () {
| + | |
− | if (d.length) {
| + | |
− | var b = d.shift();
| + | |
− | f(b.href, function (c) {
| + | |
− | v(c, b.href, b.media), o[b.href] = !0, a.setTimeout(function () {
| + | |
− | w()
| + | |
− | }, 0)
| + | |
− | })
| + | |
− | }
| + | |
− | },
| + | |
− | x = function () {
| + | |
− | for (var b = 0; b < s.length; b++) {
| + | |
− | var c = s[b],
| + | |
− | e = c.href,
| + | |
− | f = c.media,
| + | |
− | g = c.rel && "stylesheet" === c.rel.toLowerCase();
| + | |
− | e && g && !o[e] && (c.styleSheet && c.styleSheet.rawCssText ? (v(c.styleSheet.rawCssText, e, f), o[e] = !0) : (!/^([a-zA-Z:]*\/\/)/.test(e) && !r || e.replace(RegExp.$1, "").split("/")[0] === a.location.host) && ("//" === e.substring(0, 2) && (e = a.location.protocol + e), d.push({
| + | |
− | href: e,
| + | |
− | media: f
| + | |
− | })))
| + | |
− | }
| + | |
− | w()
| + | |
− | };
| + | |
− | x(), c.update = x, c.getEmValue = t, a.addEventListener ? a.addEventListener("resize", b, !1) : a.attachEvent && a.attachEvent("onresize", b)
| + | |
− | }
| + | |
− | }(this);
| + | |
− | | + | |
− | </script>
| + | |
− | <script>
| + | |
− | //
| + | |
− | // SmoothScroll for websites v1.4.6 (Balazs Galambosi)
| + | |
− | // http://www.smoothscroll.net/
| + | |
− | //
| + | |
− | // Licensed under the terms of the MIT license.
| + | |
− | //
| + | |
− | // You may use it in your theme if you credit me.
| + | |
− | // It is also free to use on any individual website.
| + | |
− | //
| + | |
− | // Exception:
| + | |
− | // The only restriction is to not publish any
| + | |
− | // extension for browsers or native application
| + | |
− | // without getting a written permission first.
| + | |
− | //
| + | |
− | | + | |
− | (function () {
| + | |
− | | + | |
− | // Scroll Variables (tweakable)
| + | |
− | var defaultOptions = {
| + | |
− | | + | |
− | // Scrolling Core
| + | |
− | frameRate: 150, // [Hz]
| + | |
− | animationTime: 400, // [ms]
| + | |
− | stepSize: 100, // [px]
| + | |
− | | + | |
− | // Pulse (less tweakable)
| + | |
− | // ratio of "tail" to "acceleration"
| + | |
− | pulseAlgorithm: true,
| + | |
− | pulseScale: 4,
| + | |
− | pulseNormalize: 1,
| + | |
− | | + | |
− | // Acceleration
| + | |
− | accelerationDelta: 50, // 50
| + | |
− | accelerationMax: 3, // 3
| + | |
− | | + | |
− | // Keyboard Settings
| + | |
− | keyboardSupport: true, // option
| + | |
− | arrowScroll: 50, // [px]
| + | |
− | | + | |
− | // Other
| + | |
− | fixedBackground: true,
| + | |
− | excluded: ''
| + | |
− | };
| + | |
− | | + | |
− | var options = defaultOptions;
| + | |
− | | + | |
− | | + | |
− | // Other Variables
| + | |
− | var isExcluded = false;
| + | |
− | var isFrame = false;
| + | |
− | var direction = {
| + | |
− | x: 0,
| + | |
− | y: 0
| + | |
− | };
| + | |
− | var initDone = false;
| + | |
− | var root = document.documentElement;
| + | |
− | var activeElement;
| + | |
− | var observer;
| + | |
− | var refreshSize;
| + | |
− | var deltaBuffer = [];
| + | |
− | var isMac = /^Mac/.test(navigator.platform);
| + | |
− | | + | |
− | var key = {
| + | |
− | left: 37,
| + | |
− | up: 38,
| + | |
− | right: 39,
| + | |
− | down: 40,
| + | |
− | spacebar: 32,
| + | |
− | pageup: 33,
| + | |
− | pagedown: 34,
| + | |
− | end: 35,
| + | |
− | home: 36
| + | |
− | };
| + | |
− | var arrowKeys = {
| + | |
− | 37: 1,
| + | |
− | 38: 1,
| + | |
− | 39: 1,
| + | |
− | 40: 1
| + | |
− | };
| + | |
− | | + | |
− | /***********************************************
| + | |
− | * INITIALIZE
| + | |
− | ***********************************************/
| + | |
− | | + | |
− | /**
| + | |
− | * Tests if smooth scrolling is allowed. Shuts down everything if not.
| + | |
− | */
| + | |
− | function initTest() {
| + | |
− | if (options.keyboardSupport) {
| + | |
− | addEvent('keydown', keydown);
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | /**
| + | |
− | * Sets up scrolls array, determines if frames are involved.
| + | |
− | */
| + | |
− | function init() {
| + | |
− | | + | |
− | if (initDone || !document.body) return;
| + | |
− | | + | |
− | initDone = true;
| + | |
− | | + | |
− | var body = document.body;
| + | |
− | var html = document.documentElement;
| + | |
− | var windowHeight = window.innerHeight;
| + | |
− | var scrollHeight = body.scrollHeight;
| + | |
− | | + | |
− | // check compat mode for root element
| + | |
− | root = (document.compatMode.indexOf('CSS') >= 0) ? html : body;
| + | |
− | activeElement = body;
| + | |
− | | + | |
− | initTest();
| + | |
− | | + | |
− | // Checks if this script is running in a frame
| + | |
− | if (top != self) {
| + | |
− | isFrame = true;
| + | |
− | }
| + | |
− | | + | |
− | /**
| + | |
− | * Safari 10 fixed it, Chrome fixed it in v45:
| + | |
− | * This fixes a bug where the areas left and right to
| + | |
− | * the content does not trigger the onmousewheel event
| + | |
− | * on some pages. e.g.: html, body { height: 100% }
| + | |
− | */
| + | |
− | else if (isOldSafari &&
| + | |
− | scrollHeight > windowHeight &&
| + | |
− | (body.offsetHeight <= windowHeight ||
| + | |
− | html.offsetHeight <= windowHeight)) {
| + | |
− | | + | |
− | var fullPageElem = document.createElement('div');
| + | |
− | fullPageElem.style.cssText = 'position:absolute; z-index:-10000; ' +
| + | |
− | 'top:0; left:0; right:0; height:' +
| + | |
− | root.scrollHeight + 'px';
| + | |
− | document.body.appendChild(fullPageElem);
| + | |
− | | + | |
− | // DOM changed (throttled) to fix height
| + | |
− | var pendingRefresh;
| + | |
− | refreshSize = function () {
| + | |
− | if (pendingRefresh) return; // could also be: clearTimeout(pendingRefresh);
| + | |
− | pendingRefresh = setTimeout(function () {
| + | |
− | if (isExcluded) return; // could be running after cleanup
| + | |
− | fullPageElem.style.height = '0';
| + | |
− | fullPageElem.style.height = root.scrollHeight + 'px';
| + | |
− | pendingRefresh = null;
| + | |
− | }, 500); // act rarely to stay fast
| + | |
− | };
| + | |
− | | + | |
− | setTimeout(refreshSize, 10);
| + | |
− | | + | |
− | addEvent('resize', refreshSize);
| + | |
− | | + | |
− | // TODO: attributeFilter?
| + | |
− | var config = {
| + | |
− | attributes: true,
| + | |
− | childList: true,
| + | |
− | characterData: false
| + | |
− | // subtree: true
| + | |
− | };
| + | |
− | | + | |
− | observer = new MutationObserver(refreshSize);
| + | |
− | observer.observe(body, config);
| + | |
− | | + | |
− | if (root.offsetHeight <= windowHeight) {
| + | |
− | var clearfix = document.createElement('div');
| + | |
− | clearfix.style.clear = 'both';
| + | |
− | body.appendChild(clearfix);
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | // disable fixed background
| + | |
− | if (!options.fixedBackground && !isExcluded) {
| + | |
− | body.style.backgroundAttachment = 'scroll';
| + | |
− | html.style.backgroundAttachment = 'scroll';
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | /**
| + | |
− | * Removes event listeners and other traces left on the page.
| + | |
− | */
| + | |
− | function cleanup() {
| + | |
− | observer && observer.disconnect();
| + | |
− | removeEvent(wheelEvent, wheel);
| + | |
− | removeEvent('mousedown', mousedown);
| + | |
− | removeEvent('keydown', keydown);
| + | |
− | removeEvent('resize', refreshSize);
| + | |
− | removeEvent('load', init);
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /************************************************
| + | |
− | * SCROLLING
| + | |
− | ************************************************/
| + | |
− | | + | |
− | var que = [];
| + | |
− | var pending = false;
| + | |
− | var lastScroll = Date.now();
| + | |
− | | + | |
− | /**
| + | |
− | * Pushes scroll actions to the scrolling queue.
| + | |
− | */
| + | |
− | function scrollArray(elem, left, top) {
| + | |
− | | + | |
− | directionCheck(left, top);
| + | |
− | | + | |
− | if (options.accelerationMax != 1) {
| + | |
− | var now = Date.now();
| + | |
− | var elapsed = now - lastScroll;
| + | |
− | if (elapsed < options.accelerationDelta) {
| + | |
− | var factor = (1 + (50 / elapsed)) / 2;
| + | |
− | if (factor > 1) {
| + | |
− | factor = Math.min(factor, options.accelerationMax);
| + | |
− | left *= factor;
| + | |
− | top *= factor;
| + | |
− | }
| + | |
− | }
| + | |
− | lastScroll = Date.now();
| + | |
− | }
| + | |
− | | + | |
− | // push a scroll command
| + | |
− | que.push({
| + | |
− | x: left,
| + | |
− | y: top,
| + | |
− | lastX: (left < 0) ? 0.99 : -0.99,
| + | |
− | lastY: (top < 0) ? 0.99 : -0.99,
| + | |
− | start: Date.now()
| + | |
− | });
| + | |
− | | + | |
− | // don't act if there's a pending queue
| + | |
− | if (pending) {
| + | |
− | return;
| + | |
− | }
| + | |
− | | + | |
− | var scrollWindow = (elem === document.body);
| + | |
− | | + | |
− | var step = function (time) {
| + | |
− | | + | |
− | var now = Date.now();
| + | |
− | var scrollX = 0;
| + | |
− | var scrollY = 0;
| + | |
− | | + | |
− | for (var i = 0; i < que.length; i++) {
| + | |
− | | + | |
− | var item = que[i];
| + | |
− | var elapsed = now - item.start;
| + | |
− | var finished = (elapsed >= options.animationTime);
| + | |
− | | + | |
− | // scroll position: [0, 1]
| + | |
− | var position = (finished) ? 1 : elapsed / options.animationTime;
| + | |
− | | + | |
− | // easing [optional]
| + | |
− | if (options.pulseAlgorithm) {
| + | |
− | position = pulse(position);
| + | |
− | }
| + | |
− | | + | |
− | // only need the difference
| + | |
− | var x = (item.x * position - item.lastX) >> 0;
| + | |
− | var y = (item.y * position - item.lastY) >> 0;
| + | |
− | | + | |
− | // add this to the total scrolling
| + | |
− | scrollX += x;
| + | |
− | scrollY += y;
| + | |
− | | + | |
− | // update last values
| + | |
− | item.lastX += x;
| + | |
− | item.lastY += y;
| + | |
− | | + | |
− | // delete and step back if it's over
| + | |
− | if (finished) {
| + | |
− | que.splice(i, 1);
| + | |
− | i--;
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | // scroll left and top
| + | |
− | if (scrollWindow) {
| + | |
− | window.scrollBy(scrollX, scrollY);
| + | |
− | } else {
| + | |
− | if (scrollX) elem.scrollLeft += scrollX;
| + | |
− | if (scrollY) elem.scrollTop += scrollY;
| + | |
− | }
| + | |
− | | + | |
− | // clean up if there's nothing left to do
| + | |
− | if (!left && !top) {
| + | |
− | que = [];
| + | |
− | }
| + | |
− | | + | |
− | if (que.length) {
| + | |
− | requestFrame(step, elem, (1000 / options.frameRate + 1));
| + | |
− | } else {
| + | |
− | pending = false;
| + | |
− | }
| + | |
− | };
| + | |
− | | + | |
− | // start a new queue of actions
| + | |
− | requestFrame(step, elem, 0);
| + | |
− | pending = true;
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /***********************************************
| + | |
− | * EVENTS
| + | |
− | ***********************************************/
| + | |
− | | + | |
− | /**
| + | |
− | * Mouse wheel handler.
| + | |
− | * @param {Object} event
| + | |
− | */
| + | |
− | function wheel(event) {
| + | |
− | | + | |
− | if (!initDone) {
| + | |
− | init();
| + | |
− | }
| + | |
− | | + | |
− | var target = event.target;
| + | |
− | | + | |
− | // leave early if default action is prevented
| + | |
− | // or it's a zooming event with CTRL
| + | |
− | if (event.defaultPrevented || event.ctrlKey) {
| + | |
− | return true;
| + | |
− | }
| + | |
− | | + | |
− | // leave embedded content alone (flash & pdf)
| + | |
− | if (isNodeName(activeElement, 'embed') ||
| + | |
− | (isNodeName(target, 'embed') && /\.pdf/i.test(target.src)) ||
| + | |
− | isNodeName(activeElement, 'object') ||
| + | |
− | target.shadowRoot) {
| + | |
− | return true;
| + | |
− | }
| + | |
− | | + | |
− | var deltaX = -event.wheelDeltaX || event.deltaX || 0;
| + | |
− | var deltaY = -event.wheelDeltaY || event.deltaY || 0;
| + | |
− | | + | |
− | if (isMac) {
| + | |
− | if (event.wheelDeltaX && isDivisible(event.wheelDeltaX, 120)) {
| + | |
− | deltaX = -120 * (event.wheelDeltaX / Math.abs(event.wheelDeltaX));
| + | |
− | }
| + | |
− | if (event.wheelDeltaY && isDivisible(event.wheelDeltaY, 120)) {
| + | |
− | deltaY = -120 * (event.wheelDeltaY / Math.abs(event.wheelDeltaY));
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | // use wheelDelta if deltaX/Y is not available
| + | |
− | if (!deltaX && !deltaY) {
| + | |
− | deltaY = -event.wheelDelta || 0;
| + | |
− | }
| + | |
− | | + | |
− | // line based scrolling (Firefox mostly)
| + | |
− | if (event.deltaMode === 1) {
| + | |
− | deltaX *= 40;
| + | |
− | deltaY *= 40;
| + | |
− | }
| + | |
− | | + | |
− | var overflowing = overflowingAncestor(target);
| + | |
− | | + | |
− | // nothing to do if there's no element that's scrollable
| + | |
− | if (!overflowing) {
| + | |
− | // except Chrome iframes seem to eat wheel events, which we need to
| + | |
− | // propagate up, if the iframe has nothing overflowing to scroll
| + | |
− | if (isFrame && isChrome) {
| + | |
− | // change target to iframe element itself for the parent frame
| + | |
− | Object.defineProperty(event, "target", {
| + | |
− | value: window.frameElement
| + | |
− | });
| + | |
− | return parent.wheel(event);
| + | |
− | }
| + | |
− | return true;
| + | |
− | }
| + | |
− | | + | |
− | // check if it's a touchpad scroll that should be ignored
| + | |
− | if (isTouchpad(deltaY)) {
| + | |
− | return true;
| + | |
− | }
| + | |
− | | + | |
− | // scale by step size
| + | |
− | // delta is 120 most of the time
| + | |
− | // synaptics seems to send 1 sometimes
| + | |
− | if (Math.abs(deltaX) > 1.2) {
| + | |
− | deltaX *= options.stepSize / 120;
| + | |
− | }
| + | |
− | if (Math.abs(deltaY) > 1.2) {
| + | |
− | deltaY *= options.stepSize / 120;
| + | |
− | }
| + | |
− | | + | |
− | scrollArray(overflowing, deltaX, deltaY);
| + | |
− | event.preventDefault();
| + | |
− | scheduleClearCache();
| + | |
− | }
| + | |
− | | + | |
− | /**
| + | |
− | * Keydown event handler.
| + | |
− | * @param {Object} event
| + | |
− | */
| + | |
− | function keydown(event) {
| + | |
− | | + | |
− | var target = event.target;
| + | |
− | var modifier = event.ctrlKey || event.altKey || event.metaKey ||
| + | |
− | (event.shiftKey && event.keyCode !== key.spacebar);
| + | |
− | | + | |
− | // our own tracked active element could've been removed from the DOM
| + | |
− | if (!document.body.contains(activeElement)) {
| + | |
− | activeElement = document.activeElement;
| + | |
− | }
| + | |
− | | + | |
− | // do nothing if user is editing text
| + | |
− | // or using a modifier key (except shift)
| + | |
− | // or in a dropdown
| + | |
− | // or inside interactive elements
| + | |
− | var inputNodeNames = /^(textarea|select|embed|object)$/i;
| + | |
− | var buttonTypes = /^(button|submit|radio|checkbox|file|color|image)$/i;
| + | |
− | if (event.defaultPrevented ||
| + | |
− | inputNodeNames.test(target.nodeName) ||
| + | |
− | isNodeName(target, 'input') && !buttonTypes.test(target.type) ||
| + | |
− | isNodeName(activeElement, 'video') ||
| + | |
− | isInsideYoutubeVideo(event) ||
| + | |
− | target.isContentEditable ||
| + | |
− | modifier) {
| + | |
− | return true;
| + | |
− | }
| + | |
− | | + | |
− | // [spacebar] should trigger button press, leave it alone
| + | |
− | if ((isNodeName(target, 'button') ||
| + | |
− | isNodeName(target, 'input') && buttonTypes.test(target.type)) &&
| + | |
− | event.keyCode === key.spacebar) {
| + | |
− | return true;
| + | |
− | }
| + | |
− | | + | |
− | // [arrwow keys] on radio buttons should be left alone
| + | |
− | if (isNodeName(target, 'input') && target.type == 'radio' &&
| + | |
− | arrowKeys[event.keyCode]) {
| + | |
− | return true;
| + | |
− | }
| + | |
− | | + | |
− | var shift, x = 0,
| + | |
− | y = 0;
| + | |
− | var overflowing = overflowingAncestor(activeElement);
| + | |
− | | + | |
− | if (!overflowing) {
| + | |
− | // Chrome iframes seem to eat key events, which we need to
| + | |
− | // propagate up, if the iframe has nothing overflowing to scroll
| + | |
− | return (isFrame && isChrome) ? parent.keydown(event) : true;
| + | |
− | }
| + | |
− | | + | |
− | var clientHeight = overflowing.clientHeight;
| + | |
− | | + | |
− | if (overflowing == document.body) {
| + | |
− | clientHeight = window.innerHeight;
| + | |
− | }
| + | |
− | | + | |
− | switch (event.keyCode) {
| + | |
− | case key.up:
| + | |
− | y = -options.arrowScroll;
| + | |
− | break;
| + | |
− | case key.down:
| + | |
− | y = options.arrowScroll;
| + | |
− | break;
| + | |
− | case key.spacebar: // (+ shift)
| + | |
− | shift = event.shiftKey ? 1 : -1;
| + | |
− | y = -shift * clientHeight * 0.9;
| + | |
− | break;
| + | |
− | case key.pageup:
| + | |
− | y = -clientHeight * 0.9;
| + | |
− | break;
| + | |
− | case key.pagedown:
| + | |
− | y = clientHeight * 0.9;
| + | |
− | break;
| + | |
− | case key.home:
| + | |
− | y = -overflowing.scrollTop;
| + | |
− | break;
| + | |
− | case key.end:
| + | |
− | var scroll = overflowing.scrollHeight - overflowing.scrollTop;
| + | |
− | var scrollRemaining = scroll - clientHeight;
| + | |
− | y = (scrollRemaining > 0) ? scrollRemaining + 10 : 0;
| + | |
− | break;
| + | |
− | case key.left:
| + | |
− | x = -options.arrowScroll;
| + | |
− | break;
| + | |
− | case key.right:
| + | |
− | x = options.arrowScroll;
| + | |
− | break;
| + | |
− | default:
| + | |
− | return true; // a key we don't care about
| + | |
− | }
| + | |
− | | + | |
− | scrollArray(overflowing, x, y);
| + | |
− | event.preventDefault();
| + | |
− | scheduleClearCache();
| + | |
− | }
| + | |
− | | + | |
− | /**
| + | |
− | * Mousedown event only for updating activeElement
| + | |
− | */
| + | |
− | function mousedown(event) {
| + | |
− | activeElement = event.target;
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /***********************************************
| + | |
− | * OVERFLOW
| + | |
− | ***********************************************/
| + | |
− | | + | |
− | var uniqueID = (function () {
| + | |
− | var i = 0;
| + | |
− | return function (el) {
| + | |
− | return el.uniqueID || (el.uniqueID = i++);
| + | |
− | };
| + | |
− | })();
| + | |
− | | + | |
− | var cache = {}; // cleared out after a scrolling session
| + | |
− | var clearCacheTimer;
| + | |
− | | + | |
− | //setInterval(function () { cache = {}; }, 10 * 1000);
| + | |
− | | + | |
− | function scheduleClearCache() {
| + | |
− | clearTimeout(clearCacheTimer);
| + | |
− | clearCacheTimer = setInterval(function () {
| + | |
− | cache = {};
| + | |
− | }, 1 * 1000);
| + | |
− | }
| + | |
− | | + | |
− | function setCache(elems, overflowing) {
| + | |
− | for (var i = elems.length; i--;)
| + | |
− | cache[uniqueID(elems[i])] = overflowing;
| + | |
− | return overflowing;
| + | |
− | }
| + | |
− | | + | |
− | // (body) (root)
| + | |
− | // | hidden | visible | scroll | auto |
| + | |
− | // hidden | no | no | YES | YES |
| + | |
− | // visible | no | YES | YES | YES |
| + | |
− | // scroll | no | YES | YES | YES |
| + | |
− | // auto | no | YES | YES | YES |
| + | |
− | | + | |
− | function overflowingAncestor(el) {
| + | |
− | var elems = [];
| + | |
− | var body = document.body;
| + | |
− | var rootScrollHeight = root.scrollHeight;
| + | |
− | do {
| + | |
− | var cached = cache[uniqueID(el)];
| + | |
− | if (cached) {
| + | |
− | return setCache(elems, cached);
| + | |
− | }
| + | |
− | elems.push(el);
| + | |
− | if (rootScrollHeight === el.scrollHeight) {
| + | |
− | var topOverflowsNotHidden = overflowNotHidden(root) && overflowNotHidden(body);
| + | |
− | var isOverflowCSS = topOverflowsNotHidden || overflowAutoOrScroll(root);
| + | |
− | if (isFrame && isContentOverflowing(root) ||
| + | |
− | !isFrame && isOverflowCSS) {
| + | |
− | return setCache(elems, getScrollRoot());
| + | |
− | }
| + | |
− | } else if (isContentOverflowing(el) && overflowAutoOrScroll(el)) {
| + | |
− | return setCache(elems, el);
| + | |
− | }
| + | |
− | } while (el = el.parentElement);
| + | |
− | }
| + | |
− | | + | |
− | function isContentOverflowing(el) {
| + | |
− | return (el.clientHeight + 10 < el.scrollHeight);
| + | |
− | }
| + | |
− | | + | |
− | // typically for <body> and <html>
| + | |
− | function overflowNotHidden(el) {
| + | |
− | var overflow = getComputedStyle(el, '').getPropertyValue('overflow-y');
| + | |
− | return (overflow !== 'hidden');
| + | |
− | }
| + | |
− | | + | |
− | // for all other elements
| + | |
− | function overflowAutoOrScroll(el) {
| + | |
− | var overflow = getComputedStyle(el, '').getPropertyValue('overflow-y');
| + | |
− | return (overflow === 'scroll' || overflow === 'auto');
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /***********************************************
| + | |
− | * HELPERS
| + | |
− | ***********************************************/
| + | |
− | | + | |
− | function addEvent(type, fn) {
| + | |
− | window.addEventListener(type, fn, false);
| + | |
− | }
| + | |
− | | + | |
− | function removeEvent(type, fn) {
| + | |
− | window.removeEventListener(type, fn, false);
| + | |
− | }
| + | |
− | | + | |
− | function isNodeName(el, tag) {
| + | |
− | return (el.nodeName || '').toLowerCase() === tag.toLowerCase();
| + | |
− | }
| + | |
− | | + | |
− | function directionCheck(x, y) {
| + | |
− | x = (x > 0) ? 1 : -1;
| + | |
− | y = (y > 0) ? 1 : -1;
| + | |
− | if (direction.x !== x || direction.y !== y) {
| + | |
− | direction.x = x;
| + | |
− | direction.y = y;
| + | |
− | que = [];
| + | |
− | lastScroll = 0;
| + | |
− | }
| + | |
− | }
| + | |
− | | + | |
− | var deltaBufferTimer;
| + | |
− | | + | |
− | if (window.localStorage && localStorage.SS_deltaBuffer) {
| + | |
− | try { // #46 Safari throws in private browsing for localStorage
| + | |
− | deltaBuffer = localStorage.SS_deltaBuffer.split(',');
| + | |
− | } catch (e) {}
| + | |
− | }
| + | |
− | | + | |
− | function isTouchpad(deltaY) {
| + | |
− | if (!deltaY) return;
| + | |
− | if (!deltaBuffer.length) {
| + | |
− | deltaBuffer = [deltaY, deltaY, deltaY];
| + | |
− | }
| + | |
− | deltaY = Math.abs(deltaY);
| + | |
− | deltaBuffer.push(deltaY);
| + | |
− | deltaBuffer.shift();
| + | |
− | clearTimeout(deltaBufferTimer);
| + | |
− | deltaBufferTimer = setTimeout(function () {
| + | |
− | try { // #46 Safari throws in private browsing for localStorage
| + | |
− | localStorage.SS_deltaBuffer = deltaBuffer.join(',');
| + | |
− | } catch (e) {}
| + | |
− | }, 1000);
| + | |
− | return !allDeltasDivisableBy(120) && !allDeltasDivisableBy(100);
| + | |
− | }
| + | |
− | | + | |
− | function isDivisible(n, divisor) {
| + | |
− | return (Math.floor(n / divisor) == n / divisor);
| + | |
− | }
| + | |
− | | + | |
− | function allDeltasDivisableBy(divisor) {
| + | |
− | return (isDivisible(deltaBuffer[0], divisor) &&
| + | |
− | isDivisible(deltaBuffer[1], divisor) &&
| + | |
− | isDivisible(deltaBuffer[2], divisor));
| + | |
− | }
| + | |
− | | + | |
− | function isInsideYoutubeVideo(event) {
| + | |
− | var elem = event.target;
| + | |
− | var isControl = false;
| + | |
− | if (document.URL.indexOf('www.youtube.com/watch') != -1) {
| + | |
− | do {
| + | |
− | isControl = (elem.classList &&
| + | |
− | elem.classList.contains('html5-video-controls'));
| + | |
− | if (isControl) break;
| + | |
− | } while (elem = elem.parentNode);
| + | |
− | }
| + | |
− | return isControl;
| + | |
− | }
| + | |
− | | + | |
− | var requestFrame = (function () {
| + | |
− | return (window.requestAnimationFrame ||
| + | |
− | window.webkitRequestAnimationFrame ||
| + | |
− | window.mozRequestAnimationFrame ||
| + | |
− | function (callback, element, delay) {
| + | |
− | window.setTimeout(callback, delay || (1000 / 60));
| + | |
− | });
| + | |
− | })();
| + | |
− | | + | |
− | var MutationObserver = (window.MutationObserver ||
| + | |
− | window.WebKitMutationObserver ||
| + | |
− | window.MozMutationObserver);
| + | |
− | | + | |
− | var getScrollRoot = (function () {
| + | |
− | var SCROLL_ROOT;
| + | |
− | return function () {
| + | |
− | if (!SCROLL_ROOT) {
| + | |
− | var dummy = document.createElement('div');
| + | |
− | dummy.style.cssText = 'height:10000px;width:1px;';
| + | |
− | document.body.appendChild(dummy);
| + | |
− | var bodyScrollTop = document.body.scrollTop;
| + | |
− | var docElScrollTop = document.documentElement.scrollTop;
| + | |
− | window.scrollBy(0, 3);
| + | |
− | if (document.body.scrollTop != bodyScrollTop)
| + | |
− | (SCROLL_ROOT = document.body);
| + | |
− | else
| + | |
− | (SCROLL_ROOT = document.documentElement);
| + | |
− | window.scrollBy(0, -3);
| + | |
− | document.body.removeChild(dummy);
| + | |
− | }
| + | |
− | return SCROLL_ROOT;
| + | |
− | };
| + | |
− | })();
| + | |
− | | + | |
− | | + | |
− | /***********************************************
| + | |
− | * PULSE (by Michael Herf)
| + | |
− | ***********************************************/
| + | |
− | | + | |
− | /**
| + | |
− | * Viscous fluid with a pulse for part and decay for the rest.
| + | |
− | * - Applies a fixed force over an interval (a damped acceleration), and
| + | |
− | * - Lets the exponential bleed away the velocity over a longer interval
| + | |
− | * - Michael Herf, http://stereopsis.com/stopping/
| + | |
− | */
| + | |
− | function pulse_(x) {
| + | |
− | var val, start, expx;
| + | |
− | // test
| + | |
− | x = x * options.pulseScale;
| + | |
− | if (x < 1) { // acceleartion
| + | |
− | val = x - (1 - Math.exp(-x));
| + | |
− | } else { // tail
| + | |
− | // the previous animation ended here:
| + | |
− | start = Math.exp(-1);
| + | |
− | // simple viscous drag
| + | |
− | x -= 1;
| + | |
− | expx = 1 - Math.exp(-x);
| + | |
− | val = start + (expx * (1 - start));
| + | |
− | }
| + | |
− | return val * options.pulseNormalize;
| + | |
− | }
| + | |
− | | + | |
− | function pulse(x) {
| + | |
− | if (x >= 1) return 1;
| + | |
− | if (x <= 0) return 0;
| + | |
− | | + | |
− | if (options.pulseNormalize == 1) {
| + | |
− | options.pulseNormalize /= pulse_(1);
| + | |
− | }
| + | |
− | return pulse_(x);
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /***********************************************
| + | |
− | * FIRST RUN
| + | |
− | ***********************************************/
| + | |
− | | + | |
− | var userAgent = window.navigator.userAgent;
| + | |
− | var isEdge = /Edge/.test(userAgent); // thank you MS
| + | |
− | var isChrome = /chrome/i.test(userAgent) && !isEdge;
| + | |
− | var isSafari = /safari/i.test(userAgent) && !isEdge;
| + | |
− | var isMobile = /mobile/i.test(userAgent);
| + | |
− | var isIEWin7 = /Windows NT 6.1/i.test(userAgent) && /rv:11/i.test(userAgent);
| + | |
− | var isOldSafari = isSafari && (/Version\/8/i.test(userAgent) || /Version\/9/i.test(userAgent));
| + | |
− | var isEnabledForBrowser = (isChrome || isSafari || isIEWin7) && !isMobile;
| + | |
− | | + | |
− | var wheelEvent;
| + | |
− | if ('onwheel' in document.createElement('div'))
| + | |
− | wheelEvent = 'wheel';
| + | |
− | else if ('onmousewheel' in document.createElement('div'))
| + | |
− | wheelEvent = 'mousewheel';
| + | |
− | | + | |
− | if (wheelEvent && isEnabledForBrowser) {
| + | |
− | addEvent(wheelEvent, wheel);
| + | |
− | addEvent('mousedown', mousedown);
| + | |
− | addEvent('load', init);
| + | |
− | }
| + | |
− | | + | |
− | | + | |
− | /***********************************************
| + | |
− | * PUBLIC INTERFACE
| + | |
− | ***********************************************/
| + | |
− | | + | |
− | function SmoothScroll(optionsToSet) {
| + | |
− | for (var key in optionsToSet)
| + | |
− | if (defaultOptions.hasOwnProperty(key))
| + | |
− | options[key] = optionsToSet[key];
| + | |
− | }
| + | |
− | SmoothScroll.destroy = cleanup;
| + | |
− | | + | |
− | if (window.SmoothScrollOptions) // async API
| + | |
− | SmoothScroll(window.SmoothScrollOptions);
| + | |
− | | + | |
− | if (typeof define === 'function' && define.amd)
| + | |
− | define(function () {
| + | |
− | return SmoothScroll;
| + | |
− | });
| + | |
− | else if ('object' == typeof exports)
| + | |
− | module.exports = SmoothScroll;
| + | |
− | else
| + | |
− | window.SmoothScroll = SmoothScroll;
| + | |
− | | + | |
− | })();
| + | |
− | | + | |
− | </script>
| + | |
− | <script>
| + | |
− | /*! WOW - v1.1.3 - 2016-05-06
| + | |
− | * Copyright (c) 2016 Matthieu Aussaguel;*/
| + | |
− | (function () {
| + | |
− | var a, b, c, d, e, f = function (a, b) {
| + | |
− | return function () {
| + | |
− | return a.apply(b, arguments)
| + | |
− | }
| + | |
− | },
| + | |
− | g = [].indexOf || function (a) {
| + | |
− | for (var b = 0, c = this.length; c > b; b++)
| + | |
− | if (b in this && this[b] === a) return b;
| + | |
− | return -1
| + | |
− | };
| + | |
− | b = function () {
| + | |
− | function a() {}
| + | |
− | return a.prototype.extend = function (a, b) {
| + | |
− | var c, d;
| + | |
− | for (c in b) d = b[c], null == a[c] && (a[c] = d);
| + | |
− | return a
| + | |
− | }, a.prototype.isMobile = function (a) {
| + | |
− | return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(a)
| + | |
− | }, a.prototype.createEvent = function (a, b, c, d) {
| + | |
− | var e;
| + | |
− | return null == b && (b = !1), null == c && (c = !1), null == d && (d = null), null != document.createEvent ? (e = document.createEvent("CustomEvent"), e.initCustomEvent(a, b, c, d)) : null != document.createEventObject ? (e = document.createEventObject(), e.eventType = a) : e.eventName = a, e
| + | |
− | }, a.prototype.emitEvent = function (a, b) {
| + | |
− | return null != a.dispatchEvent ? a.dispatchEvent(b) : b in (null != a) ? a[b]() : "on" + b in (null != a) ? a["on" + b]() : void 0
| + | |
− | }, a.prototype.addEvent = function (a, b, c) {
| + | |
− | return null != a.addEventListener ? a.addEventListener(b, c, !1) : null != a.attachEvent ? a.attachEvent("on" + b, c) : a[b] = c
| + | |
− | }, a.prototype.removeEvent = function (a, b, c) {
| + | |
− | return null != a.removeEventListener ? a.removeEventListener(b, c, !1) : null != a.detachEvent ? a.detachEvent("on" + b, c) : delete a[b]
| + | |
− | }, a.prototype.innerHeight = function () {
| + | |
− | return "innerHeight" in window ? window.innerHeight : document.documentElement.clientHeight
| + | |
− | }, a
| + | |
− | }(), c = this.WeakMap || this.MozWeakMap || (c = function () {
| + | |
− | function a() {
| + | |
− | this.keys = [], this.values = []
| + | |
− | }
| + | |
− | return a.prototype.get = function (a) {
| + | |
− | var b, c, d, e, f;
| + | |
− | for (f = this.keys, b = d = 0, e = f.length; e > d; b = ++d)
| + | |
− | if (c = f[b], c === a) return this.values[b]
| + | |
− | }, a.prototype.set = function (a, b) {
| + | |
− | var c, d, e, f, g;
| + | |
− | for (g = this.keys, c = e = 0, f = g.length; f > e; c = ++e)
| + | |
− | if (d = g[c], d === a) return void(this.values[c] = b);
| + | |
− | return this.keys.push(a), this.values.push(b)
| + | |
− | }, a
| + | |
− | }()), a = this.MutationObserver || this.WebkitMutationObserver || this.MozMutationObserver || (a = function () {
| + | |
− | function a() {
| + | |
− | "undefined" != typeof console && null !== console && console.warn("MutationObserver is not supported by your browser."), "undefined" != typeof console && null !== console && console.warn("WOW.js cannot detect dom mutations, please call .sync() after loading new content.")
| + | |
− | }
| + | |
− | return a.notSupported = !0, a.prototype.observe = function () {}, a
| + | |
− | }()), d = this.getComputedStyle || function (a, b) {
| + | |
− | return this.getPropertyValue = function (b) {
| + | |
− | var c;
| + | |
− | return "float" === b && (b = "styleFloat"), e.test(b) && b.replace(e, function (a, b) {
| + | |
− | return b.toUpperCase()
| + | |
− | }), (null != (c = a.currentStyle) ? c[b] : void 0) || null
| + | |
− | }, this
| + | |
− | }, e = /(\-([a-z]){1})/g, this.WOW = function () {
| + | |
− | function e(a) {
| + | |
− | null == a && (a = {}), this.scrollCallback = f(this.scrollCallback, this), this.scrollHandler = f(this.scrollHandler, this), this.resetAnimation = f(this.resetAnimation, this), this.start = f(this.start, this), this.scrolled = !0, this.config = this.util().extend(a, this.defaults), null != a.scrollContainer && (this.config.scrollContainer = document.querySelector(a.scrollContainer)), this.animationNameCache = new c, this.wowEvent = this.util().createEvent(this.config.boxClass)
| + | |
− | }
| + | |
− | return e.prototype.defaults = {
| + | |
− | boxClass: "wow",
| + | |
− | animateClass: "animated",
| + | |
− | offset: 0,
| + | |
− | mobile: !0,
| + | |
− | live: !0,
| + | |
− | callback: null,
| + | |
− | scrollContainer: null
| + | |
− | }, e.prototype.init = function () {
| + | |
− | var a;
| + | |
− | return this.element = window.document.documentElement, "interactive" === (a = document.readyState) || "complete" === a ? this.start() : this.util().addEvent(document, "DOMContentLoaded", this.start), this.finished = []
| + | |
− | }, e.prototype.start = function () {
| + | |
− | var b, c, d, e;
| + | |
− | if (this.stopped = !1, this.boxes = function () {
| + | |
− | var a, c, d, e;
| + | |
− | for (d = this.element.querySelectorAll("." + this.config.boxClass), e = [], a = 0, c = d.length; c > a; a++) b = d[a], e.push(b);
| + | |
− | return e
| + | |
− | }.call(this), this.all = function () {
| + | |
− | var a, c, d, e;
| + | |
− | for (d = this.boxes, e = [], a = 0, c = d.length; c > a; a++) b = d[a], e.push(b);
| + | |
− | return e
| + | |
− | }.call(this), this.boxes.length)
| + | |
− | if (this.disabled()) this.resetStyle();
| + | |
− | else
| + | |
− | for (e = this.boxes, c = 0, d = e.length; d > c; c++) b = e[c], this.applyStyle(b, !0);
| + | |
− | return this.disabled() || (this.util().addEvent(this.config.scrollContainer || window, "scroll", this.scrollHandler), this.util().addEvent(window, "resize", this.scrollHandler), this.interval = setInterval(this.scrollCallback, 50)), this.config.live ? new a(function (a) {
| + | |
− | return function (b) {
| + | |
− | var c, d, e, f, g;
| + | |
− | for (g = [], c = 0, d = b.length; d > c; c++) f = b[c], g.push(function () {
| + | |
− | var a, b, c, d;
| + | |
− | for (c = f.addedNodes || [], d = [], a = 0, b = c.length; b > a; a++) e = c[a], d.push(this.doSync(e));
| + | |
− | return d
| + | |
− | }.call(a));
| + | |
− | return g
| + | |
− | }
| + | |
− | }(this)).observe(document.body, {
| + | |
− | childList: !0,
| + | |
− | subtree: !0
| + | |
− | }) : void 0
| + | |
− | }, e.prototype.stop = function () {
| + | |
− | return this.stopped = !0, this.util().removeEvent(this.config.scrollContainer || window, "scroll", this.scrollHandler), this.util().removeEvent(window, "resize", this.scrollHandler), null != this.interval ? clearInterval(this.interval) : void 0
| + | |
− | }, e.prototype.sync = function (b) {
| + | |
− | return a.notSupported ? this.doSync(this.element) : void 0
| + | |
− | }, e.prototype.doSync = function (a) {
| + | |
− | var b, c, d, e, f;
| + | |
− | if (null == a && (a = this.element), 1 === a.nodeType) {
| + | |
− | for (a = a.parentNode || a, e = a.querySelectorAll("." + this.config.boxClass), f = [], c = 0, d = e.length; d > c; c++) b = e[c], g.call(this.all, b) < 0 ? (this.boxes.push(b), this.all.push(b), this.stopped || this.disabled() ? this.resetStyle() : this.applyStyle(b, !0), f.push(this.scrolled = !0)) : f.push(void 0);
| + | |
− | return f
| + | |
− | }
| + | |
− | }, e.prototype.show = function (a) {
| + | |
− | return this.applyStyle(a), a.className = a.className + " " + this.config.animateClass, null != this.config.callback && this.config.callback(a), this.util().emitEvent(a, this.wowEvent), this.util().addEvent(a, "animationend", this.resetAnimation), this.util().addEvent(a, "oanimationend", this.resetAnimation), this.util().addEvent(a, "webkitAnimationEnd", this.resetAnimation), this.util().addEvent(a, "MSAnimationEnd", this.resetAnimation), a
| + | |
− | }, e.prototype.applyStyle = function (a, b) {
| + | |
− | var c, d, e;
| + | |
− | return d = a.getAttribute("data-wow-duration"), c = a.getAttribute("data-wow-delay"), e = a.getAttribute("data-wow-iteration"), this.animate(function (f) {
| + | |
− | return function () {
| + | |
− | return f.customStyle(a, b, d, c, e)
| + | |
− | }
| + | |
− | }(this))
| + | |
− | }, e.prototype.animate = function () {
| + | |
− | return "requestAnimationFrame" in window ? function (a) {
| + | |
− | return window.requestAnimationFrame(a)
| + | |
− | } : function (a) {
| + | |
− | return a()
| + | |
− | }
| + | |
− | }(), e.prototype.resetStyle = function () {
| + | |
− | var a, b, c, d, e;
| + | |
− | for (d = this.boxes, e = [], b = 0, c = d.length; c > b; b++) a = d[b], e.push(a.style.visibility = "visible");
| + | |
− | return e
| + | |
− | }, e.prototype.resetAnimation = function (a) {
| + | |
− | var b;
| + | |
− | return a.type.toLowerCase().indexOf("animationend") >= 0 ? (b = a.target || a.srcElement, b.className = b.className.replace(this.config.animateClass, "").trim()) : void 0
| + | |
− | }, e.prototype.customStyle = function (a, b, c, d, e) {
| + | |
− | return b && this.cacheAnimationName(a), a.style.visibility = b ? "hidden" : "visible", c && this.vendorSet(a.style, {
| + | |
− | animationDuration: c
| + | |
− | }), d && this.vendorSet(a.style, {
| + | |
− | animationDelay: d
| + | |
− | }), e && this.vendorSet(a.style, {
| + | |
− | animationIterationCount: e
| + | |
− | }), this.vendorSet(a.style, {
| + | |
− | animationName: b ? "none" : this.cachedAnimationName(a)
| + | |
− | }), a
| + | |
− | }, e.prototype.vendors = ["moz", "webkit"], e.prototype.vendorSet = function (a, b) {
| + | |
− | var c, d, e, f;
| + | |
− | d = [];
| + | |
− | for (c in b) e = b[c], a["" + c] = e, d.push(function () {
| + | |
− | var b, d, g, h;
| + | |
− | for (g = this.vendors, h = [], b = 0, d = g.length; d > b; b++) f = g[b], h.push(a["" + f + c.charAt(0).toUpperCase() + c.substr(1)] = e);
| + | |
− | return h
| + | |
− | }.call(this));
| + | |
− | return d
| + | |
− | }, e.prototype.vendorCSS = function (a, b) {
| + | |
− | var c, e, f, g, h, i;
| + | |
− | for (h = d(a), g = h.getPropertyCSSValue(b), f = this.vendors, c = 0, e = f.length; e > c; c++) i = f[c], g = g || h.getPropertyCSSValue("-" + i + "-" + b);
| + | |
− | return g
| + | |
− | }, e.prototype.animationName = function (a) {
| + | |
− | var b;
| + | |
− | try {
| + | |
− | b = this.vendorCSS(a, "animation-name").cssText
| + | |
− | } catch (c) {
| + | |
− | b = d(a).getPropertyValue("animation-name")
| + | |
− | }
| + | |
− | return "none" === b ? "" : b
| + | |
− | }, e.prototype.cacheAnimationName = function (a) {
| + | |
− | return this.animationNameCache.set(a, this.animationName(a))
| + | |
− | }, e.prototype.cachedAnimationName = function (a) {
| + | |
− | return this.animationNameCache.get(a)
| + | |
− | }, e.prototype.scrollHandler = function () {
| + | |
− | return this.scrolled = !0
| + | |
− | }, e.prototype.scrollCallback = function () {
| + | |
− | var a;
| + | |
− | return !this.scrolled || (this.scrolled = !1, this.boxes = function () {
| + | |
− | var b, c, d, e;
| + | |
− | for (d = this.boxes, e = [], b = 0, c = d.length; c > b; b++) a = d[b], a && (this.isVisible(a) ? this.show(a) : e.push(a));
| + | |
− | return e
| + | |
− | }.call(this), this.boxes.length || this.config.live) ? void 0 : this.stop()
| + | |
− | }, e.prototype.offsetTop = function (a) {
| + | |
− | for (var b; void 0 === a.offsetTop;) a = a.parentNode;
| + | |
− | for (b = a.offsetTop; a = a.offsetParent;) b += a.offsetTop;
| + | |
− | return b
| + | |
− | }, e.prototype.isVisible = function (a) {
| + | |
− | var b, c, d, e, f;
| + | |
− | return c = a.getAttribute("data-wow-offset") || this.config.offset, f = this.config.scrollContainer && this.config.scrollContainer.scrollTop || window.pageYOffset, e = f + Math.min(this.element.clientHeight, this.util().innerHeight()) - c, d = this.offsetTop(a), b = d + a.clientHeight, e >= d && b >= f
| + | |
− | }, e.prototype.util = function () {
| + | |
− | return null != this._util ? this._util : this._util = new b
| + | |
− | }, e.prototype.disabled = function () {
| + | |
− | return !this.config.mobile && this.util().isMobile(navigator.userAgent)
| + | |
− | }, e
| + | |
− | }()
| + | |
− | }).call(this);
| + | |
− | | + | |
− | </script>
| + | |