|
|
(12 intermediate revisions by 2 users not shown) |
Line 1: |
Line 1: |
− | <html>
| + | {{Nanjing-China/JS/jquery-min}} |
− | <meta name="viewport" content="width=device-width, initial-scale=1" />
| + | {{Nanjing-China/JS/bootstrap}} |
− | <script>
| + | {{Nanjing-China/JS/jquery-parallax}} |
− | /*!
| + | {{Nanjing-China/JS/modernizr-2.6.2-min}} |
− | * Bootstrap v3.3.5 (http://getbootstrap.com)
| + | {{Nanjing-China/JS/jquery-themepunch-revolution-min}} |
− | * Copyright 2011-2015 Twitter, Inc.
| + | {{Nanjing-China/JS/jquery-nivo-slider-pack}} |
− | * Licensed under the MIT license
| + | {{Nanjing-China/JS/jquery-prettyPhoto}} |
− | */
| + | {{Nanjing-China/JS/superfish}} |
− | if ("undefined" == typeof jQuery) throw new Error("Bootstrap's JavaScript requires jQuery"); + function (a) {
| + | |
− | "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>
| + | |
− | /*!
| + | |
− | * Isotope PACKAGED v3.0.4
| + | |
− | *
| + | |
− | * Licensed GPLv3 for open source use
| + | |
− | * or Isotope Commercial License for commercial use
| + | |
− | *
| + | |
− | * http://isotope.metafizzy.co
| + | |
− | * Copyright 2017 Metafizzy
| + | |
− | */
| + | |
− | | + | |
− | ! 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>
| + | |