/** 2.7.5 | MIT Licensed */
;!function(d) {
    "use strict";
    var t, h = d.document, m = {
        modules: {},
        status: {},
        timeout: 10,
        event: {}
    }, r = function() {
        this.v = "2.7.5"
    }, e = d.LAYUI_GLOBAL || {}, v = (t = h.currentScript ? h.currentScript.src : function() {
        for (var t, e = h.scripts, o = e.length - 1, r = o; 0 < r; r--)
            if ("interactive" === e[r].readyState) {
                t = e[r].src;
                break
            }
        return t || e[o].src
    }(),
    m.dir = e.dir || t.substring(0, t.lastIndexOf("/") + 1)), g = function(t, e) {
        e = e || "log",
        d.console && console[e] && console[e]("layui error hint: " + t)
    }, b = "undefined" != typeof opera && "[object Opera]" === opera.toString(), N = m.builtin = {
        lay: "lay",
        layer: "layer",
        laydate: "laydate",
        laypage: "laypage",
        laytpl: "laytpl",
        layedit: "layedit",
        form: "form",
        upload: "upload",
        dropdown: "dropdown",
        transfer: "transfer",
        tree: "tree",
        table: "table",
        element: "element",
        rate: "rate",
        colorpicker: "colorpicker",
        slider: "slider",
        carousel: "carousel",
        flow: "flow",
        util: "util",
        code: "code",
        jquery: "jquery",
        all: "all",
        "layui.all": "layui.all"
    }, s = (r.prototype.cache = m,
    r.prototype.define = function(t, r) {
        return "function" == typeof t && (r = t,
        t = []),
        this.use(t, function() {
            var o = function(t, e) {
                layui[t] = e,
                m.status[t] = !0
            };
            return "function" == typeof r && r(function(t, e) {
                o(t, e),
                m.callback[t] = function() {
                    r(o)
                }
            }),
            this
        }, null, "define"),
        this
    }
    ,
    r.prototype.use = function(o, t, e, r) {
        var n = this
          , i = m.dir = m.dir || v
          , a = h.getElementsByTagName("head")[0]
          , u = (o = "string" == typeof o ? [o] : "function" == typeof o ? (t = o,
        ["all"]) : o,
        d.jQuery && jQuery.fn.on && (n.each(o, function(t, e) {
            "jquery" === e && o.splice(t, 1)
        }),
        layui.jquery = layui.$ = jQuery),
        o[0])
          , l = 0;
        function s(t, e) {
            var o = "PLaySTATION 3" === navigator.platform ? /^complete$/ : /^(complete|loaded)$/;
            "load" !== t.type && !o.test((t.currentTarget || t.srcElement).readyState) || (m.modules[u] = e,
            a.removeChild(p),
            function r() {
                return ++l > 1e3 * m.timeout / 4 ? g(u + " is not a valid module", "error") : void (m.status[u] ? c() : setTimeout(r, 4))
            }())
        }
        function c() {
            e.push(layui[u]),
            1 < o.length ? n.use(o.slice(1), t, e, r) : "function" == typeof t && (layui.jquery && "function" == typeof layui.jquery && "define" !== r ? layui.jquery(function() {
                t.apply(layui, e)
            }) : t.apply(layui, e))
        }
        if (e = e || [],
        m.host = m.host || (i.match(/\/\/([\s\S]+?)\//) || ["//" + location.host + "/"])[0],
        0 === o.length || layui["layui.all"] && N[u])
            return c(),
            n;
        var p, y = (y = (N[u] ? i + "modules/" : !/^\{\/\}/.test(n.modules[u]) && m.base || "") + (n.modules[u] || u) + ".js").replace(/^\{\/\}/, "");
        return !m.modules[u] && layui[u] && (m.modules[u] = y),
        m.modules[u] ? function f() {
            return ++l > 1e3 * m.timeout / 4 ? g(u + " is not a valid module", "error") : void ("string" == typeof m.modules[u] && m.status[u] ? c() : setTimeout(f, 4))
        }() : ((p = h.createElement("script"))["async"] = !0,
        p.charset = "utf-8",
        p.src = y + ((i = !0 === m.version ? m.v || (new Date).getTime() : m.version || "") ? "?v=" + i : ""),
        a.appendChild(p),
        !p.attachEvent || p.attachEvent.toString && p.attachEvent.toString().indexOf("[native code") < 0 || b ? p.addEventListener("load", function(t) {
            s(t, y)
        }, !1) : p.attachEvent("onreadystatechange", function(t) {
            s(t, y)
        }),
        m.modules[u] = y),
        n
    }
    ,
    r.prototype.disuse = function(t) {
        var o = this;
        return t = o.isArray(t) ? t : [t],
        o.each(t, function(t, e) {
            m.status[e],
            delete o[e],
            delete N[e],
            delete o.modules[e],
            delete m.status[e],
            delete m.modules[e]
        }),
        o
    }
    ,
    r.prototype.getStyle = function(t, e) {
        t = t.currentStyle || d.getComputedStyle(t, null);
        return t[t.getPropertyValue ? "getPropertyValue" : "getAttribute"](e)
    }
    ,
    r.prototype.link = function(o, r, t) {
        var n = this
          , e = h.getElementsByTagName("head")[0]
          , i = h.createElement("link")
          , t = ((t = "string" == typeof r ? r : t) || o).replace(/\.|\//g, "")
          , a = i.id = "layuicss-" + t
          , u = "creating"
          , l = 0;
        return i.rel = "stylesheet",
        i.href = o + (m.debug ? "?v=" + (new Date).getTime() : ""),
        i.media = "all",
        h.getElementById(a) || e.appendChild(i),
        "function" != typeof r || function s(t) {
            var e = h.getElementById(a);
            return ++l > 1e3 * m.timeout / 100 ? g(o + " timeout") : void (1989 === parseInt(n.getStyle(e, "width")) ? (t === u && e.removeAttribute("lay-status"),
            e.getAttribute("lay-status") === u ? setTimeout(s, 100) : r()) : (e.setAttribute("lay-status", u),
            setTimeout(function() {
                s(u)
            }, 100)))
        }(),
        n
    }
    ,
    r.prototype.addcss = function(t, e, o) {
        return layui.link(m.dir + "css/" + t, e, o)
    }
    ,
    m.callback = {},
    r.prototype.factory = function(t) {
        if (layui[t])
            return "function" == typeof m.callback[t] ? m.callback[t] : null
    }
    ,
    r.prototype.img = function(t, e, o) {
        var r = new Image;
        if (r.src = t,
        r.complete)
            return e(r);
        r.onload = function() {
            r.onload = null,
            "function" == typeof e && e(r)
        }
        ,
        r.onerror = function(t) {
            r.onerror = null,
            "function" == typeof o && o(t)
        }
    }
    ,
    r.prototype.config = function(t) {
        for (var e in t = t || {})
            m[e] = t[e];
        return this
    }
    ,
    r.prototype.modules = function() {
        var t, e = {};
        for (t in N)
            e[t] = N[t];
        return e
    }(),
    r.prototype.extend = function(t) {
        for (var e in t = t || {})
            this[e] || this.modules[e] ? g(e + " Module already exists", "error") : this.modules[e] = t[e];
        return this
    }
    ,
    r.prototype.router = r.prototype.hash = function(t) {
        var o = {
            path: [],
            search: {},
            hash: ((t = t || location.hash).match(/[^#](#.*$)/) || [])[1] || ""
        };
        return /^#\//.test(t) && (t = t.replace(/^#\//, ""),
        o.href = "/" + t,
        t = t.replace(/([^#])(#.*$)/, "$1").split("/") || [],
        this.each(t, function(t, e) {
            /^\w+=/.test(e) ? (e = e.split("="),
            o.search[e[0]] = e[1]) : o.path.push(e)
        })),
        o
    }
    ,
    r.prototype.url = function(t) {
        var n, e, o = this;
        return {
            pathname: (t ? ((t.match(/\.[^.]+?\/.+/) || [])[0] || "").replace(/^[^\/]+/, "").replace(/\?.+/, "") : location.pathname).replace(/^\//, "").split("/"),
            search: (n = {},
            e = (t ? ((t.match(/\?.+/) || [])[0] || "").replace(/\#.+/, "") : location.search).replace(/^\?+/, "").split("&"),
            o.each(e, function(t, e) {
                var o = e.indexOf("=")
                  , r = o < 0 ? e.substr(0, e.length) : 0 !== o && e.substr(0, o);
                r && (n[r] = 0 < o ? e.substr(o + 1) : null)
            }),
            n),
            hash: o.router(t ? (t.match(/#.+/) || [])[0] || "/" : location.hash)
        }
    }
    ,
    r.prototype.data = function(t, e, o) {
        if (t = t || "layui",
        o = o || localStorage,
        d.JSON && d.JSON.parse) {
            if (null === e)
                return delete o[t];
            e = "object" == typeof e ? e : {
                key: e
            };
            try {
                var r = JSON.parse(o[t])
            } catch (n) {
                r = {}
            }
            return "value"in e && (r[e.key] = e.value),
            e.remove && delete r[e.key],
            o[t] = JSON.stringify(r),
            e.key ? r[e.key] : r
        }
    }
    ,
    r.prototype.sessionData = function(t, e) {
        return this.data(t, e, sessionStorage)
    }
    ,
    r.prototype.device = function(t) {
        var o = navigator.userAgent.toLowerCase()
          , e = function(t) {
            var e = new RegExp(t + "/([^\\s\\_\\-]+)");
            return (t = (o.match(e) || [])[1]) || !1
        }
          , r = {
            os: /windows/.test(o) ? "windows" : /linux/.test(o) ? "linux" : /iphone|ipod|ipad|ios/.test(o) ? "ios" : /mac/.test(o) ? "mac" : void 0,
            ie: !!(d.ActiveXObject || "ActiveXObject"in d) && ((o.match(/msie\s(\d+)/) || [])[1] || "11"),
            weixin: e("micromessenger")
        };
        return t && !r[t] && (r[t] = e(t)),
        r.android = /android/.test(o),
        r.ios = "ios" === r.os,
        r.mobile = !(!r.android && !r.ios),
        r
    }
    ,
    r.prototype.hint = function() {
        return {
            error: g
        }
    }
    ,
    r.prototype._typeof = r.prototype.type = function(t) {
        return null === t ? String(t) : "object" == typeof t || "function" == typeof t ? (e = (e = Object.prototype.toString.call(t).match(/\s(.+)\]$/) || [])[1] || "Object",
        new RegExp("\\b(Function|Array|Date|RegExp|Object|Error|Symbol)\\b").test(e) ? e.toLowerCase() : "object") : typeof t;
        var e
    }
    ,
    r.prototype._isArray = r.prototype.isArray = function(t) {
        var e, o = this.type(t);
        return !(!t || "object" != typeof t || t === d) && (e = "length"in t && t.length,
        "array" === o || 0 === e || "number" == typeof e && 0 < e && e - 1 in t)
    }
    ,
    r.prototype.each = function(t, o) {
        var e, r = function(t, e) {
            return o.call(e[t], t, e[t])
        };
        if ("function" != typeof o)
            return this;
        if (this.isArray(t = t || []))
            for (e = 0; e < t.length && !r(e, t); e++)
                ;
        else
            for (e in t)
                if (r(e, t))
                    break;
        return this
    }
    ,
    r.prototype.sort = function(t, n, e) {
        var o = JSON.parse(JSON.stringify(t || []));
        return "object" !== this.type(t) || n ? "object" != typeof t ? [o] : (o.sort(function(t, e) {
            var o = t[n]
              , r = e[n];
            if (!isNaN(t) && !isNaN(e))
                return t - e;
            if (!isNaN(t) && isNaN(e)) {
                if (!n || "object" != typeof e)
                    return -1;
                o = t
            } else if (isNaN(t) && !isNaN(e)) {
                if (!n || "object" != typeof t)
                    return 1;
                r = e
            }
            t = [!isNaN(o), !isNaN(r)];
            return t[0] && t[1] ? o && !r && 0 !== r ? 1 : !o && 0 !== o && r ? -1 : o - r : t[0] || t[1] ? t[0] || !t[1] ? -1 : !t[0] || t[1] ? 1 : void 0 : r < o ? 1 : o < r ? -1 : 0
        }),
        e && o.reverse(),
        o) : o
    }
    ,
    r.prototype.stope = function(t) {
        t = t || d.event;
        try {
            t.stopPropagation()
        } catch (e) {
            t.cancelBubble = !0
        }
    }
    ,
    "LAYUI-EVENT-REMOVE");
    r.prototype.onevent = function(t, e, o) {
        return "string" != typeof t || "function" != typeof o ? this : r.event(t, e, null, o)
    }
    ,
    r.prototype.event = r.event = function(t, e, o, r) {
        var n = this
          , i = null
          , a = (e || "").match(/\((.*)\)$/) || []
          , t = (t + "." + e).replace(a[0], "")
          , u = a[1] || ""
          , l = function(t, e) {
            !1 === (e && e.call(n, o)) && null === i && (i = !1)
        };
        return o === s ? (delete (n.cache.event[t] || {})[u],
        n) : r ? (m.event[t] = m.event[t] || {},
        m.event[t][u] = [r],
        this) : (layui.each(m.event[t], function(t, e) {
            "{*}" === u ? layui.each(e, l) : ("" === t && layui.each(e, l),
            u && t === u && layui.each(e, l))
        }),
        i)
    }
    ,
    r.prototype.on = function(t, e, o) {
        return this.onevent.call(this, e, t, o)
    }
    ,
    r.prototype.off = function(t, e) {
        return this.event.call(this, e, t, s)
    }
    ,
    d.layui = new r
}(window);
layui.define(function(a) {
    var i = layui.cache;
    layui.config({
        dir: i.dir.replace(/lay\/dest\/$/, "")
    }),
    a("layui.all", layui.v)
});
!function(l) {
    "use strict";
    var t, f = l.document, h = function(t) {
        return new i(t)
    }, i = function(t) {
        for (var e = 0, n = "object" == typeof t ? [t] : (this.selector = t,
        f.querySelectorAll(t || null)); e < n.length; e++)
            this.push(n[e])
    };
    (i.prototype = []).constructor = i,
    h.extend = function() {
        var t, e = 1, n = arguments, o = function(t, e) {
            for (var n in t = t || ("array" === layui.type(e) ? [] : {}),
            e)
                t[n] = e[n] && e[n].constructor === Object ? o(t[n], e[n]) : e[n];
            return t
        };
        for (n[0] = "object" == typeof n[0] ? n[0] : {},
        t = n.length; e < t; e++)
            "object" == typeof n[e] && o(n[0], n[e]);
        return n[0]
    }
    ,
    h.v = "1.0.8",
    h.ie = (t = navigator.userAgent.toLowerCase(),
    !!(l.ActiveXObject || "ActiveXObject"in l) && ((t.match(/msie\s(\d+)/) || [])[1] || "11")),
    h.layui = layui || {},
    h.getPath = layui.cache.dir,
    h.stope = layui.stope,
    h.each = function() {
        return layui.each.apply(layui, arguments),
        this
    }
    ,
    h.digit = function(t, e) {
        if ("string" != typeof t && "number" != typeof t)
            return "";
        var n = "";
        e = e || 2;
        for (var o = (t = String(t)).length; o < e; o++)
            n += "0";
        return t < Math.pow(10, e) ? n + t : t
    }
    ,
    h.elem = function(t, e) {
        var n = f.createElement(t);
        return h.each(e || {}, function(t, e) {
            n.setAttribute(t, e)
        }),
        n
    }
    ,
    h.hasScrollbar = function() {
        return f.body.scrollHeight > (l.innerHeight || f.documentElement.clientHeight)
    }
    ,
    h.position = function(t, e, n) {
        var o, i, r, c, u, a, s;
        e && (n = n || {},
        t !== f && t !== h("body")[0] || (n.clickType = "right"),
        u = "right" === n.clickType ? {
            left: (u = n.e || l.event || {}).clientX,
            top: u.clientY,
            right: u.clientX,
            bottom: u.clientY
        } : t.getBoundingClientRect(),
        a = e.offsetWidth,
        s = e.offsetHeight,
        o = function(t) {
            return f.body[t = t ? "scrollLeft" : "scrollTop"] | f.documentElement[t]
        }
        ,
        r = u.left,
        c = u.bottom,
        "center" === n.align ? r -= (a - t.offsetWidth) / 2 : "right" === n.align && (r = r - a + t.offsetWidth),
        (r = r + a + 5 > (i = function(t) {
            return f.documentElement[t ? "clientWidth" : "clientHeight"]
        }
        )("width") ? i("width") - a - 5 : r) < 5 && (r = 5),
        c + s + 5 > i() && (u.top > s + 5 ? c = u.top - s - 10 : "right" === n.clickType ? (c = i() - s - 10) < 0 && (c = 0) : c = 5),
        (a = n.position) && (e.style.position = a),
        e.style.left = r + ("fixed" === a ? 0 : o(1)) + "px",
        e.style.top = c + ("fixed" === a ? 0 : o()) + "px",
        h.hasScrollbar() || (s = e.getBoundingClientRect(),
        !n.SYSTEM_RELOAD && s.bottom + 5 > i() && (n.SYSTEM_RELOAD = !0,
        setTimeout(function() {
            h.position(t, e, n)
        }, 50))))
    }
    ,
    h.options = function(t, e) {
        t = h(t),
        e = e || "lay-options";
        try {
            return new Function("return " + (t.attr(e) || "{}"))()
        } catch (n) {
            return hint.error("parseerror\uff1a" + n, "error"),
            {}
        }
    }
    ,
    h.isTopElem = function(n) {
        var t = [f, h("body")[0]]
          , o = !1;
        return h.each(t, function(t, e) {
            if (e === n)
                return o = !0
        }),
        o
    }
    ,
    i.addStr = function(n, t) {
        return n = n.replace(/\s+/, " "),
        t = t.replace(/\s+/, " ").split(" "),
        h.each(t, function(t, e) {
            new RegExp("\\b" + e + "\\b").test(n) || (n = n + " " + e)
        }),
        n.replace(/^\s|\s$/, "")
    }
    ,
    i.removeStr = function(n, t) {
        return n = n.replace(/\s+/, " "),
        t = t.replace(/\s+/, " ").split(" "),
        h.each(t, function(t, e) {
            e = new RegExp("\\b" + e + "\\b");
            e.test(n) && (n = n.replace(e, ""))
        }),
        n.replace(/\s+/, " ").replace(/^\s|\s$/, "")
    }
    ,
    i.prototype.find = function(o) {
        var i = this
          , r = 0
          , c = []
          , u = "object" == typeof o;
        return this.each(function(t, e) {
            for (var n = u ? e.contains(o) : e.querySelectorAll(o || null); r < n.length; r++)
                c.push(n[r]);
            i.shift()
        }),
        u || (i.selector = (i.selector ? i.selector + " " : "") + o),
        h.each(c, function(t, e) {
            i.push(e)
        }),
        i
    }
    ,
    i.prototype.each = function(t) {
        return h.each.call(this, this, t)
    }
    ,
    i.prototype.addClass = function(n, o) {
        return this.each(function(t, e) {
            e.className = i[o ? "removeStr" : "addStr"](e.className, n)
        })
    }
    ,
    i.prototype.removeClass = function(t) {
        return this.addClass(t, !0)
    }
    ,
    i.prototype.hasClass = function(n) {
        var o = !1;
        return this.each(function(t, e) {
            new RegExp("\\b" + n + "\\b").test(e.className) && (o = !0)
        }),
        o
    }
    ,
    i.prototype.css = function(e, o) {
        var t = this
          , i = function(t) {
            return isNaN(t) ? t : t + "px"
        };
        return "string" != typeof e || o !== undefined ? t.each(function(t, n) {
            "object" == typeof e ? h.each(e, function(t, e) {
                n.style[t] = i(e)
            }) : n.style[e] = i(o)
        }) : 0 < t.length ? t[0].style[e] : void 0
    }
    ,
    i.prototype.width = function(n) {
        var o = this;
        return n !== undefined ? o.each(function(t, e) {
            o.css("width", n)
        }) : 0 < o.length ? o[0].offsetWidth : void 0
    }
    ,
    i.prototype.height = function(n) {
        var o = this;
        return n !== undefined ? o.each(function(t, e) {
            o.css("height", n)
        }) : 0 < o.length ? o[0].offsetHeight : void 0
    }
    ,
    i.prototype.attr = function(n, o) {
        var t = this;
        return o !== undefined ? t.each(function(t, e) {
            e.setAttribute(n, o)
        }) : 0 < t.length ? t[0].getAttribute(n) : void 0
    }
    ,
    i.prototype.removeAttr = function(n) {
        return this.each(function(t, e) {
            e.removeAttribute(n)
        })
    }
    ,
    i.prototype.html = function(n) {
        var t = this;
        return n !== undefined ? this.each(function(t, e) {
            e.innerHTML = n
        }) : 0 < t.length ? t[0].innerHTML : void 0
    }
    ,
    i.prototype.val = function(n) {
        var t = this;
        return n !== undefined ? this.each(function(t, e) {
            e.value = n
        }) : 0 < t.length ? t[0].value : void 0
    }
    ,
    i.prototype.append = function(n) {
        return this.each(function(t, e) {
            "object" == typeof n ? e.appendChild(n) : e.innerHTML = e.innerHTML + n
        })
    }
    ,
    i.prototype.remove = function(n) {
        return this.each(function(t, e) {
            n ? e.removeChild(n) : e.parentNode.removeChild(e)
        })
    }
    ,
    i.prototype.on = function(n, o) {
        return this.each(function(t, e) {
            e.attachEvent ? e.attachEvent("on" + n, function(t) {
                t.target = t.srcElement,
                o.call(e, t)
            }) : e.addEventListener(n, o, !1)
        })
    }
    ,
    i.prototype.off = function(n, o) {
        return this.each(function(t, e) {
            e.detachEvent ? e.detachEvent("on" + n, o) : e.removeEventListener(n, o, !1)
        })
    }
    ,
    l.lay = h,
    l.layui && layui.define && layui.define(function(t) {
        t("lay", h)
    })
}(window, window.document);
layui.define(function(e) {
    "use strict";
    var p = {
        open: "{{",
        close: "}}"
    }
      , a = {
        exp: function(e) {
            return new RegExp(e,"g")
        },
        query: function(e, r, n) {
            return l((r || "") + p.open + ["#([\\s\\S])+?", "([^{#}])*?"][e || 0] + p.close + (n || ""))
        },
        escape: function(e) {
            return e === undefined || null === e ? "" : /[<"'>]|&(?=#[a-zA-Z0-9]+)/g.test(e += "") ? e.replace(/&(?!#?[a-zA-Z0-9]+;)/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/'/g, "&#39;").replace(/"/g, "&quot;") : e
        },
        error: function(e, r) {
            var n = "Laytpl Error: ";
            return "object" == typeof console && console.error(n + e + "\n" + (r || "")),
            n + e
        }
    }
      , l = a.exp
      , r = function(e) {
        this.tpl = e
    }
      , n = (r.pt = r.prototype,
    window.errors = 0,
    r.pt.parse = function(e, r) {
        var n = e
          , c = l("^" + p.open + "#", "")
          , t = l(p.close + "$", "");
        e = '"use strict";var view = "' + (e = e.replace(/\s+|\r|\t|\n/g, " ").replace(l(p.open + "#"), p.open + "# ").replace(l(p.close + "}"), "} " + p.close).replace(/\\/g, "\\\\").replace(l(p.open + "!(.+?)!" + p.close), function(e) {
            return e = e.replace(l("^" + p.open + "!"), "").replace(l("!" + p.close), "").replace(l(p.open + "|" + p.close), function(e) {
                return e.replace(/(.)/g, "\\$1")
            })
        }).replace(/(?="|')/g, "\\").replace(a.query(), function(e) {
            return '";' + (e = e.replace(c, "").replace(t, "")).replace(/\\(.)/g, "$1") + ';view+="'
        }).replace(a.query(1), function(e) {
            var r = '"+laytpl.escape(';
            return e.replace(/\s/g, "") === p.open + p.close ? "" : (e = e.replace(l(p.open + "|" + p.close), ""),
            /^=/.test(e) ? e = e.replace(/^=/, "") : /^-/.test(e) && (e = e.replace(/^-/, ""),
            r = '"+('),
            r + e.replace(/\\(.)/g, "$1") + ')+"')
        })) + '";return view;';
        try {
            return this.cache = e = new Function("d, laytpl",e),
            e(r, a)
        } catch (o) {
            return delete this.cache,
            a.error(o, n)
        }
    }
    ,
    r.pt.render = function(e, r) {
        var n = this;
        return e ? (e = n.cache ? n.cache(e, a) : n.parse(n.tpl, e),
        r ? void r(e) : e) : a.error("no data")
    }
    ,
    function(e) {
        return "string" != typeof e ? a.error("Template not found") : new r(e)
    }
    );
    n.config = function(e) {
        for (var r in e = e || {})
            p[r] = e[r]
    }
    ,
    n.v = "1.2.0",
    e("laytpl", n)
});
layui.define(function(e) {
    "use strict";
    var n = document
      , u = "getElementById"
      , c = "getElementsByTagName"
      , a = "layui-disabled"
      , t = function(e) {
        var a = this;
        a.config = e || {},
        a.config.index = ++o.index,
        a.render(!0)
    }
      , o = (t.prototype.type = function() {
        var e = this.config;
        if ("object" == typeof e.elem)
            return e.elem.length === undefined ? 2 : 3
    }
    ,
    t.prototype.view = function() {
        var t, i, r = this.config, n = r.groups = "groups"in r ? Number(r.groups) || 0 : 5, u = (r.layout = "object" == typeof r.layout ? r.layout : ["prev", "page", "next"],
        r.count = Number(r.count) || 0,
        r.curr = Number(r.curr) || 1,
        r.limits = "object" == typeof r.limits ? r.limits : [10, 20, 30, 40, 50],
        r.limit = Number(r.limit) || 10,
        r.pages = Math.ceil(r.count / r.limit) || 1,
        r.curr > r.pages ? r.curr = r.pages : r.curr < 1 && (r.curr = 1),
        n < 0 ? n = 1 : n > r.pages && (n = r.pages),
        r.prev = "prev"in r ? r.prev : "&#x4E0A;&#x4E00;&#x9875;",
        r.next = "next"in r ? r.next : "&#x4E0B;&#x4E00;&#x9875;",
        r.pages > n ? Math.ceil((r.curr + (1 < n ? 1 : 0)) / (0 < n ? n : 1)) : 1), s = {
            prev: r.prev ? '<a href="javascript:;" class="layui-laypage-prev' + (1 == r.curr ? " " + a : "") + '" data-page="' + (r.curr - 1) + '">' + r.prev + "</a>" : "",
            page: function() {
                var e = [];
                if (r.count < 1)
                    return "";
                1 < u && !1 !== r.first && 0 !== n && e.push('<a href="javascript:;" class="layui-laypage-first" data-page="1"  title="&#x9996;&#x9875;">' + (r.first || 1) + "</a>");
                var a = Math.floor((n - 1) / 2)
                  , t = 1 < u ? r.curr - a : 1
                  , i = 1 < u ? (a = r.curr + (n - a - 1)) > r.pages ? r.pages : a : n;
                for (i - t < n - 1 && (t = i - n + 1),
                !1 !== r.first && 2 < t && e.push('<span class="layui-laypage-spr">&#x2026;</span>'); t <= i; t++)
                    t === r.curr ? e.push('<span class="layui-laypage-curr"><em class="layui-laypage-em" ' + (/^#/.test(r.theme) ? 'style="background-color:' + r.theme + ';"' : "") + "></em><em>" + t + "</em></span>") : e.push('<a href="javascript:;" data-page="' + t + '">' + t + "</a>");
                return r.pages > n && r.pages > i && !1 !== r.last && (i + 1 < r.pages && e.push('<span class="layui-laypage-spr">&#x2026;</span>'),
                0 !== n && e.push('<a href="javascript:;" class="layui-laypage-last" title="&#x5C3E;&#x9875;"  data-page="' + r.pages + '">' + (r.last || r.pages) + "</a>")),
                e.join("")
            }(),
            next: r.next ? '<a href="javascript:;" class="layui-laypage-next' + (r.curr == r.pages ? " " + a : "") + '" data-page="' + (r.curr + 1) + '">' + r.next + "</a>" : "",
            count: '<span class="layui-laypage-count">\u5171 ' + r.count + " \u6761</span>",
            limit: (t = ['<span class="layui-laypage-limits"><select lay-ignore>'],
            layui.each(r.limits, function(e, a) {
                t.push('<option value="' + a + '"' + (a === r.limit ? "selected" : "") + ">" + a + " \u6761/\u9875</option>")
            }),
            t.join("") + "</select></span>"),
            refresh: ['<a href="javascript:;" data-page="' + r.curr + '" class="layui-laypage-refresh">', '<i class="layui-icon layui-icon-refresh"></i>', "</a>"].join(""),
            skip: ['<span class="layui-laypage-skip">&#x5230;&#x7B2C;', '<input type="text" min="1" value="' + r.curr + '" class="layui-input">', '&#x9875;<button type="button" class="layui-laypage-btn">&#x786e;&#x5b9a;</button>', "</span>"].join("")
        };
        return ['<div class="layui-box layui-laypage layui-laypage-' + (r.theme ? /^#/.test(r.theme) ? "molv" : r.theme : "default") + '" id="layui-laypage-' + r.index + '">', (i = [],
        layui.each(r.layout, function(e, a) {
            s[a] && i.push(s[a])
        }),
        i.join("")), "</div>"].join("")
    }
    ,
    t.prototype.jump = function(e, a) {
        if (e) {
            var t = this
              , i = t.config
              , r = e.children
              , n = e[c]("button")[0]
              , u = e[c]("input")[0]
              , e = e[c]("select")[0]
              , s = function() {
                var e = Number(u.value.replace(/\s|\D/g, ""));
                e && (i.curr = e,
                t.render())
            };
            if (a)
                return s();
            for (var l = 0, p = r.length; l < p; l++)
                "a" === r[l].nodeName.toLowerCase() && o.on(r[l], "click", function() {
                    var e = Number(this.getAttribute("data-page"));
                    e < 1 || e > i.pages || (i.curr = e,
                    t.render())
                });
            e && o.on(e, "change", function() {
                var e = this.value;
                i.curr * e > i.count && (i.curr = Math.ceil(i.count / e)),
                i.limit = e,
                t.render()
            }),
            n && o.on(n, "click", function() {
                s()
            })
        }
    }
    ,
    t.prototype.skip = function(t) {
        var i, e;
        t && (i = this,
        (e = t[c]("input")[0]) && o.on(e, "keyup", function(e) {
            var a = this.value
              , e = e.keyCode;
            /^(37|38|39|40)$/.test(e) || (/\D/.test(a) && (this.value = a.replace(/\D/, "")),
            13 === e && i.jump(t, !0))
        }))
    }
    ,
    t.prototype.render = function(e) {
        var a = this
          , t = a.config
          , i = a.type()
          , r = a.view()
          , i = (2 === i ? t.elem && (t.elem.innerHTML = r) : 3 === i ? t.elem.html(r) : n[u](t.elem) && (n[u](t.elem).innerHTML = r),
        t.jump && t.jump(t, e),
        n[u]("layui-laypage-" + t.index));
        a.jump(i),
        t.hash && !e && (location.hash = "!" + t.hash + "=" + t.curr),
        a.skip(i)
    }
    ,
    {
        render: function(e) {
            return new t(e).index
        },
        index: layui.laypage ? layui.laypage.index + 1e4 : 0,
        on: function(a, e, t) {
            return a.attachEvent ? a.attachEvent("on" + e, function(e) {
                e.target = e.srcElement,
                t.call(a, e)
            }) : a.addEventListener(e, t, !1),
            this
        }
    });
    e("laypage", o)
});
!function(i, r) {
    "use strict";
    var n = i.layui && layui.define
      , l = {
        getPath: i.lay && lay.getPath ? lay.getPath : "",
        link: function(e, t, a) {
            u.path && i.lay && lay.layui && lay.layui.link(u.path + e, t, a)
        }
    }
      , e = i.LAYUI_GLOBAL || {}
      , u = {
        v: "5.3.1",
        config: {
            weekStart: 0
        },
        index: i.laydate && i.laydate.v ? 1e5 : 0,
        path: e.laydate_dir || l.getPath,
        set: function(e) {
            var t = this;
            return t.config = lay.extend({}, t.config, e),
            t
        },
        ready: function(e) {
            var t = "laydate"
              , a = (n ? "modules/laydate/" : "theme/") + "default/laydate.css?v=" + u.v;
            return n ? layui.addcss(a, e, t) : l.link(a, e, t),
            this
        }
    }
      , s = function() {
        var t = this
          , e = t.config.id;
        return {
            hint: function(e) {
                t.hint.call(t, e)
            },
            config: (s.that[e] = t).config
        }
    }
      , a = "laydate"
      , w = "layui-this"
      , x = "laydate-disabled"
      , h = [100, 2e5]
      , p = "layui-laydate-static"
      , M = "layui-laydate-list"
      , o = "layui-laydate-hint"
      , E = ".laydate-btns-confirm"
      , C = "laydate-time-text"
      , k = "laydate-btns-time"
      , f = "layui-laydate-preview"
      , g = function(e) {
        var t = this
          , a = (t.index = ++u.index,
        t.config = lay.extend({}, t.config, u.config, e),
        lay(e.elem || t.config.elem));
        if (1 < a.length)
            return layui.each(a, function() {
                u.render(lay.extend({}, t.config, {
                    elem: this
                }))
            }),
            t;
        (e = t.config).id = "id"in e ? e.id : t.index,
        u.ready(function() {
            t.init()
        })
    }
      , y = "yyyy|y|MM|M|dd|d|HH|H|mm|m|ss|s";
    s.formatArr = function(e) {
        return (e || "").match(new RegExp(y + "|.","g")) || []
    }
    ,
    g.isLeapYear = function(e) {
        return e % 4 == 0 && e % 100 != 0 || e % 400 == 0
    }
    ,
    g.prototype.config = {
        type: "date",
        range: !1,
        format: "yyyy-MM-dd",
        value: null,
        isInitValue: !0,
        min: "1900-1-1",
        max: "2099-12-31",
        trigger: "click",
        show: !1,
        showBottom: !0,
        isPreview: !0,
        btns: ["clear", "now", "confirm"],
        lang: "cn",
        theme: "default",
        position: null,
        calendar: !1,
        mark: {},
        holidays: null,
        zIndex: null,
        done: null,
        change: null
    },
    g.prototype.lang = function() {
        var e = {
            cn: {
                weeks: ["\u65e5", "\u4e00", "\u4e8c", "\u4e09", "\u56db", "\u4e94", "\u516d"],
                time: ["\u65f6", "\u5206", "\u79d2"],
                timeTips: "\u9009\u62e9\u65f6\u95f4",
                startTime: "\u5f00\u59cb\u65f6\u95f4",
                endTime: "\u7ed3\u675f\u65f6\u95f4",
                dateTips: "\u8fd4\u56de\u65e5\u671f",
                month: ["\u4e00", "\u4e8c", "\u4e09", "\u56db", "\u4e94", "\u516d", "\u4e03", "\u516b", "\u4e5d", "\u5341", "\u5341\u4e00", "\u5341\u4e8c"],
                tools: {
                    confirm: "\u786e\u5b9a",
                    clear: "\u6e05\u7a7a",
                    now: "\u73b0\u5728"
                },
                timeout: "\u7ed3\u675f\u65f6\u95f4\u4e0d\u80fd\u65e9\u4e8e\u5f00\u59cb\u65f6\u95f4<br>\u8bf7\u91cd\u65b0\u9009\u62e9",
                invalidDate: "\u4e0d\u5728\u6709\u6548\u65e5\u671f\u6216\u65f6\u95f4\u8303\u56f4\u5185",
                formatError: ["\u65e5\u671f\u683c\u5f0f\u4e0d\u5408\u6cd5<br>\u5fc5\u987b\u9075\u5faa\u4e0b\u8ff0\u683c\u5f0f\uff1a<br>", "<br>\u5df2\u4e3a\u4f60\u91cd\u7f6e"],
                preview: "\u5f53\u524d\u9009\u4e2d\u7684\u7ed3\u679c"
            },
            en: {
                weeks: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"],
                time: ["Hours", "Minutes", "Seconds"],
                timeTips: "Select Time",
                startTime: "Start Time",
                endTime: "End Time",
                dateTips: "Select Date",
                month: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
                tools: {
                    confirm: "Confirm",
                    clear: "Clear",
                    now: "Now"
                },
                timeout: "End time cannot be less than start Time<br>Please re-select",
                invalidDate: "Invalid date",
                formatError: ["The date format error<br>Must be followed\uff1a<br>", "<br>It has been reset"],
                preview: "The selected result"
            }
        };
        return e[this.config.lang] || e.cn
    }
    ,
    g.prototype.init = function() {
        var r = this
          , o = r.config
          , e = "static" === o.position
          , t = {
            year: "yyyy",
            month: "yyyy-MM",
            date: "yyyy-MM-dd",
            time: "HH:mm:ss",
            datetime: "yyyy-MM-dd HH:mm:ss"
        };
        o.elem = lay(o.elem),
        o.eventElem = lay(o.eventElem),
        o.elem[0] && (r.rangeStr = o.range ? "string" == typeof o.range ? o.range : "-" : "",
        "array" === layui.type(o.range) && (r.rangeElem = [lay(o.range[0]), lay(o.range[1])]),
        t[o.type] || (i.console && console.error && console.error("laydate type error:'" + o.type + "' is not supported"),
        o.type = "date"),
        o.format === t.date && (o.format = t[o.type] || t.date),
        r.format = s.formatArr(o.format),
        o.weekStart && !/^[0-6]$/.test(o.weekStart) && (t = r.lang(),
        o.weekStart = t.weeks.indexOf(o.weekStart),
        -1 === o.weekStart && (o.weekStart = 0)),
        r.EXP_IF = "",
        r.EXP_SPLIT = "",
        lay.each(r.format, function(e, t) {
            e = new RegExp(y).test(t) ? "\\d{" + (new RegExp(y).test(r.format[0 === e ? e + 1 : e - 1] || "") ? /^yyyy|y$/.test(t) ? 4 : t.length : /^yyyy$/.test(t) ? "1,4" : /^y$/.test(t) ? "1,308" : "1,2") + "}" : "\\" + t;
            r.EXP_IF = r.EXP_IF + e,
            r.EXP_SPLIT = r.EXP_SPLIT + "(" + e + ")"
        }),
        r.EXP_IF_ONE = new RegExp("^" + r.EXP_IF + "$"),
        r.EXP_IF = new RegExp("^" + (o.range ? r.EXP_IF + "\\s\\" + r.rangeStr + "\\s" + r.EXP_IF : r.EXP_IF) + "$"),
        r.EXP_SPLIT = new RegExp("^" + r.EXP_SPLIT + "$",""),
        r.isInput(o.elem[0]) || "focus" === o.trigger && (o.trigger = "click"),
        o.elem.attr("lay-key") || (o.elem.attr("lay-key", r.index),
        o.eventElem.attr("lay-key", r.index)),
        o.mark = lay.extend({}, o.calendar && "cn" === o.lang ? {
            "0-1-1": "\u5143\u65e6",
            "0-2-14": "\u60c5\u4eba",
            "0-3-8": "\u5987\u5973",
            "0-3-12": "\u690d\u6811",
            "0-4-1": "\u611a\u4eba",
            "0-5-1": "\u52b3\u52a8",
            "0-5-4": "\u9752\u5e74",
            "0-6-1": "\u513f\u7ae5",
            "0-9-10": "\u6559\u5e08",
            "0-10-1": "\u56fd\u5e86",
            "0-12-25": "\u5723\u8bde"
        } : {}, o.mark),
        lay.each(["min", "max"], function(e, t) {
            var a, n, i = [], l = [];
            l = "number" == typeof o[t] ? (n = o[t],
            a = new Date,
            a = r.newDate({
                year: a.getFullYear(),
                month: a.getMonth(),
                date: a.getDate(),
                hours: "23",
                minutes: "59",
                seconds: "59"
            }).getTime(),
            i = [(n = new Date(n ? n < 864e5 ? a + 864e5 * n : n : a)).getFullYear(), n.getMonth() + 1, n.getDate()],
            [n.getHours(), n.getMinutes(), n.getSeconds()]) : (i = (o[t].match(/\d+-\d+-\d+/) || [""])[0].split("-"),
            (o[t].match(/\d+:\d+:\d+/) || [""])[0].split(":")),
            o[t] = {
                year: 0 | i[0] || (new Date).getFullYear(),
                month: i[1] ? (0 | i[1]) - 1 : (new Date).getMonth(),
                date: 0 | i[2] || (new Date).getDate(),
                hours: 0 | l[0],
                minutes: 0 | l[1],
                seconds: 0 | l[2]
            }
        }),
        r.elemID = "layui-laydate" + o.elem.attr("lay-key"),
        (o.show || e) && r.render(),
        e || r.events(),
        o.value && o.isInitValue && ("date" === layui.type(o.value) ? r.setValue(r.parse(0, r.systemDate(o.value))) : r.setValue(o.value)))
    }
    ,
    g.prototype.render = function() {
        var n, e, t = this, o = t.config, s = t.lang(), i = "static" === o.position, a = t.elem = lay.elem("div", {
            id: t.elemID,
            "class": ["layui-laydate", o.range ? " layui-laydate-range" : "", i ? " " + p : "", o.theme && "default" !== o.theme && !/^#/.test(o.theme) ? " laydate-theme-" + o.theme : ""].join("")
        }), y = t.elemMain = [], d = t.elemHeader = [], m = t.elemCont = [], c = t.table = [], l = t.footer = lay.elem("div", {
            "class": "layui-laydate-footer"
        });
        o.zIndex && (a.style.zIndex = o.zIndex),
        lay.each(new Array(2), function(e) {
            if (!o.range && 0 < e)
                return !0;
            var a = lay.elem("div", {
                "class": "layui-laydate-header"
            })
              , t = [((t = lay.elem("i", {
                "class": "layui-icon laydate-icon laydate-prev-y"
            })).innerHTML = "&#xe65a;",
            t), ((t = lay.elem("i", {
                "class": "layui-icon laydate-icon laydate-prev-m"
            })).innerHTML = "&#xe603;",
            t), (t = lay.elem("div", {
                "class": "laydate-set-ym"
            }),
            n = lay.elem("span"),
            l = lay.elem("span"),
            t.appendChild(n),
            t.appendChild(l),
            t), ((n = lay.elem("i", {
                "class": "layui-icon laydate-icon laydate-next-m"
            })).innerHTML = "&#xe602;",
            n), ((l = lay.elem("i", {
                "class": "layui-icon laydate-icon laydate-next-y"
            })).innerHTML = "&#xe65b;",
            l)]
              , n = lay.elem("div", {
                "class": "layui-laydate-content"
            })
              , i = lay.elem("table")
              , l = lay.elem("thead")
              , r = lay.elem("tr");
            lay.each(t, function(e, t) {
                a.appendChild(t)
            }),
            l.appendChild(r),
            lay.each(new Array(6), function(a) {
                var n = i.insertRow(0);
                lay.each(new Array(7), function(e) {
                    var t;
                    0 === a && ((t = lay.elem("th")).innerHTML = s.weeks[(e + o.weekStart) % 7],
                    r.appendChild(t)),
                    n.insertCell(e)
                })
            }),
            i.insertBefore(l, i.children[0]),
            n.appendChild(i),
            y[e] = lay.elem("div", {
                "class": "layui-laydate-main laydate-main-list-" + e
            }),
            y[e].appendChild(a),
            y[e].appendChild(n),
            d.push(t),
            m.push(n),
            c.push(i)
        }),
        lay(l).html((e = [],
        n = [],
        "datetime" === o.type && e.push('<span lay-type="datetime" class="' + k + '">' + s.timeTips + "</span>"),
        !o.range && "datetime" === o.type || e.push('<span class="' + f + '" title="' + s.preview + '"></span>'),
        lay.each(o.btns, function(e, t) {
            var a = s.tools[t] || "btn";
            o.range && "now" === t || (i && "clear" === t && (a = "cn" === o.lang ? "\u91cd\u7f6e" : "Reset"),
            n.push('<span lay-type="' + t + '" class="laydate-btns-' + t + '">' + a + "</span>"))
        }),
        e.push('<div class="laydate-footer-btns">' + n.join("") + "</div>"),
        e.join(""))),
        lay.each(y, function(e, t) {
            a.appendChild(t)
        }),
        o.showBottom && a.appendChild(l),
        /^#/.test(o.theme) && (e = lay.elem("style"),
        l = ["#{{id}} .layui-laydate-header{background-color:{{theme}};}", "#{{id}} .layui-this{background-color:{{theme}} !important;}"].join("").replace(/{{id}}/g, t.elemID).replace(/{{theme}}/g, o.theme),
        "styleSheet"in e ? (e.setAttribute("type", "text/css"),
        e.styleSheet.cssText = l) : e.innerHTML = l,
        lay(a).addClass("laydate-theme-molv"),
        a.appendChild(e)),
        t.remove(g.thisElemDate),
        u.thisId = o.id,
        i ? o.elem.append(a) : (r.body.appendChild(a),
        t.position()),
        t.checkDate().calendar(null, 0, "init"),
        t.changeEvent(),
        g.thisElemDate = t.elemID,
        "function" == typeof o.ready && o.ready(lay.extend({}, o.dateTime, {
            month: o.dateTime.month + 1
        })),
        t.preview()
    }
    ,
    g.prototype.remove = function(e) {
        var t = this
          , a = t.config
          , n = lay("#" + (e || t.elemID));
        return n[0] && (n.hasClass(p) || t.checkDate(function() {
            n.remove(),
            delete u.thisId,
            "function" == typeof a.close && a.close(t)
        })),
        t
    }
    ,
    g.prototype.position = function() {
        var e = this.config;
        return lay.position(this.bindElem || e.elem[0], this.elem, {
            position: e.position
        }),
        this
    }
    ,
    g.prototype.hint = function(e) {
        var t = this
          , a = (t.config,
        lay.elem("div", {
            "class": o
        }));
        t.elem && (a.innerHTML = e || "",
        lay(t.elem).find("." + o).remove(),
        t.elem.appendChild(a),
        clearTimeout(t.hinTimer),
        t.hinTimer = setTimeout(function() {
            lay(t.elem).find("." + o).remove()
        }, 3e3))
    }
    ,
    g.prototype.getAsYM = function(e, t, a) {
        return a ? t-- : t++,
        t < 0 && (t = 11,
        e--),
        11 < t && (t = 0,
        e++),
        [e, t]
    }
    ,
    g.prototype.systemDate = function(e) {
        var t = e || new Date;
        return {
            year: t.getFullYear(),
            month: t.getMonth(),
            date: t.getDate(),
            hours: e ? e.getHours() : 0,
            minutes: e ? e.getMinutes() : 0,
            seconds: e ? e.getSeconds() : 0
        }
    }
    ,
    g.prototype.checkDate = function(e) {
        var t, o, s = this, y = (new Date,
        s.config), a = s.lang(), n = y.dateTime = y.dateTime || s.systemDate(), i = s.bindElem || y.elem[0], l = (s.isInput(i),
        function() {
            if (s.rangeElem) {
                var e = [s.rangeElem[0].val(), s.rangeElem[1].val()];
                if (e[0] && e[1])
                    return e.join(" " + s.rangeStr + " ")
            }
            return s.isInput(i) ? i.value : "static" === y.position ? "" : lay(i).attr("lay-date")
        }()), d = function(e) {
            e.year > h[1] && (e.year = h[1],
            o = !0),
            11 < e.month && (e.month = 11,
            o = !0),
            59 < e.seconds && (e.seconds = 0,
            e.minutes++,
            o = !0),
            59 < e.minutes && (e.minutes = 0,
            e.hours++,
            o = !0),
            23 < e.hours && (e.hours = 0,
            o = !0),
            t = u.getEndDate(e.month + 1, e.year),
            e.date > t && (e.date = t,
            o = !0)
        }, r = function(n, i, l) {
            var r = ["startTime", "endTime"];
            i = (i.match(s.EXP_SPLIT) || []).slice(1),
            l = l || 0,
            y.range && (s[r[l]] = s[r[l]] || {}),
            lay.each(s.format, function(e, t) {
                var a = parseFloat(i[e]);
                i[e].length < t.length && (o = !0),
                /yyyy|y/.test(t) ? (a < h[0] && (a = h[0],
                o = !0),
                n.year = a) : /MM|M/.test(t) ? (a < 1 && (a = 1,
                o = !0),
                n.month = a - 1) : /dd|d/.test(t) ? (a < 1 && (a = 1,
                o = !0),
                n.date = a) : /HH|H/.test(t) ? (a < 0 && (o = !(a = 0)),
                23 < a && (a = 23,
                o = !0),
                n.hours = a,
                y.range && (s[r[l]].hours = a)) : /mm|m/.test(t) ? (a < 0 && (o = !(a = 0)),
                59 < a && (a = 59,
                o = !0),
                n.minutes = a,
                y.range && (s[r[l]].minutes = a)) : /ss|s/.test(t) && (a < 0 && (o = !(a = 0)),
                59 < a && (a = 59,
                o = !0),
                n.seconds = a,
                y.range && (s[r[l]].seconds = a))
            }),
            d(n)
        };
        if ("limit" === e)
            return d(n),
            s;
        "string" == typeof (l = l || y.value) && (l = l.replace(/\s+/g, " ").replace(/^\s|\s$/g, ""));
        var m, c = function() {
            var e, t, a;
            y.range && (s.endDate = s.endDate || lay.extend({}, y.dateTime, (e = {},
            t = y.dateTime,
            a = s.getAsYM(t.year, t.month),
            "year" === y.type ? e.year = t.year + 1 : "time" !== y.type && (e.year = a[0],
            e.month = a[1]),
            "datetime" !== y.type && "time" !== y.type || (e.hours = 23,
            e.minutes = e.seconds = 59),
            e)))
        };
        return c(),
        "string" == typeof l && l ? s.EXP_IF.test(l) ? y.range ? (l = l.split(" " + s.rangeStr + " "),
        lay.each([y.dateTime, s.endDate], function(e, t) {
            r(t, l[e], e)
        })) : r(n, l) : (s.hint(a.formatError[0] + (y.range ? y.format + " " + s.rangeStr + " " + y.format : y.format) + a.formatError[1]),
        o = !0) : l && "date" === layui.type(l) ? y.dateTime = s.systemDate(l) : (y.dateTime = s.systemDate(),
        delete s.startTime,
        delete s.endDate,
        c(),
        delete s.endTime),
        s.rangeElem && (a = [s.rangeElem[0].val(), s.rangeElem[1].val()],
        m = [y.dateTime, s.endDate],
        lay.each(a, function(e, t) {
            s.EXP_IF_ONE.test(t) && r(m[e], t, e)
        })),
        d(n),
        y.range && d(s.endDate),
        o && l && s.setValue(!y.range || s.endDate ? s.parse() : ""),
        s.getDateTime(n) > s.getDateTime(y.max) ? n = y.dateTime = lay.extend({}, y.max) : s.getDateTime(n) < s.getDateTime(y.min) && (n = y.dateTime = lay.extend({}, y.min)),
        y.range && ((s.getDateTime(s.endDate) < s.getDateTime(y.min) || s.getDateTime(s.endDate) > s.getDateTime(y.max)) && (s.endDate = lay.extend({}, y.max)),
        s.startTime = {
            hours: y.dateTime.hours,
            minutes: y.dateTime.minutes,
            seconds: y.dateTime.seconds
        },
        s.endTime = {
            hours: s.endDate.hours,
            minutes: s.endDate.minutes,
            seconds: s.endDate.seconds
        }),
        e && e(),
        s
    }
    ,
    g.prototype.mark = function(e, a) {
        var n, t = this.config;
        return lay.each(t.mark, function(e, t) {
            e = e.split("-");
            e[0] != a[0] && 0 != e[0] || e[1] != a[1] && 0 != e[1] || e[2] != a[2] || (n = t || a[2])
        }),
        n && e.html('<span class="laydate-day-mark">' + n + "</span>"),
        this
    }
    ,
    g.prototype.holidays = function(n, i) {
        var e = this.config
          , l = ["", "work"];
        return "array" !== layui.type(e.holidays) || lay.each(e.holidays, function(a, e) {
            lay.each(e, function(e, t) {
                t === n.attr("lay-ymd") && n.html('<span class="laydate-day-holidays"' + (l[a] ? 'type="' + l[a] + '"' : "") + ">" + i[2] + "</span>")
            })
        }),
        this
    }
    ,
    g.prototype.limit = function(e, t, a, i) {
        var l = this
          , n = l.config
          , r = {}
          , a = (i ? 0 : 41) < a ? l.endDate : n.dateTime
          , a = lay.extend({}, a, t || {});
        return lay.each({
            now: a,
            min: n.min,
            max: n.max
        }, function(e, a) {
            var n;
            r[e] = l.newDate(lay.extend({
                year: a.year,
                month: a.month,
                date: a.date
            }, (n = {},
            lay.each(i, function(e, t) {
                n[t] = a[t]
            }),
            n))).getTime()
        }),
        t = r.now < r.min || r.now > r.max,
        e && e[t ? "addClass" : "removeClass"](x),
        t
    }
    ,
    g.prototype.thisDateTime = function(e) {
        var t = this.config;
        return e ? this.endDate : t.dateTime
    }
    ,
    g.prototype.calendar = function(e, t, a) {
        var i, l, r, o = this, n = o.config, t = t ? 1 : 0, s = e || o.thisDateTime(t), y = new Date, d = o.lang(), m = "date" !== n.type && "datetime" !== n.type, c = lay(o.table[t]).find("td"), t = lay(o.elemHeader[t][2]).find("span");
        return s.year < h[0] && (s.year = h[0],
        o.hint(d.invalidDate)),
        s.year > h[1] && (s.year = h[1],
        o.hint(d.invalidDate)),
        o.firstDate || (o.firstDate = lay.extend({}, s)),
        y.setFullYear(s.year, s.month, 1),
        i = (y.getDay() + (7 - n.weekStart)) % 7,
        l = u.getEndDate(s.month || 12, s.year),
        r = u.getEndDate(s.month + 1, s.year),
        lay.each(c, function(e, t) {
            var a = [s.year, s.month]
              , n = 0;
            (t = lay(t)).removeAttr("class"),
            e < i ? (n = l - i + e,
            t.addClass("laydate-day-prev"),
            a = o.getAsYM(s.year, s.month, "sub")) : i <= e && e < r + i ? (n = e - i) + 1 === s.date && t.addClass(w) : (n = e - r - i,
            t.addClass("laydate-day-next"),
            a = o.getAsYM(s.year, s.month)),
            a[1]++,
            a[2] = n + 1,
            t.attr("lay-ymd", a.join("-")).html(a[2]),
            o.mark(t, a).holidays(t, a).limit(t, {
                year: a[0],
                month: a[1] - 1,
                date: a[2]
            }, e)
        }),
        lay(t[0]).attr("lay-ym", s.year + "-" + (s.month + 1)),
        lay(t[1]).attr("lay-ym", s.year + "-" + (s.month + 1)),
        "cn" === n.lang ? (lay(t[0]).attr("lay-type", "year").html(s.year + " \u5e74"),
        lay(t[1]).attr("lay-type", "month").html(s.month + 1 + " \u6708")) : (lay(t[0]).attr("lay-type", "month").html(d.month[s.month]),
        lay(t[1]).attr("lay-type", "year").html(s.year)),
        m && (n.range ? e && (o.listYM = [[n.dateTime.year, n.dateTime.month + 1], [o.endDate.year, o.endDate.month + 1]],
        o.list(n.type, 0).list(n.type, 1),
        "time" === n.type ? o.setBtnStatus("\u65f6\u95f4", lay.extend({}, o.systemDate(), o.startTime), lay.extend({}, o.systemDate(), o.endTime)) : o.setBtnStatus(!0)) : (o.listYM = [[s.year, s.month + 1]],
        o.list(n.type, 0))),
        n.range && "init" === a && !e && o.calendar(o.endDate, 1),
        n.range || o.limit(lay(o.footer).find(E), null, 0, ["hours", "minutes", "seconds"]),
        o.setBtnStatus(),
        o
    }
    ,
    g.prototype.list = function(t, n) {
        var i, l, e, r, o = this, s = o.config, y = s.dateTime, d = o.lang(), a = s.range && "date" !== s.type && "datetime" !== s.type, m = lay.elem("ul", {
            "class": M + " " + {
                year: "laydate-year-list",
                month: "laydate-month-list",
                time: "laydate-time-list"
            }[t]
        }), c = o.elemHeader[n], u = lay(c[2]).find("span"), h = o.elemCont[n || 0], p = lay(h).find("." + M)[0], f = "cn" === s.lang, g = f ? "\u5e74" : "", v = o.listYM[n] || {}, T = ["hours", "minutes", "seconds"], D = ["startTime", "endTime"][n];
        return v[0] < 1 && (v[0] = 1),
        "year" === t ? (e = i = v[0] - 7,
        i < 1 && (e = i = 1),
        lay.each(new Array(15), function(e) {
            var t = lay.elem("li", {
                "lay-ym": i
            })
              , a = {
                year: i,
                month: 0,
                date: 1
            };
            i == v[0] && lay(t).addClass(w),
            t.innerHTML = i + g,
            m.appendChild(t),
            o.limit(lay(t), a, n),
            i++
        }),
        lay(u[f ? 0 : 1]).attr("lay-ym", i - 8 + "-" + v[1]).html(e + g + " - " + (i - 1) + g)) : "month" === t ? (lay.each(new Array(12), function(e) {
            var t = lay.elem("li", {
                "lay-ym": e
            })
              , a = {
                year: v[0],
                month: e,
                date: 1
            };
            e + 1 == v[1] && lay(t).addClass(w),
            t.innerHTML = d.month[e] + (f ? "\u6708" : ""),
            m.appendChild(t),
            o.limit(lay(t), a, n)
        }),
        lay(u[f ? 0 : 1]).attr("lay-ym", v[0] + "-" + v[1]).html(v[0] + g)) : "time" === t && (l = function() {
            lay(m).find("ol").each(function(a, e) {
                lay(e).find("li").each(function(e, t) {
                    o.limit(lay(t), [{
                        hours: e
                    }, {
                        hours: o[D].hours,
                        minutes: e
                    }, {
                        hours: o[D].hours,
                        minutes: o[D].minutes,
                        seconds: e
                    }][a], n, [["hours"], ["hours", "minutes"], ["hours", "minutes", "seconds"]][a])
                })
            }),
            s.range || o.limit(lay(o.footer).find(E), o[D], 0, ["hours", "minutes", "seconds"])
        }
        ,
        s.range ? o[D] || (o[D] = "startTime" === D ? y : o.endDate) : o[D] = y,
        lay.each([24, 60, 60], function(t, e) {
            var a = lay.elem("li")
              , n = ["<p>" + d.time[t] + "</p><ol>"];
            lay.each(new Array(e), function(e) {
                n.push("<li" + (o[D][T[t]] === e ? ' class="' + w + '"' : "") + ">" + lay.digit(e, 2) + "</li>")
            }),
            a.innerHTML = n.join("") + "</ol>",
            m.appendChild(a)
        }),
        l()),
        p && h.removeChild(p),
        h.appendChild(m),
        "year" === t || "month" === t ? (lay(o.elemMain[n]).addClass("laydate-ym-show"),
        lay(m).find("li").on("click", function() {
            var e = 0 | lay(this).attr("lay-ym");
            lay(this).hasClass(x) || (0 === n ? (y[t] = e,
            o.limit(lay(o.footer).find(E), null, 0)) : o.endDate[t] = e,
            "year" === s.type || "month" === s.type ? (lay(m).find("." + w).removeClass(w),
            lay(this).addClass(w),
            "month" === s.type && "year" === t && (o.listYM[n][0] = e,
            a && ((n ? o.endDate : y).year = e),
            o.list("month", n))) : (o.checkDate("limit").calendar(null, n),
            o.closeList()),
            o.setBtnStatus(),
            s.range || ("month" === s.type && "month" === t || "year" === s.type && "year" === t) && o.setValue(o.parse()).remove().done(),
            o.done(null, "change"),
            lay(o.footer).find("." + k).removeClass(x))
        })) : (e = lay.elem("span", {
            "class": C
        }),
        r = function() {
            lay(m).find("ol").each(function(e) {
                var a = this
                  , t = lay(a).find("li");
                a.scrollTop = 30 * (o[D][T[e]] - 2),
                a.scrollTop <= 0 && t.each(function(e, t) {
                    if (!lay(this).hasClass(x))
                        return a.scrollTop = 30 * (e - 2),
                        !0
                })
            })
        }
        ,
        u = lay(c[2]).find("." + C),
        r(),
        e.innerHTML = s.range ? [d.startTime, d.endTime][n] : d.timeTips,
        lay(o.elemMain[n]).addClass("laydate-time-show"),
        u[0] && u.remove(),
        c[2].appendChild(e),
        lay(m).find("ol").each(function(t) {
            var a = this;
            lay(a).find("li").on("click", function() {
                var e = 0 | this.innerHTML;
                lay(this).hasClass(x) || (s.range ? o[D][T[t]] = e : y[T[t]] = e,
                lay(a).find("." + w).removeClass(w),
                lay(this).addClass(w),
                l(),
                r(),
                !o.endDate && "time" !== s.type || o.done(null, "change"),
                o.setBtnStatus())
            })
        })),
        o
    }
    ,
    g.prototype.listYM = [],
    g.prototype.closeList = function() {
        var a = this;
        a.config;
        lay.each(a.elemCont, function(e, t) {
            lay(this).find("." + M).remove(),
            lay(a.elemMain[e]).removeClass("laydate-ym-show laydate-time-show")
        }),
        lay(a.elem).find("." + C).remove()
    }
    ,
    g.prototype.setBtnStatus = function(e, t, a) {
        var n = this
          , i = n.config
          , l = n.lang()
          , r = lay(n.footer).find(E);
        i.range && "time" !== i.type && (t = t || i.dateTime,
        a = a || n.endDate,
        i = n.newDate(t).getTime() > n.newDate(a).getTime(),
        n.limit(null, t) || n.limit(null, a) ? r.addClass(x) : r[i ? "addClass" : "removeClass"](x),
        e && i && n.hint("string" == typeof e ? l.timeout.replace(/\u65e5\u671f/g, e) : l.timeout))
    }
    ,
    g.prototype.parse = function(e, t) {
        var a = this
          , n = a.config
          , t = t || ("end" == e ? lay.extend({}, a.endDate, a.endTime) : n.range ? lay.extend({}, n.dateTime, a.startTime) : n.dateTime)
          , t = u.parse(t, a.format, 1);
        return n.range && e === undefined ? t + " " + a.rangeStr + " " + a.parse("end") : t
    }
    ,
    g.prototype.newDate = function(e) {
        return e = e || {},
        new Date(e.year || 1,e.month || 0,e.date || 1,e.hours || 0,e.minutes || 0,e.seconds || 0)
    }
    ,
    g.prototype.getDateTime = function(e) {
        return this.newDate(e).getTime()
    }
    ,
    g.prototype.setValue = function(e) {
        var t = this
          , a = t.config
          , n = t.bindElem || a.elem[0];
        return "static" === a.position || (e = e || "",
        t.isInput(n) ? lay(n).val(e) : (a = t.rangeElem) ? ("array" !== layui.type(e) && (e = e.split(" " + t.rangeStr + " ")),
        a[0].val(e[0] || ""),
        a[1].val(e[1] || "")) : (0 === lay(n).find("*").length && lay(n).html(e),
        lay(n).attr("lay-date", e))),
        t
    }
    ,
    g.prototype.preview = function() {
        var e, t = this, a = t.config;
        a.isPreview && (e = lay(t.elem).find("." + f),
        a = !a.range || t.endDate ? t.parse() : "",
        e.html(a).css({
            color: "#5FB878"
        }),
        setTimeout(function() {
            e.css({
                color: "#666"
            })
        }, 300))
    }
    ,
    g.prototype.done = function(e, t) {
        var a = this
          , n = a.config
          , i = lay.extend({}, lay.extend(n.dateTime, a.startTime))
          , l = lay.extend({}, lay.extend(a.endDate, a.endTime));
        return lay.each([i, l], function(e, t) {
            "month"in t && lay.extend(t, {
                month: t.month + 1
            })
        }),
        a.preview(),
        e = e || [a.parse(), i, l],
        "function" == typeof n[t || "done"] && n[t || "done"].apply(n, e),
        a
    }
    ,
    g.prototype.choose = function(e, a) {
        var n = this
          , i = n.config
          , l = n.thisDateTime(a)
          , t = (lay(n.elem).find("td"),
        {
            year: 0 | (t = e.attr("lay-ymd").split("-"))[0],
            month: (0 | t[1]) - 1,
            date: 0 | t[2]
        });
        e.hasClass(x) || (lay.extend(l, t),
        i.range ? (lay.each(["startTime", "endTime"], function(e, t) {
            n[t] = n[t] || {
                hours: e ? 23 : 0,
                minutes: e ? 59 : 0,
                seconds: e ? 59 : 0
            },
            a === e && (n.getDateTime(lay.extend({}, l, n[t])) < n.getDateTime(i.min) ? (n[t] = {
                hours: i.min.hours,
                minutes: i.min.minutes,
                seconds: i.min.seconds
            },
            lay.extend(l, n[t])) : n.getDateTime(lay.extend({}, l, n[t])) > n.getDateTime(i.max) && (n[t] = {
                hours: i.max.hours,
                minutes: i.max.minutes,
                seconds: i.max.seconds
            },
            lay.extend(l, n[t])))
        }),
        n.calendar(null, a).done(null, "change")) : "static" === i.position ? n.calendar().done().done(null, "change") : "date" === i.type ? n.setValue(n.parse()).remove().done() : "datetime" === i.type && n.calendar().done(null, "change"))
    }
    ,
    g.prototype.tool = function(e, t) {
        var a = this
          , n = a.config
          , i = a.lang()
          , l = n.dateTime
          , r = "static" === n.position
          , o = {
            datetime: function() {
                lay(e).hasClass(x) || (a.list("time", 0),
                n.range && a.list("time", 1),
                lay(e).attr("lay-type", "date").html(a.lang().dateTips))
            },
            date: function() {
                a.closeList(),
                lay(e).attr("lay-type", "datetime").html(a.lang().timeTips)
            },
            clear: function() {
                r && (lay.extend(l, a.firstDate),
                a.calendar()),
                n.range && (delete n.dateTime,
                delete a.endDate,
                delete a.startTime,
                delete a.endTime),
                a.setValue("").remove(),
                a.done(["", {}, {}])
            },
            now: function() {
                var e = new Date;
                lay.extend(l, a.systemDate(), {
                    hours: e.getHours(),
                    minutes: e.getMinutes(),
                    seconds: e.getSeconds()
                }),
                a.setValue(a.parse()).remove(),
                r && a.calendar(),
                a.done()
            },
            confirm: function() {
                if (n.range) {
                    if (lay(e).hasClass(x))
                        return a.hint("time" === n.type ? i.timeout.replace(/\u65e5\u671f/g, "\u65f6\u95f4") : i.timeout)
                } else if (lay(e).hasClass(x))
                    return a.hint(i.invalidDate);
                a.setValue(a.parse()).remove(),
                a.done()
            }
        };
        o[t] && o[t]()
    }
    ,
    g.prototype.change = function(n) {
        var i = this
          , l = i.config
          , r = i.thisDateTime(n)
          , o = l.range && ("year" === l.type || "month" === l.type)
          , s = i.elemCont[n || 0]
          , y = i.listYM[n]
          , e = function(e) {
            var t = lay(s).find(".laydate-year-list")[0]
              , a = lay(s).find(".laydate-month-list")[0];
            return t && (y[0] = e ? y[0] - 15 : y[0] + 15,
            i.list("year", n)),
            a && (e ? y[0]-- : y[0]++,
            i.list("month", n)),
            (t || a) && (lay.extend(r, {
                year: y[0]
            }),
            o && (r.year = y[0]),
            l.range || i.done(null, "change"),
            l.range || i.limit(lay(i.footer).find(E), {
                year: y[0]
            })),
            i.setBtnStatus(),
            t || a
        };
        return {
            prevYear: function() {
                e("sub") || (r.year--,
                i.checkDate("limit").calendar(null, n),
                i.done(null, "change"))
            },
            prevMonth: function() {
                var e = i.getAsYM(r.year, r.month, "sub");
                lay.extend(r, {
                    year: e[0],
                    month: e[1]
                }),
                i.checkDate("limit").calendar(null, n),
                i.done(null, "change")
            },
            nextMonth: function() {
                var e = i.getAsYM(r.year, r.month);
                lay.extend(r, {
                    year: e[0],
                    month: e[1]
                }),
                i.checkDate("limit").calendar(null, n),
                i.done(null, "change")
            },
            nextYear: function() {
                e() || (r.year++,
                i.checkDate("limit").calendar(null, n),
                i.done(null, "change"))
            }
        }
    }
    ,
    g.prototype.changeEvent = function() {
        var i = this;
        i.config;
        lay(i.elem).on("click", function(e) {
            lay.stope(e)
        }).on("mousedown", function(e) {
            lay.stope(e)
        }),
        lay.each(i.elemHeader, function(n, e) {
            lay(e[0]).on("click", function(e) {
                i.change(n).prevYear()
            }),
            lay(e[1]).on("click", function(e) {
                i.change(n).prevMonth()
            }),
            lay(e[2]).find("span").on("click", function(e) {
                var t = lay(this)
                  , a = t.attr("lay-ym")
                  , t = t.attr("lay-type");
                a && (a = a.split("-"),
                i.listYM[n] = [0 | a[0], 0 | a[1]],
                i.list(t, n),
                lay(i.footer).find("." + k).addClass(x))
            }),
            lay(e[3]).on("click", function(e) {
                i.change(n).nextMonth()
            }),
            lay(e[4]).on("click", function(e) {
                i.change(n).nextYear()
            })
        }),
        lay.each(i.table, function(e, t) {
            lay(t).find("td").on("click", function() {
                i.choose(lay(this), e)
            })
        }),
        lay(i.footer).find("span").on("click", function() {
            var e = lay(this).attr("lay-type");
            i.tool(this, e)
        })
    }
    ,
    g.prototype.isInput = function(e) {
        return /input|textarea/.test(e.tagName.toLocaleLowerCase()) || /INPUT|TEXTAREA/.test(e.tagName)
    }
    ,
    g.prototype.events = function() {
        var a = this
          , n = a.config
          , e = function(e, t) {
            e.on(n.trigger, function() {
                u.thisId !== n.id && (t && (a.bindElem = this),
                a.render())
            })
        };
        n.elem[0] && !n.elem[0].eventHandler && (e(n.elem, "bind"),
        e(n.eventElem),
        n.elem[0].eventHandler = !0)
    }
    ,
    s.that = {},
    s.getThis = function(e) {
        var t = s.that[e];
        return !t && n && layui.hint().error(e ? a + " instance with ID '" + e + "' not found" : "ID argument required"),
        t
    }
    ,
    l.run = function(n) {
        n(r).on("mousedown", function(e) {
            var t, a;
            !u.thisId || (t = s.getThis(u.thisId)) && (a = t.config,
            e.target !== a.elem[0] && e.target !== a.eventElem[0] && e.target !== n(a.closeStop)[0] && t.remove())
        }).on("keydown", function(e) {
            var t;
            !u.thisId || (t = s.getThis(u.thisId)) && "static" !== t.config.position && 13 === e.keyCode && n("#" + t.elemID)[0] && t.elemID === g.thisElemDate && (e.preventDefault(),
            n(t.footer).find(E)[0].click())
        }),
        n(i).on("resize", function() {
            if (u.thisId) {
                var e = s.getThis(u.thisId);
                if (e)
                    return !(!e.elem || !n(".layui-laydate")[0]) && void e.position()
            }
        })
    }
    ,
    u.render = function(e) {
        e = new g(e);
        return s.call(e)
    }
    ,
    u.parse = function(a, n, i) {
        return a = a || {},
        n = ((n = "string" == typeof n ? s.formatArr(n) : n) || []).concat(),
        lay.each(n, function(e, t) {
            /yyyy|y/.test(t) ? n[e] = lay.digit(a.year, t.length) : /MM|M/.test(t) ? n[e] = lay.digit(a.month + (i || 0), t.length) : /dd|d/.test(t) ? n[e] = lay.digit(a.date, t.length) : /HH|H/.test(t) ? n[e] = lay.digit(a.hours, t.length) : /mm|m/.test(t) ? n[e] = lay.digit(a.minutes, t.length) : /ss|s/.test(t) && (n[e] = lay.digit(a.seconds, t.length))
        }),
        n.join("")
    }
    ,
    u.getEndDate = function(e, t) {
        var a = new Date;
        return a.setFullYear(t || a.getFullYear(), e || a.getMonth() + 1, 1),
        new Date(a.getTime() - 864e5).getDate()
    }
    ,
    u.close = function(e) {
        e = s.getThis(e || u.thisId);
        if (e)
            return e.remove()
    }
    ,
    n ? (u.ready(),
    layui.define("lay", function(e) {
        u.path = layui.cache.dir,
        l.run(lay),
        e(a, u)
    })) : "function" == typeof define && define.amd ? define(function() {
        return l.run(lay),
        u
    }) : (u.ready(),
    l.run(i.lay),
    i.laydate = u)
}(window, window.document);
!function(e, t) {
    "object" == typeof module && "object" == typeof module.exports ? module.exports = e.document ? t(e) : function(e) {
        if (e.document)
            return t(e);
        throw new Error("jQuery requires a window with a document")
    }
    : t(e)
}("undefined" != typeof window ? window : this, function(T, M) {
    var f = []
      , g = T.document
      , c = f.slice
      , O = f.concat
      , R = f.push
      , P = f.indexOf
      , B = {}
      , W = B.toString
      , m = B.hasOwnProperty
      , y = {}
      , e = "1.12.4"
      , C = function(e, t) {
        return new C.fn.init(e,t)
    }
      , I = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g
      , $ = /^-ms-/
      , z = /-([\da-z])/gi
      , X = function(e, t) {
        return t.toUpperCase()
    };
    function U(e) {
        var t = !!e && "length"in e && e.length
          , n = C.type(e);
        return "function" !== n && !C.isWindow(e) && ("array" === n || 0 === t || "number" == typeof t && 0 < t && t - 1 in e)
    }
    C.fn = C.prototype = {
        jquery: e,
        constructor: C,
        selector: "",
        length: 0,
        toArray: function() {
            return c.call(this)
        },
        get: function(e) {
            return null != e ? e < 0 ? this[e + this.length] : this[e] : c.call(this)
        },
        pushStack: function(e) {
            e = C.merge(this.constructor(), e);
            return e.prevObject = this,
            e.context = this.context,
            e
        },
        each: function(e) {
            return C.each(this, e)
        },
        map: function(n) {
            return this.pushStack(C.map(this, function(e, t) {
                return n.call(e, t, e)
            }))
        },
        slice: function() {
            return this.pushStack(c.apply(this, arguments))
        },
        first: function() {
            return this.eq(0)
        },
        last: function() {
            return this.eq(-1)
        },
        eq: function(e) {
            var t = this.length
              , e = +e + (e < 0 ? t : 0);
            return this.pushStack(0 <= e && e < t ? [this[e]] : [])
        },
        end: function() {
            return this.prevObject || this.constructor()
        },
        push: R,
        sort: f.sort,
        splice: f.splice
    },
    C.extend = C.fn.extend = function() {
        var e, t, n, r, i, o = arguments[0] || {}, a = 1, s = arguments.length, u = !1;
        for ("boolean" == typeof o && (u = o,
        o = arguments[a] || {},
        a++),
        "object" == typeof o || C.isFunction(o) || (o = {}),
        a === s && (o = this,
        a--); a < s; a++)
            if (null != (r = arguments[a]))
                for (n in r)
                    i = o[n],
                    o !== (t = r[n]) && (u && t && (C.isPlainObject(t) || (e = C.isArray(t))) ? (i = e ? (e = !1,
                    i && C.isArray(i) ? i : []) : i && C.isPlainObject(i) ? i : {},
                    o[n] = C.extend(u, i, t)) : t !== undefined && (o[n] = t));
        return o
    }
    ,
    C.extend({
        expando: "jQuery" + (e + Math.random()).replace(/\D/g, ""),
        isReady: !0,
        error: function(e) {
            throw new Error(e)
        },
        noop: function() {},
        isFunction: function(e) {
            return "function" === C.type(e)
        },
        isArray: Array.isArray || function(e) {
            return "array" === C.type(e)
        }
        ,
        isWindow: function(e) {
            return null != e && e == e.window
        },
        isNumeric: function(e) {
            var t = e && e.toString();
            return !C.isArray(e) && 0 <= t - parseFloat(t) + 1
        },
        isEmptyObject: function(e) {
            for (var t in e)
                return !1;
            return !0
        },
        isPlainObject: function(e) {
            if (!e || "object" !== C.type(e) || e.nodeType || C.isWindow(e))
                return !1;
            try {
                if (e.constructor && !m.call(e, "constructor") && !m.call(e.constructor.prototype, "isPrototypeOf"))
                    return !1
            } catch (n) {
                return !1
            }
            if (!y.ownFirst)
                for (var t in e)
                    return m.call(e, t);
            for (t in e)
                ;
            return t === undefined || m.call(e, t)
        },
        type: function(e) {
            return null == e ? e + "" : "object" == typeof e || "function" == typeof e ? B[W.call(e)] || "object" : typeof e
        },
        globalEval: function(e) {
            e && C.trim(e) && (T.execScript || function(e) {
                T.eval.call(T, e)
            }
            )(e)
        },
        camelCase: function(e) {
            return e.replace($, "ms-").replace(z, X)
        },
        nodeName: function(e, t) {
            return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase()
        },
        each: function(e, t) {
            var n, r = 0;
            if (U(e))
                for (n = e.length; r < n && !1 !== t.call(e[r], r, e[r]); r++)
                    ;
            else
                for (r in e)
                    if (!1 === t.call(e[r], r, e[r]))
                        break;
            return e
        },
        trim: function(e) {
            return null == e ? "" : (e + "").replace(I, "")
        },
        makeArray: function(e, t) {
            t = t || [];
            return null != e && (U(Object(e)) ? C.merge(t, "string" == typeof e ? [e] : e) : R.call(t, e)),
            t
        },
        inArray: function(e, t, n) {
            var r;
            if (t) {
                if (P)
                    return P.call(t, e, n);
                for (r = t.length,
                n = n ? n < 0 ? Math.max(0, r + n) : n : 0; n < r; n++)
                    if (n in t && t[n] === e)
                        return n
            }
            return -1
        },
        merge: function(e, t) {
            for (var n = +t.length, r = 0, i = e.length; r < n; )
                e[i++] = t[r++];
            if (n != n)
                for (; t[r] !== undefined; )
                    e[i++] = t[r++];
            return e.length = i,
            e
        },
        grep: function(e, t, n) {
            for (var r = [], i = 0, o = e.length, a = !n; i < o; i++)
                !t(e[i], i) != a && r.push(e[i]);
            return r
        },
        map: function(e, t, n) {
            var r, i, o = 0, a = [];
            if (U(e))
                for (r = e.length; o < r; o++)
                    null != (i = t(e[o], o, n)) && a.push(i);
            else
                for (o in e)
                    null != (i = t(e[o], o, n)) && a.push(i);
            return O.apply([], a)
        },
        guid: 1,
        proxy: function(e, t) {
            var n, r;
            return "string" == typeof t && (r = e[t],
            t = e,
            e = r),
            C.isFunction(e) ? (n = c.call(arguments, 2),
            (r = function() {
                return e.apply(t || this, n.concat(c.call(arguments)))
            }
            ).guid = e.guid = e.guid || C.guid++,
            r) : undefined
        },
        now: function() {
            return +new Date
        },
        support: y
    }),
    "function" == typeof Symbol && (C.fn[Symbol.iterator] = f[Symbol.iterator]),
    C.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function(e, t) {
        B["[object " + t + "]"] = t.toLowerCase()
    });
    var e = function(M) {
        var e, g, b, o, O, w, R, P, T, u, l, C, E, t, N, m, r, i, y, k = "sizzle" + +new Date, v = M.document, S = 0, B = 0, W = le(), I = le(), A = le(), $ = function(e, t) {
            return e === t && (l = !0),
            0
        }, z = {}.hasOwnProperty, n = [], X = n.pop, U = n.push, D = n.push, V = n.slice, j = function(e, t) {
            for (var n = 0, r = e.length; n < r; n++)
                if (e[n] === t)
                    return n;
            return -1
        }, Y = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped", a = "[\\x20\\t\\r\\n\\f]", s = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+", J = "\\[" + a + "*(" + s + ")(?:" + a + "*([*^$|!~]?=)" + a + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + s + "))|)" + a + "*\\]", G = ":(" + s + ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" + J + ")*)|.*)\\)|)", K = new RegExp(a + "+","g"), L = new RegExp("^" + a + "+|((?:^|[^\\\\])(?:\\\\.)*)" + a + "+$","g"), Q = new RegExp("^" + a + "*," + a + "*"), Z = new RegExp("^" + a + "*([>+~]|" + a + ")" + a + "*"), ee = new RegExp("=" + a + "*([^\\]'\"]*?)" + a + "*\\]","g"), te = new RegExp(G), ne = new RegExp("^" + s + "$"), f = {
            ID: new RegExp("^#(" + s + ")"),
            CLASS: new RegExp("^\\.(" + s + ")"),
            TAG: new RegExp("^(" + s + "|[*])"),
            ATTR: new RegExp("^" + J),
            PSEUDO: new RegExp("^" + G),
            CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + a + "*(even|odd|(([+-]|)(\\d*)n|)" + a + "*(?:([+-]|)" + a + "*(\\d+)|))" + a + "*\\)|)","i"),
            bool: new RegExp("^(?:" + Y + ")$","i"),
            needsContext: new RegExp("^" + a + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + a + "*((?:-\\d)?\\d*)" + a + "*\\)|)(?=[^-]|$)","i")
        }, re = /^(?:input|select|textarea|button)$/i, ie = /^h\d$/i, c = /^[^{]+\{\s*\[native \w/, oe = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, ae = /[+~]/, se = /'|\\/g, d = new RegExp("\\\\([\\da-f]{1,6}" + a + "?|(" + a + ")|.)","ig"), p = function(e, t, n) {
            var r = "0x" + t - 65536;
            return r != r || n ? t : r < 0 ? String.fromCharCode(65536 + r) : String.fromCharCode(r >> 10 | 55296, 1023 & r | 56320)
        }, ue = function() {
            C()
        };
        try {
            D.apply(n = V.call(v.childNodes), v.childNodes),
            n[v.childNodes.length].nodeType
        } catch (F) {
            D = {
                apply: n.length ? function(e, t) {
                    U.apply(e, V.call(t))
                }
                : function(e, t) {
                    for (var n = e.length, r = 0; e[n++] = t[r++]; )
                        ;
                    e.length = n - 1
                }
            }
        }
        function H(e, t, n, r) {
            var i, o, a, s, u, l, c, f, d = t && t.ownerDocument, p = t ? t.nodeType : 9;
            if (n = n || [],
            "string" != typeof e || !e || 1 !== p && 9 !== p && 11 !== p)
                return n;
            if (!r && ((t ? t.ownerDocument || t : v) !== E && C(t),
            t = t || E,
            N)) {
                if (11 !== p && (l = oe.exec(e)))
                    if (i = l[1]) {
                        if (9 === p) {
                            if (!(a = t.getElementById(i)))
                                return n;
                            if (a.id === i)
                                return n.push(a),
                                n
                        } else if (d && (a = d.getElementById(i)) && y(t, a) && a.id === i)
                            return n.push(a),
                            n
                    } else {
                        if (l[2])
                            return D.apply(n, t.getElementsByTagName(e)),
                            n;
                        if ((i = l[3]) && g.getElementsByClassName && t.getElementsByClassName)
                            return D.apply(n, t.getElementsByClassName(i)),
                            n
                    }
                if (g.qsa && !A[e + " "] && (!m || !m.test(e))) {
                    if (1 !== p)
                        d = t,
                        f = e;
                    else if ("object" !== t.nodeName.toLowerCase()) {
                        for ((s = t.getAttribute("id")) ? s = s.replace(se, "\\$&") : t.setAttribute("id", s = k),
                        o = (c = w(e)).length,
                        u = ne.test(s) ? "#" + s : "[id='" + s + "']"; o--; )
                            c[o] = u + " " + _(c[o]);
                        f = c.join(","),
                        d = ae.test(e) && de(t.parentNode) || t
                    }
                    if (f)
                        try {
                            return D.apply(n, d.querySelectorAll(f)),
                            n
                        } catch (h) {} finally {
                            s === k && t.removeAttribute("id")
                        }
                }
            }
            return P(e.replace(L, "$1"), t, n, r)
        }
        function le() {
            var n = [];
            function r(e, t) {
                return n.push(e + " ") > b.cacheLength && delete r[n.shift()],
                r[e + " "] = t
            }
            return r
        }
        function q(e) {
            return e[k] = !0,
            e
        }
        function h(e) {
            var t = E.createElement("div");
            try {
                return !!e(t)
            } catch (F) {
                return !1
            } finally {
                t.parentNode && t.parentNode.removeChild(t)
            }
        }
        function ce(e, t) {
            for (var n = e.split("|"), r = n.length; r--; )
                b.attrHandle[n[r]] = t
        }
        function fe(e, t) {
            var n = t && e
              , r = n && 1 === e.nodeType && 1 === t.nodeType && (~t.sourceIndex || 1 << 31) - (~e.sourceIndex || 1 << 31);
            if (r)
                return r;
            if (n)
                for (; n = n.nextSibling; )
                    if (n === t)
                        return -1;
            return e ? 1 : -1
        }
        function x(a) {
            return q(function(o) {
                return o = +o,
                q(function(e, t) {
                    for (var n, r = a([], e.length, o), i = r.length; i--; )
                        e[n = r[i]] && (e[n] = !(t[n] = e[n]))
                })
            })
        }
        function de(e) {
            return e && "undefined" != typeof e.getElementsByTagName && e
        }
        for (e in g = H.support = {},
        O = H.isXML = function(e) {
            e = e && (e.ownerDocument || e).documentElement;
            return !!e && "HTML" !== e.nodeName
        }
        ,
        C = H.setDocument = function(e) {
            var e = e ? e.ownerDocument || e : v;
            return e !== E && 9 === e.nodeType && e.documentElement && (t = (E = e).documentElement,
            N = !O(E),
            (e = E.defaultView) && e.top !== e && (e.addEventListener ? e.addEventListener("unload", ue, !1) : e.attachEvent && e.attachEvent("onunload", ue)),
            g.attributes = h(function(e) {
                return e.className = "i",
                !e.getAttribute("className")
            }),
            g.getElementsByTagName = h(function(e) {
                return e.appendChild(E.createComment("")),
                !e.getElementsByTagName("*").length
            }),
            g.getElementsByClassName = c.test(E.getElementsByClassName),
            g.getById = h(function(e) {
                return t.appendChild(e).id = k,
                !E.getElementsByName || !E.getElementsByName(k).length
            }),
            g.getById ? (b.find.ID = function(e, t) {
                if ("undefined" != typeof t.getElementById && N)
                    return (e = t.getElementById(e)) ? [e] : []
            }
            ,
            b.filter.ID = function(e) {
                var t = e.replace(d, p);
                return function(e) {
                    return e.getAttribute("id") === t
                }
            }
            ) : (delete b.find.ID,
            b.filter.ID = function(e) {
                var t = e.replace(d, p);
                return function(e) {
                    e = "undefined" != typeof e.getAttributeNode && e.getAttributeNode("id");
                    return e && e.value === t
                }
            }
            ),
            b.find.TAG = g.getElementsByTagName ? function(e, t) {
                return "undefined" != typeof t.getElementsByTagName ? t.getElementsByTagName(e) : g.qsa ? t.querySelectorAll(e) : void 0
            }
            : function(e, t) {
                var n, r = [], i = 0, o = t.getElementsByTagName(e);
                if ("*" !== e)
                    return o;
                for (; n = o[i++]; )
                    1 === n.nodeType && r.push(n);
                return r
            }
            ,
            b.find.CLASS = g.getElementsByClassName && function(e, t) {
                if ("undefined" != typeof t.getElementsByClassName && N)
                    return t.getElementsByClassName(e)
            }
            ,
            r = [],
            m = [],
            (g.qsa = c.test(E.querySelectorAll)) && (h(function(e) {
                t.appendChild(e).innerHTML = "<a id='" + k + "'></a><select id='" + k + "-\r\\' msallowcapture=''><option selected=''></option></select>",
                e.querySelectorAll("[msallowcapture^='']").length && m.push("[*^$]=" + a + "*(?:''|\"\")"),
                e.querySelectorAll("[selected]").length || m.push("\\[" + a + "*(?:value|" + Y + ")"),
                e.querySelectorAll("[id~=" + k + "-]").length || m.push("~="),
                e.querySelectorAll(":checked").length || m.push(":checked"),
                e.querySelectorAll("a#" + k + "+*").length || m.push(".#.+[+~]")
            }),
            h(function(e) {
                var t = E.createElement("input");
                t.setAttribute("type", "hidden"),
                e.appendChild(t).setAttribute("name", "D"),
                e.querySelectorAll("[name=d]").length && m.push("name" + a + "*[*^$|!~]?="),
                e.querySelectorAll(":enabled").length || m.push(":enabled", ":disabled"),
                e.querySelectorAll("*,:x"),
                m.push(",.*:")
            })),
            (g.matchesSelector = c.test(i = t.matches || t.webkitMatchesSelector || t.mozMatchesSelector || t.oMatchesSelector || t.msMatchesSelector)) && h(function(e) {
                g.disconnectedMatch = i.call(e, "div"),
                i.call(e, "[s!='']:x"),
                r.push("!=", G)
            }),
            m = m.length && new RegExp(m.join("|")),
            r = r.length && new RegExp(r.join("|")),
            e = c.test(t.compareDocumentPosition),
            y = e || c.test(t.contains) ? function(e, t) {
                var n = 9 === e.nodeType ? e.documentElement : e
                  , t = t && t.parentNode;
                return e === t || !(!t || 1 !== t.nodeType || !(n.contains ? n.contains(t) : e.compareDocumentPosition && 16 & e.compareDocumentPosition(t)))
            }
            : function(e, t) {
                if (t)
                    for (; t = t.parentNode; )
                        if (t === e)
                            return !0;
                return !1
            }
            ,
            $ = e ? function(e, t) {
                if (e === t)
                    return l = !0,
                    0;
                var n = !e.compareDocumentPosition - !t.compareDocumentPosition;
                return n || (1 & (n = (e.ownerDocument || e) === (t.ownerDocument || t) ? e.compareDocumentPosition(t) : 1) || !g.sortDetached && t.compareDocumentPosition(e) === n ? e === E || e.ownerDocument === v && y(v, e) ? -1 : t === E || t.ownerDocument === v && y(v, t) ? 1 : u ? j(u, e) - j(u, t) : 0 : 4 & n ? -1 : 1)
            }
            : function(e, t) {
                if (e === t)
                    return l = !0,
                    0;
                var n, r = 0, i = e.parentNode, o = t.parentNode, a = [e], s = [t];
                if (!i || !o)
                    return e === E ? -1 : t === E ? 1 : i ? -1 : o ? 1 : u ? j(u, e) - j(u, t) : 0;
                if (i === o)
                    return fe(e, t);
                for (n = e; n = n.parentNode; )
                    a.unshift(n);
                for (n = t; n = n.parentNode; )
                    s.unshift(n);
                for (; a[r] === s[r]; )
                    r++;
                return r ? fe(a[r], s[r]) : a[r] === v ? -1 : s[r] === v ? 1 : 0
            }
            ),
            E
        }
        ,
        H.matches = function(e, t) {
            return H(e, null, null, t)
        }
        ,
        H.matchesSelector = function(e, t) {
            if ((e.ownerDocument || e) !== E && C(e),
            t = t.replace(ee, "='$1']"),
            g.matchesSelector && N && !A[t + " "] && (!r || !r.test(t)) && (!m || !m.test(t)))
                try {
                    var n = i.call(e, t);
                    if (n || g.disconnectedMatch || e.document && 11 !== e.document.nodeType)
                        return n
                } catch (F) {}
            return 0 < H(t, E, null, [e]).length
        }
        ,
        H.contains = function(e, t) {
            return (e.ownerDocument || e) !== E && C(e),
            y(e, t)
        }
        ,
        H.attr = function(e, t) {
            (e.ownerDocument || e) !== E && C(e);
            var n = b.attrHandle[t.toLowerCase()]
              , n = n && z.call(b.attrHandle, t.toLowerCase()) ? n(e, t, !N) : undefined;
            return n !== undefined ? n : g.attributes || !N ? e.getAttribute(t) : (n = e.getAttributeNode(t)) && n.specified ? n.value : null
        }
        ,
        H.error = function(e) {
            throw new Error("Syntax error, unrecognized expression: " + e)
        }
        ,
        H.uniqueSort = function(e) {
            var t, n = [], r = 0, i = 0;
            if (l = !g.detectDuplicates,
            u = !g.sortStable && e.slice(0),
            e.sort($),
            l) {
                for (; t = e[i++]; )
                    t === e[i] && (r = n.push(i));
                for (; r--; )
                    e.splice(n[r], 1)
            }
            return u = null,
            e
        }
        ,
        o = H.getText = function(e) {
            var t, n = "", r = 0, i = e.nodeType;
            if (i) {
                if (1 === i || 9 === i || 11 === i) {
                    if ("string" == typeof e.textContent)
                        return e.textContent;
                    for (e = e.firstChild; e; e = e.nextSibling)
                        n += o(e)
                } else if (3 === i || 4 === i)
                    return e.nodeValue
            } else
                for (; t = e[r++]; )
                    n += o(t);
            return n
        }
        ,
        (b = H.selectors = {
            cacheLength: 50,
            createPseudo: q,
            match: f,
            attrHandle: {},
            find: {},
            relative: {
                ">": {
                    dir: "parentNode",
                    first: !0
                },
                " ": {
                    dir: "parentNode"
                },
                "+": {
                    dir: "previousSibling",
                    first: !0
                },
                "~": {
                    dir: "previousSibling"
                }
            },
            preFilter: {
                ATTR: function(e) {
                    return e[1] = e[1].replace(d, p),
                    e[3] = (e[3] || e[4] || e[5] || "").replace(d, p),
                    "~=" === e[2] && (e[3] = " " + e[3] + " "),
                    e.slice(0, 4)
                },
                CHILD: function(e) {
                    return e[1] = e[1].toLowerCase(),
                    "nth" === e[1].slice(0, 3) ? (e[3] || H.error(e[0]),
                    e[4] = +(e[4] ? e[5] + (e[6] || 1) : 2 * ("even" === e[3] || "odd" === e[3])),
                    e[5] = +(e[7] + e[8] || "odd" === e[3])) : e[3] && H.error(e[0]),
                    e
                },
                PSEUDO: function(e) {
                    var t, n = !e[6] && e[2];
                    return f.CHILD.test(e[0]) ? null : (e[3] ? e[2] = e[4] || e[5] || "" : n && te.test(n) && (t = w(n, !0)) && (t = n.indexOf(")", n.length - t) - n.length) && (e[0] = e[0].slice(0, t),
                    e[2] = n.slice(0, t)),
                    e.slice(0, 3))
                }
            },
            filter: {
                TAG: function(e) {
                    var t = e.replace(d, p).toLowerCase();
                    return "*" === e ? function() {
                        return !0
                    }
                    : function(e) {
                        return e.nodeName && e.nodeName.toLowerCase() === t
                    }
                },
                CLASS: function(e) {
                    var t = W[e + " "];
                    return t || (t = new RegExp("(^|" + a + ")" + e + "(" + a + "|$)")) && W(e, function(e) {
                        return t.test("string" == typeof e.className && e.className || "undefined" != typeof e.getAttribute && e.getAttribute("class") || "")
                    })
                },
                ATTR: function(t, n, r) {
                    return function(e) {
                        e = H.attr(e, t);
                        return null == e ? "!=" === n : !n || (e += "",
                        "=" === n ? e === r : "!=" === n ? e !== r : "^=" === n ? r && 0 === e.indexOf(r) : "*=" === n ? r && -1 < e.indexOf(r) : "$=" === n ? r && e.slice(-r.length) === r : "~=" === n ? -1 < (" " + e.replace(K, " ") + " ").indexOf(r) : "|=" === n && (e === r || e.slice(0, r.length + 1) === r + "-"))
                    }
                },
                CHILD: function(h, e, t, g, m) {
                    var y = "nth" !== h.slice(0, 3)
                      , v = "last" !== h.slice(-4)
                      , x = "of-type" === e;
                    return 1 === g && 0 === m ? function(e) {
                        return !!e.parentNode
                    }
                    : function(e, t, n) {
                        var r, i, o, a, s, u, l = y != v ? "nextSibling" : "previousSibling", c = e.parentNode, f = x && e.nodeName.toLowerCase(), d = !n && !x, p = !1;
                        if (c) {
                            if (y) {
                                for (; l; ) {
                                    for (a = e; a = a[l]; )
                                        if (x ? a.nodeName.toLowerCase() === f : 1 === a.nodeType)
                                            return !1;
                                    u = l = "only" === h && !u && "nextSibling"
                                }
                                return !0
                            }
                            if (u = [v ? c.firstChild : c.lastChild],
                            v && d) {
                                for (p = (s = (r = (i = (o = (a = c)[k] || (a[k] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] || [])[0] === S && r[1]) && r[2],
                                a = s && c.childNodes[s]; a = ++s && a && a[l] || (p = s = 0) || u.pop(); )
                                    if (1 === a.nodeType && ++p && a === e) {
                                        i[h] = [S, s, p];
                                        break
                                    }
                            } else if (!1 === (p = d ? s = (r = (i = (o = (a = e)[k] || (a[k] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] || [])[0] === S && r[1] : p))
                                for (; (a = ++s && a && a[l] || (p = s = 0) || u.pop()) && ((x ? a.nodeName.toLowerCase() !== f : 1 !== a.nodeType) || !++p || (d && ((i = (o = a[k] || (a[k] = {}))[a.uniqueID] || (o[a.uniqueID] = {}))[h] = [S, p]),
                                a !== e)); )
                                    ;
                            return (p -= m) === g || p % g == 0 && 0 <= p / g
                        }
                    }
                },
                PSEUDO: function(e, o) {
                    var t, a = b.pseudos[e] || b.setFilters[e.toLowerCase()] || H.error("unsupported pseudo: " + e);
                    return a[k] ? a(o) : 1 < a.length ? (t = [e, e, "", o],
                    b.setFilters.hasOwnProperty(e.toLowerCase()) ? q(function(e, t) {
                        for (var n, r = a(e, o), i = r.length; i--; )
                            e[n = j(e, r[i])] = !(t[n] = r[i])
                    }) : function(e) {
                        return a(e, 0, t)
                    }
                    ) : a
                }
            },
            pseudos: {
                not: q(function(e) {
                    var r = []
                      , i = []
                      , s = R(e.replace(L, "$1"));
                    return s[k] ? q(function(e, t, n, r) {
                        for (var i, o = s(e, null, r, []), a = e.length; a--; )
                            (i = o[a]) && (e[a] = !(t[a] = i))
                    }) : function(e, t, n) {
                        return r[0] = e,
                        s(r, null, n, i),
                        r[0] = null,
                        !i.pop()
                    }
                }),
                has: q(function(t) {
                    return function(e) {
                        return 0 < H(t, e).length
                    }
                }),
                contains: q(function(t) {
                    return t = t.replace(d, p),
                    function(e) {
                        return -1 < (e.textContent || e.innerText || o(e)).indexOf(t)
                    }
                }),
                lang: q(function(n) {
                    return ne.test(n || "") || H.error("unsupported lang: " + n),
                    n = n.replace(d, p).toLowerCase(),
                    function(e) {
                        var t;
                        do {
                            if (t = N ? e.lang : e.getAttribute("xml:lang") || e.getAttribute("lang"))
                                return (t = t.toLowerCase()) === n || 0 === t.indexOf(n + "-")
                        } while ((e = e.parentNode) && 1 === e.nodeType);
                        return !1
                    }
                }),
                target: function(e) {
                    var t = M.location && M.location.hash;
                    return t && t.slice(1) === e.id
                },
                root: function(e) {
                    return e === t
                },
                focus: function(e) {
                    return e === E.activeElement && (!E.hasFocus || E.hasFocus()) && !!(e.type || e.href || ~e.tabIndex)
                },
                enabled: function(e) {
                    return !1 === e.disabled
                },
                disabled: function(e) {
                    return !0 === e.disabled
                },
                checked: function(e) {
                    var t = e.nodeName.toLowerCase();
                    return "input" === t && !!e.checked || "option" === t && !!e.selected
                },
                selected: function(e) {
                    return e.parentNode && e.parentNode.selectedIndex,
                    !0 === e.selected
                },
                empty: function(e) {
                    for (e = e.firstChild; e; e = e.nextSibling)
                        if (e.nodeType < 6)
                            return !1;
                    return !0
                },
                parent: function(e) {
                    return !b.pseudos.empty(e)
                },
                header: function(e) {
                    return ie.test(e.nodeName)
                },
                input: function(e) {
                    return re.test(e.nodeName)
                },
                button: function(e) {
                    var t = e.nodeName.toLowerCase();
                    return "input" === t && "button" === e.type || "button" === t
                },
                text: function(e) {
                    return "input" === e.nodeName.toLowerCase() && "text" === e.type && (null == (e = e.getAttribute("type")) || "text" === e.toLowerCase())
                },
                first: x(function() {
                    return [0]
                }),
                last: x(function(e, t) {
                    return [t - 1]
                }),
                eq: x(function(e, t, n) {
                    return [n < 0 ? n + t : n]
                }),
                even: x(function(e, t) {
                    for (var n = 0; n < t; n += 2)
                        e.push(n);
                    return e
                }),
                odd: x(function(e, t) {
                    for (var n = 1; n < t; n += 2)
                        e.push(n);
                    return e
                }),
                lt: x(function(e, t, n) {
                    for (var r = n < 0 ? n + t : n; 0 <= --r; )
                        e.push(r);
                    return e
                }),
                gt: x(function(e, t, n) {
                    for (var r = n < 0 ? n + t : n; ++r < t; )
                        e.push(r);
                    return e
                })
            }
        }).pseudos.nth = b.pseudos.eq,
        {
            radio: !0,
            checkbox: !0,
            file: !0,
            password: !0,
            image: !0
        })
            b.pseudos[e] = function(t) {
                return function(e) {
                    return "input" === e.nodeName.toLowerCase() && e.type === t
                }
            }(e);
        for (e in {
            submit: !0,
            reset: !0
        })
            b.pseudos[e] = function(n) {
                return function(e) {
                    var t = e.nodeName.toLowerCase();
                    return ("input" === t || "button" === t) && e.type === n
                }
            }(e);
        function pe() {}
        function _(e) {
            for (var t = 0, n = e.length, r = ""; t < n; t++)
                r += e[t].value;
            return r
        }
        function he(a, e, t) {
            var s = e.dir
              , u = t && "parentNode" === s
              , l = B++;
            return e.first ? function(e, t, n) {
                for (; e = e[s]; )
                    if (1 === e.nodeType || u)
                        return a(e, t, n)
            }
            : function(e, t, n) {
                var r, i, o = [S, l];
                if (n) {
                    for (; e = e[s]; )
                        if ((1 === e.nodeType || u) && a(e, t, n))
                            return !0
                } else
                    for (; e = e[s]; )
                        if (1 === e.nodeType || u) {
                            if ((r = (i = (i = e[k] || (e[k] = {}))[e.uniqueID] || (i[e.uniqueID] = {}))[s]) && r[0] === S && r[1] === l)
                                return o[2] = r[2];
                            if ((i[s] = o)[2] = a(e, t, n))
                                return !0
                        }
            }
        }
        function ge(i) {
            return 1 < i.length ? function(e, t, n) {
                for (var r = i.length; r--; )
                    if (!i[r](e, t, n))
                        return !1;
                return !0
            }
            : i[0]
        }
        function me(e, t, n, r, i) {
            for (var o, a = [], s = 0, u = e.length, l = null != t; s < u; s++)
                !(o = e[s]) || n && !n(o, r, i) || (a.push(o),
                l && t.push(s));
            return a
        }
        function ye(p, h, g, m, y, e) {
            return m && !m[k] && (m = ye(m)),
            y && !y[k] && (y = ye(y, e)),
            q(function(e, t, n, r) {
                var i, o, a, s = [], u = [], l = t.length, c = e || function(e, t, n) {
                    for (var r = 0, i = t.length; r < i; r++)
                        H(e, t[r], n);
                    return n
                }(h || "*", n.nodeType ? [n] : n, []), f = !p || !e && h ? c : me(c, s, p, n, r), d = g ? y || (e ? p : l || m) ? [] : t : f;
                if (g && g(f, d, n, r),
                m)
                    for (i = me(d, u),
                    m(i, [], n, r),
                    o = i.length; o--; )
                        (a = i[o]) && (d[u[o]] = !(f[u[o]] = a));
                if (e) {
                    if (y || p) {
                        if (y) {
                            for (i = [],
                            o = d.length; o--; )
                                (a = d[o]) && i.push(f[o] = a);
                            y(null, d = [], i, r)
                        }
                        for (o = d.length; o--; )
                            (a = d[o]) && -1 < (i = y ? j(e, a) : s[o]) && (e[i] = !(t[i] = a))
                    }
                } else
                    d = me(d === t ? d.splice(l, d.length) : d),
                    y ? y(null, t, d, r) : D.apply(t, d)
            })
        }
        return pe.prototype = b.filters = b.pseudos,
        b.setFilters = new pe,
        w = H.tokenize = function(e, t) {
            var n, r, i, o, a, s, u, l = I[e + " "];
            if (l)
                return t ? 0 : l.slice(0);
            for (a = e,
            s = [],
            u = b.preFilter; a; ) {
                for (o in n && !(r = Q.exec(a)) || (r && (a = a.slice(r[0].length) || a),
                s.push(i = [])),
                n = !1,
                (r = Z.exec(a)) && (n = r.shift(),
                i.push({
                    value: n,
                    type: r[0].replace(L, " ")
                }),
                a = a.slice(n.length)),
                b.filter)
                    !(r = f[o].exec(a)) || u[o] && !(r = u[o](r)) || (n = r.shift(),
                    i.push({
                        value: n,
                        type: o,
                        matches: r
                    }),
                    a = a.slice(n.length));
                if (!n)
                    break
            }
            return t ? a.length : a ? H.error(e) : I(e, s).slice(0)
        }
        ,
        R = H.compile = function(e, t) {
            var n, m, y, v, x, r, i = [], o = [], a = A[e + " "];
            if (!a) {
                for (n = (t = t || w(e)).length; n--; )
                    ((a = function f(e) {
                        for (var r, t, n, i = e.length, o = b.relative[e[0].type], a = o || b.relative[" "], s = o ? 1 : 0, u = he(function(e) {
                            return e === r
                        }, a, !0), l = he(function(e) {
                            return -1 < j(r, e)
                        }, a, !0), c = [function(e, t, n) {
                            return e = !o && (n || t !== T) || ((r = t).nodeType ? u : l)(e, t, n),
                            r = null,
                            e
                        }
                        ]; s < i; s++)
                            if (t = b.relative[e[s].type])
                                c = [he(ge(c), t)];
                            else {
                                if ((t = b.filter[e[s].type].apply(null, e[s].matches))[k]) {
                                    for (n = ++s; n < i && !b.relative[e[n].type]; n++)
                                        ;
                                    return ye(1 < s && ge(c), 1 < s && _(e.slice(0, s - 1).concat({
                                        value: " " === e[s - 2].type ? "*" : ""
                                    })).replace(L, "$1"), t, s < n && f(e.slice(s, n)), n < i && f(e = e.slice(n)), n < i && _(e))
                                }
                                c.push(t)
                            }
                        return ge(c)
                    }(t[n]))[k] ? i : o).push(a);
                (a = A(e, (m = o,
                v = 0 < (y = i).length,
                x = 0 < m.length,
                r = function(e, t, n, r, i) {
                    var o, a, s, u = 0, l = "0", c = e && [], f = [], d = T, p = e || x && b.find.TAG("*", i), h = S += null == d ? 1 : Math.random() || .1, g = p.length;
                    for (i && (T = t === E || t || i); l !== g && null != (o = p[l]); l++) {
                        if (x && o) {
                            for (a = 0,
                            t || o.ownerDocument === E || (C(o),
                            n = !N); s = m[a++]; )
                                if (s(o, t || E, n)) {
                                    r.push(o);
                                    break
                                }
                            i && (S = h)
                        }
                        v && ((o = !s && o) && u--,
                        e && c.push(o))
                    }
                    if (u += l,
                    v && l !== u) {
                        for (a = 0; s = y[a++]; )
                            s(c, f, t, n);
                        if (e) {
                            if (0 < u)
                                for (; l--; )
                                    c[l] || f[l] || (f[l] = X.call(r));
                            f = me(f)
                        }
                        D.apply(r, f),
                        i && !e && 0 < f.length && 1 < u + y.length && H.uniqueSort(r)
                    }
                    return i && (S = h,
                    T = d),
                    c
                }
                ,
                v ? q(r) : r))).selector = e
            }
            return a
        }
        ,
        P = H.select = function(e, t, n, r) {
            var i, o, a, s, u, l = "function" == typeof e && e, c = !r && w(e = l.selector || e);
            if (n = n || [],
            1 === c.length) {
                if (2 < (o = c[0] = c[0].slice(0)).length && "ID" === (a = o[0]).type && g.getById && 9 === t.nodeType && N && b.relative[o[1].type]) {
                    if (!(t = (b.find.ID(a.matches[0].replace(d, p), t) || [])[0]))
                        return n;
                    l && (t = t.parentNode),
                    e = e.slice(o.shift().value.length)
                }
                for (i = f.needsContext.test(e) ? 0 : o.length; i-- && (a = o[i],
                !b.relative[s = a.type]); )
                    if ((u = b.find[s]) && (r = u(a.matches[0].replace(d, p), ae.test(o[0].type) && de(t.parentNode) || t))) {
                        if (o.splice(i, 1),
                        e = r.length && _(o))
                            break;
                        return D.apply(n, r),
                        n
                    }
            }
            return (l || R(e, c))(r, t, !N, n, !t || ae.test(e) && de(t.parentNode) || t),
            n
        }
        ,
        g.sortStable = k.split("").sort($).join("") === k,
        g.detectDuplicates = !!l,
        C(),
        g.sortDetached = h(function(e) {
            return 1 & e.compareDocumentPosition(E.createElement("div"))
        }),
        h(function(e) {
            return e.innerHTML = "<a href='#'></a>",
            "#" === e.firstChild.getAttribute("href")
        }) || ce("type|href|height|width", function(e, t, n) {
            if (!n)
                return e.getAttribute(t, "type" === t.toLowerCase() ? 1 : 2)
        }),
        g.attributes && h(function(e) {
            return e.innerHTML = "<input/>",
            e.firstChild.setAttribute("value", ""),
            "" === e.firstChild.getAttribute("value")
        }) || ce("value", function(e, t, n) {
            if (!n && "input" === e.nodeName.toLowerCase())
                return e.defaultValue
        }),
        h(function(e) {
            return null == e.getAttribute("disabled")
        }) || ce(Y, function(e, t, n) {
            if (!n)
                return !0 === e[t] ? t.toLowerCase() : (n = e.getAttributeNode(t)) && n.specified ? n.value : null
        }),
        H
    }(T)
      , r = (C.find = e,
    C.expr = e.selectors,
    C.expr[":"] = C.expr.pseudos,
    C.uniqueSort = C.unique = e.uniqueSort,
    C.text = e.getText,
    C.isXMLDoc = e.isXML,
    C.contains = e.contains,
    function(e, t, n) {
        for (var r = [], i = n !== undefined; (e = e[t]) && 9 !== e.nodeType; )
            if (1 === e.nodeType) {
                if (i && C(e).is(n))
                    break;
                r.push(e)
            }
        return r
    }
    )
      , V = function(e, t) {
        for (var n = []; e; e = e.nextSibling)
            1 === e.nodeType && e !== t && n.push(e);
        return n
    }
      , Y = C.expr.match.needsContext
      , J = /^<([\w-]+)\s*\/?>(?:<\/\1>|)$/
      , G = /^.[^:#\[\.,]*$/;
    function K(e, n, r) {
        if (C.isFunction(n))
            return C.grep(e, function(e, t) {
                return !!n.call(e, t, e) !== r
            });
        if (n.nodeType)
            return C.grep(e, function(e) {
                return e === n !== r
            });
        if ("string" == typeof n) {
            if (G.test(n))
                return C.filter(n, e, r);
            n = C.filter(n, e)
        }
        return C.grep(e, function(e) {
            return -1 < C.inArray(e, n) !== r
        })
    }
    C.filter = function(e, t, n) {
        var r = t[0];
        return n && (e = ":not(" + e + ")"),
        1 === t.length && 1 === r.nodeType ? C.find.matchesSelector(r, e) ? [r] : [] : C.find.matches(e, C.grep(t, function(e) {
            return 1 === e.nodeType
        }))
    }
    ,
    C.fn.extend({
        find: function(e) {
            var t, n = [], r = this, i = r.length;
            if ("string" != typeof e)
                return this.pushStack(C(e).filter(function() {
                    for (t = 0; t < i; t++)
                        if (C.contains(r[t], this))
                            return !0
                }));
            for (t = 0; t < i; t++)
                C.find(e, r[t], n);
            return (n = this.pushStack(1 < i ? C.unique(n) : n)).selector = this.selector ? this.selector + " " + e : e,
            n
        },
        filter: function(e) {
            return this.pushStack(K(this, e || [], !1))
        },
        not: function(e) {
            return this.pushStack(K(this, e || [], !0))
        },
        is: function(e) {
            return !!K(this, "string" == typeof e && Y.test(e) ? C(e) : e || [], !1).length
        }
    });
    var Q, Z = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/, ee = ((C.fn.init = function(e, t, n) {
        if (!e)
            return this;
        if (n = n || Q,
        "string" != typeof e)
            return e.nodeType ? (this.context = this[0] = e,
            this.length = 1,
            this) : C.isFunction(e) ? "undefined" != typeof n.ready ? n.ready(e) : e(C) : (e.selector !== undefined && (this.selector = e.selector,
            this.context = e.context),
            C.makeArray(e, this));
        if (!(r = "<" === e.charAt(0) && ">" === e.charAt(e.length - 1) && 3 <= e.length ? [null, e, null] : Z.exec(e)) || !r[1] && t)
            return (!t || t.jquery ? t || n : this.constructor(t)).find(e);
        if (r[1]) {
            if (t = t instanceof C ? t[0] : t,
            C.merge(this, C.parseHTML(r[1], t && t.nodeType ? t.ownerDocument || t : g, !0)),
            J.test(r[1]) && C.isPlainObject(t))
                for (var r in t)
                    C.isFunction(this[r]) ? this[r](t[r]) : this.attr(r, t[r]);
            return this
        }
        if ((n = g.getElementById(r[2])) && n.parentNode) {
            if (n.id !== r[2])
                return Q.find(e);
            this.length = 1,
            this[0] = n
        }
        return this.context = g,
        this.selector = e,
        this
    }
    ).prototype = C.fn,
    Q = C(g),
    /^(?:parents|prev(?:Until|All))/), te = {
        children: !0,
        contents: !0,
        next: !0,
        prev: !0
    };
    function ne(e, t) {
        for (; (e = e[t]) && 1 !== e.nodeType; )
            ;
        return e
    }
    C.fn.extend({
        has: function(e) {
            var t, n = C(e, this), r = n.length;
            return this.filter(function() {
                for (t = 0; t < r; t++)
                    if (C.contains(this, n[t]))
                        return !0
            })
        },
        closest: function(e, t) {
            for (var n, r = 0, i = this.length, o = [], a = Y.test(e) || "string" != typeof e ? C(e, t || this.context) : 0; r < i; r++)
                for (n = this[r]; n && n !== t; n = n.parentNode)
                    if (n.nodeType < 11 && (a ? -1 < a.index(n) : 1 === n.nodeType && C.find.matchesSelector(n, e))) {
                        o.push(n);
                        break
                    }
            return this.pushStack(1 < o.length ? C.uniqueSort(o) : o)
        },
        index: function(e) {
            return e ? "string" == typeof e ? C.inArray(this[0], C(e)) : C.inArray(e.jquery ? e[0] : e, this) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1
        },
        add: function(e, t) {
            return this.pushStack(C.uniqueSort(C.merge(this.get(), C(e, t))))
        },
        addBack: function(e) {
            return this.add(null == e ? this.prevObject : this.prevObject.filter(e))
        }
    }),
    C.each({
        parent: function(e) {
            e = e.parentNode;
            return e && 11 !== e.nodeType ? e : null
        },
        parents: function(e) {
            return r(e, "parentNode")
        },
        parentsUntil: function(e, t, n) {
            return r(e, "parentNode", n)
        },
        next: function(e) {
            return ne(e, "nextSibling")
        },
        prev: function(e) {
            return ne(e, "previousSibling")
        },
        nextAll: function(e) {
            return r(e, "nextSibling")
        },
        prevAll: function(e) {
            return r(e, "previousSibling")
        },
        nextUntil: function(e, t, n) {
            return r(e, "nextSibling", n)
        },
        prevUntil: function(e, t, n) {
            return r(e, "previousSibling", n)
        },
        siblings: function(e) {
            return V((e.parentNode || {}).firstChild, e)
        },
        children: function(e) {
            return V(e.firstChild)
        },
        contents: function(e) {
            return C.nodeName(e, "iframe") ? e.contentDocument || e.contentWindow.document : C.merge([], e.childNodes)
        }
    }, function(r, i) {
        C.fn[r] = function(e, t) {
            var n = C.map(this, i, e);
            return (t = "Until" !== r.slice(-5) ? e : t) && "string" == typeof t && (n = C.filter(t, n)),
            1 < this.length && (te[r] || (n = C.uniqueSort(n)),
            ee.test(r) && (n = n.reverse())),
            this.pushStack(n)
        }
    });
    var re, ie, E = /\S+/g;
    function oe() {
        g.addEventListener ? (g.removeEventListener("DOMContentLoaded", i),
        T.removeEventListener("load", i)) : (g.detachEvent("onreadystatechange", i),
        T.detachEvent("onload", i))
    }
    function i() {
        !g.addEventListener && "load" !== T.event.type && "complete" !== g.readyState || (oe(),
        C.ready())
    }
    for (ie in C.Callbacks = function(r) {
        var e, n;
        r = "string" == typeof r ? (e = r,
        n = {},
        C.each(e.match(E) || [], function(e, t) {
            n[t] = !0
        }),
        n) : C.extend({}, r);
        var i, t, o, a, s = [], u = [], l = -1, c = function() {
            for (a = r.once,
            o = i = !0; u.length; l = -1)
                for (t = u.shift(); ++l < s.length; )
                    !1 === s[l].apply(t[0], t[1]) && r.stopOnFalse && (l = s.length,
                    t = !1);
            r.memory || (t = !1),
            i = !1,
            a && (s = t ? [] : "")
        }, f = {
            add: function() {
                return s && (t && !i && (l = s.length - 1,
                u.push(t)),
                function n(e) {
                    C.each(e, function(e, t) {
                        C.isFunction(t) ? r.unique && f.has(t) || s.push(t) : t && t.length && "string" !== C.type(t) && n(t)
                    })
                }(arguments),
                t && !i && c()),
                this
            },
            remove: function() {
                return C.each(arguments, function(e, t) {
                    for (var n; -1 < (n = C.inArray(t, s, n)); )
                        s.splice(n, 1),
                        n <= l && l--
                }),
                this
            },
            has: function(e) {
                return e ? -1 < C.inArray(e, s) : 0 < s.length
            },
            empty: function() {
                return s = s && [],
                this
            },
            disable: function() {
                return a = u = [],
                s = t = "",
                this
            },
            disabled: function() {
                return !s
            },
            lock: function() {
                return a = !0,
                t || f.disable(),
                this
            },
            locked: function() {
                return !!a
            },
            fireWith: function(e, t) {
                return a || (t = [e, (t = t || []).slice ? t.slice() : t],
                u.push(t),
                i || c()),
                this
            },
            fire: function() {
                return f.fireWith(this, arguments),
                this
            },
            fired: function() {
                return !!o
            }
        };
        return f
    }
    ,
    C.extend({
        Deferred: function(e) {
            var o = [["resolve", "done", C.Callbacks("once memory"), "resolved"], ["reject", "fail", C.Callbacks("once memory"), "rejected"], ["notify", "progress", C.Callbacks("memory")]]
              , i = "pending"
              , a = {
                state: function() {
                    return i
                },
                always: function() {
                    return s.done(arguments).fail(arguments),
                    this
                },
                then: function() {
                    var i = arguments;
                    return C.Deferred(function(r) {
                        C.each(o, function(e, t) {
                            var n = C.isFunction(i[e]) && i[e];
                            s[t[1]](function() {
                                var e = n && n.apply(this, arguments);
                                e && C.isFunction(e.promise) ? e.promise().progress(r.notify).done(r.resolve).fail(r.reject) : r[t[0] + "With"](this === a ? r.promise() : this, n ? [e] : arguments)
                            })
                        }),
                        i = null
                    }).promise()
                },
                promise: function(e) {
                    return null != e ? C.extend(e, a) : a
                }
            }
              , s = {};
            return a.pipe = a.then,
            C.each(o, function(e, t) {
                var n = t[2]
                  , r = t[3];
                a[t[1]] = n.add,
                r && n.add(function() {
                    i = r
                }, o[1 ^ e][2].disable, o[2][2].lock),
                s[t[0]] = function() {
                    return s[t[0] + "With"](this === s ? a : this, arguments),
                    this
                }
                ,
                s[t[0] + "With"] = n.fireWith
            }),
            a.promise(s),
            e && e.call(s, s),
            s
        },
        when: function(e) {
            var i, t, n, r = 0, o = c.call(arguments), a = o.length, s = 1 !== a || e && C.isFunction(e.promise) ? a : 0, u = 1 === s ? e : C.Deferred(), l = function(t, n, r) {
                return function(e) {
                    n[t] = this,
                    r[t] = 1 < arguments.length ? c.call(arguments) : e,
                    r === i ? u.notifyWith(n, r) : --s || u.resolveWith(n, r)
                }
            };
            if (1 < a)
                for (i = new Array(a),
                t = new Array(a),
                n = new Array(a); r < a; r++)
                    o[r] && C.isFunction(o[r].promise) ? o[r].promise().progress(l(r, t, i)).done(l(r, n, o)).fail(u.reject) : --s;
            return s || u.resolveWith(n, o),
            u.promise()
        }
    }),
    C.fn.ready = function(e) {
        return C.ready.promise().done(e),
        this
    }
    ,
    C.extend({
        isReady: !1,
        readyWait: 1,
        holdReady: function(e) {
            e ? C.readyWait++ : C.ready(!0)
        },
        ready: function(e) {
            (!0 === e ? --C.readyWait : C.isReady) || (C.isReady = !0) !== e && 0 < --C.readyWait || (re.resolveWith(g, [C]),
            C.fn.triggerHandler && (C(g).triggerHandler("ready"),
            C(g).off("ready")))
        }
    }),
    C.ready.promise = function(e) {
        if (!re)
            if (re = C.Deferred(),
            "complete" === g.readyState || "loading" !== g.readyState && !g.documentElement.doScroll)
                T.setTimeout(C.ready);
            else if (g.addEventListener)
                g.addEventListener("DOMContentLoaded", i),
                T.addEventListener("load", i);
            else {
                g.attachEvent("onreadystatechange", i),
                T.attachEvent("onload", i);
                var t = !1;
                try {
                    t = null == T.frameElement && g.documentElement
                } catch (n) {}
                t && t.doScroll && !function r() {
                    if (!C.isReady) {
                        try {
                            t.doScroll("left")
                        } catch (n) {
                            return T.setTimeout(r, 50)
                        }
                        oe(),
                        C.ready()
                    }
                }()
            }
        return re.promise(e)
    }
    ,
    C.ready.promise(),
    C(y))
        break;
    y.ownFirst = "0" === ie,
    y.inlineBlockNeedsLayout = !1,
    C(function() {
        var e, t, n = g.getElementsByTagName("body")[0];
        n && n.style && (e = g.createElement("div"),
        (t = g.createElement("div")).style.cssText = "position:absolute;border:0;width:0;height:0;top:0;left:-9999px",
        n.appendChild(t).appendChild(e),
        "undefined" != typeof e.style.zoom && (e.style.cssText = "display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1",
        y.inlineBlockNeedsLayout = e = 3 === e.offsetWidth,
        e && (n.style.zoom = 1)),
        n.removeChild(t))
    });
    e = g.createElement("div");
    y.deleteExpando = !0;
    try {
        delete e.test
    } catch (yn) {
        y.deleteExpando = !1
    }
    var o, v = function(e) {
        var t = C.noData[(e.nodeName + " ").toLowerCase()]
          , n = +e.nodeType || 1;
        return (1 === n || 9 === n) && (!t || !0 !== t && e.getAttribute("classid") === t)
    }, ae = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, se = /([A-Z])/g;
    function ue(e, t, n) {
        if (n === undefined && 1 === e.nodeType) {
            var r = "data-" + t.replace(se, "-$1").toLowerCase();
            if ("string" == typeof (n = e.getAttribute(r))) {
                try {
                    n = "true" === n || "false" !== n && ("null" === n ? null : +n + "" === n ? +n : ae.test(n) ? C.parseJSON(n) : n)
                } catch (i) {}
                C.data(e, t, n)
            } else
                n = undefined
        }
        return n
    }
    function le(e) {
        for (var t in e)
            if (("data" !== t || !C.isEmptyObject(e[t])) && "toJSON" !== t)
                return;
        return 1
    }
    function ce(e, t, n, r) {
        if (v(e)) {
            var i, o = C.expando, a = e.nodeType, s = a ? C.cache : e, u = a ? e[o] : e[o] && o;
            if (u && s[u] && (r || s[u].data) || n !== undefined || "string" != typeof t)
                return s[u = u || (a ? e[o] = f.pop() || C.guid++ : o)] || (s[u] = a ? {} : {
                    toJSON: C.noop
                }),
                "object" != typeof t && "function" != typeof t || (r ? s[u] = C.extend(s[u], t) : s[u].data = C.extend(s[u].data, t)),
                e = s[u],
                r || (e.data || (e.data = {}),
                e = e.data),
                n !== undefined && (e[C.camelCase(t)] = n),
                "string" == typeof t ? null == (i = e[t]) && (i = e[C.camelCase(t)]) : i = e,
                i
        }
    }
    function fe(e, t, n) {
        if (v(e)) {
            var r, i, o = e.nodeType, a = o ? C.cache : e, s = o ? e[C.expando] : C.expando;
            if (a[s]) {
                if (t && (r = n ? a[s] : a[s].data)) {
                    i = (t = C.isArray(t) ? t.concat(C.map(t, C.camelCase)) : t in r || (t = C.camelCase(t))in r ? [t] : t.split(" ")).length;
                    for (; i--; )
                        delete r[t[i]];
                    if (n ? !le(r) : !C.isEmptyObject(r))
                        return
                }
                (n || (delete a[s].data,
                le(a[s]))) && (o ? C.cleanData([e], !0) : y.deleteExpando || a != a.window ? delete a[s] : a[s] = undefined)
            }
        }
    }
    C.extend({
        cache: {},
        noData: {
            "applet ": !0,
            "embed ": !0,
            "object ": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
        },
        hasData: function(e) {
            return !!(e = e.nodeType ? C.cache[e[C.expando]] : e[C.expando]) && !le(e)
        },
        data: function(e, t, n) {
            return ce(e, t, n)
        },
        removeData: function(e, t) {
            return fe(e, t)
        },
        _data: function(e, t, n) {
            return ce(e, t, n, !0)
        },
        _removeData: function(e, t) {
            return fe(e, t, !0)
        }
    }),
    C.fn.extend({
        data: function(e, t) {
            var n, r, i, o = this[0], a = o && o.attributes;
            if (e !== undefined)
                return "object" == typeof e ? this.each(function() {
                    C.data(this, e)
                }) : 1 < arguments.length ? this.each(function() {
                    C.data(this, e, t)
                }) : o ? ue(o, e, C.data(o, e)) : undefined;
            if (this.length && (i = C.data(o),
            1 === o.nodeType && !C._data(o, "parsedAttrs"))) {
                for (n = a.length; n--; )
                    a[n] && 0 === (r = a[n].name).indexOf("data-") && ue(o, r = C.camelCase(r.slice(5)), i[r]);
                C._data(o, "parsedAttrs", !0)
            }
            return i
        },
        removeData: function(e) {
            return this.each(function() {
                C.removeData(this, e)
            })
        }
    }),
    C.extend({
        queue: function(e, t, n) {
            var r;
            if (e)
                return r = C._data(e, t = (t || "fx") + "queue"),
                n && (!r || C.isArray(n) ? r = C._data(e, t, C.makeArray(n)) : r.push(n)),
                r || []
        },
        dequeue: function(e, t) {
            t = t || "fx";
            var n = C.queue(e, t)
              , r = n.length
              , i = n.shift()
              , o = C._queueHooks(e, t);
            "inprogress" === i && (i = n.shift(),
            r--),
            i && ("fx" === t && n.unshift("inprogress"),
            delete o.stop,
            i.call(e, function() {
                C.dequeue(e, t)
            }, o)),
            !r && o && o.empty.fire()
        },
        _queueHooks: function(e, t) {
            var n = t + "queueHooks";
            return C._data(e, n) || C._data(e, n, {
                empty: C.Callbacks("once memory").add(function() {
                    C._removeData(e, t + "queue"),
                    C._removeData(e, n)
                })
            })
        }
    }),
    C.fn.extend({
        queue: function(t, n) {
            var e = 2;
            return "string" != typeof t && (n = t,
            t = "fx",
            e--),
            arguments.length < e ? C.queue(this[0], t) : n === undefined ? this : this.each(function() {
                var e = C.queue(this, t, n);
                C._queueHooks(this, t),
                "fx" === t && "inprogress" !== e[0] && C.dequeue(this, t)
            })
        },
        dequeue: function(e) {
            return this.each(function() {
                C.dequeue(this, e)
            })
        },
        clearQueue: function(e) {
            return this.queue(e || "fx", [])
        },
        promise: function(e, t) {
            var n, r = 1, i = C.Deferred(), o = this, a = this.length, s = function() {
                --r || i.resolveWith(o, [o])
            };
            for ("string" != typeof e && (t = e,
            e = undefined),
            e = e || "fx"; a--; )
                (n = C._data(o[a], e + "queueHooks")) && n.empty && (r++,
                n.empty.add(s));
            return s(),
            i.promise(t)
        }
    }),
    y.shrinkWrapBlocks = function() {
        return null != o ? o : (o = !1,
        (t = g.getElementsByTagName("body")[0]) && t.style ? (e = g.createElement("div"),
        (n = g.createElement("div")).style.cssText = "position:absolute;border:0;width:0;height:0;top:0;left:-9999px",
        t.appendChild(n).appendChild(e),
        "undefined" != typeof e.style.zoom && (e.style.cssText = "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:1px;width:1px;zoom:1",
        e.appendChild(g.createElement("div")).style.width = "5px",
        o = 3 !== e.offsetWidth),
        t.removeChild(n),
        o) : void 0);
        var e, t, n
    }
    ;
    var e = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source
      , de = new RegExp("^(?:([+-])=|)(" + e + ")([a-z%]*)$","i")
      , s = ["Top", "Right", "Bottom", "Left"]
      , pe = function(e, t) {
        return "none" === C.css(e = t || e, "display") || !C.contains(e.ownerDocument, e)
    };
    function he(e, t, n, r) {
        var i, o = 1, a = 20, s = r ? function() {
            return r.cur()
        }
        : function() {
            return C.css(e, t, "")
        }
        , u = s(), l = n && n[3] || (C.cssNumber[t] ? "" : "px"), c = (C.cssNumber[t] || "px" !== l && +u) && de.exec(C.css(e, t));
        if (c && c[3] !== l)
            for (l = l || c[3],
            n = n || [],
            c = +u || 1; c /= o = o || ".5",
            C.style(e, t, c + l),
            o !== (o = s() / u) && 1 !== o && --a; )
                ;
        return n && (c = +c || +u || 0,
        i = n[1] ? c + (n[1] + 1) * n[2] : +n[2],
        r && (r.unit = l,
        r.start = c,
        r.end = i)),
        i
    }
    var d = function(e, t, n, r, i, o, a) {
        var s = 0
          , u = e.length
          , l = null == n;
        if ("object" === C.type(n))
            for (s in i = !0,
            n)
                d(e, t, s, n[s], !0, o, a);
        else if (r !== undefined && (i = !0,
        C.isFunction(r) || (a = !0),
        t = l ? a ? (t.call(e, r),
        null) : (l = t,
        function(e, t, n) {
            return l.call(C(e), n)
        }
        ) : t))
            for (; s < u; s++)
                t(e[s], n, a ? r : r.call(e[s], s, t(e[s], n)));
        return i ? e : l ? t.call(e) : u ? t(e[0], n) : o
    }
      , ge = /^(?:checkbox|radio)$/i
      , me = /<([\w:-]+)/
      , ye = /^$|\/(?:java|ecma)script/i
      , ve = /^\s+/
      , xe = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|dialog|figcaption|figure|footer|header|hgroup|main|mark|meter|nav|output|picture|progress|section|summary|template|time|video";
    function be(e) {
        var t = xe.split("|")
          , n = e.createDocumentFragment();
        if (n.createElement)
            for (; t.length; )
                n.createElement(t.pop());
        return n
    }
    S = g.createElement("div"),
    k = g.createDocumentFragment(),
    q = g.createElement("input"),
    S.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
    y.leadingWhitespace = 3 === S.firstChild.nodeType,
    y.tbody = !S.getElementsByTagName("tbody").length,
    y.htmlSerialize = !!S.getElementsByTagName("link").length,
    y.html5Clone = "<:nav></:nav>" !== g.createElement("nav").cloneNode(!0).outerHTML,
    q.type = "checkbox",
    q.checked = !0,
    k.appendChild(q),
    y.appendChecked = q.checked,
    S.innerHTML = "<textarea>x</textarea>",
    y.noCloneChecked = !!S.cloneNode(!0).lastChild.defaultValue,
    k.appendChild(S),
    (q = g.createElement("input")).setAttribute("type", "radio"),
    q.setAttribute("checked", "checked"),
    q.setAttribute("name", "t"),
    S.appendChild(q),
    y.checkClone = S.cloneNode(!0).cloneNode(!0).lastChild.checked,
    y.noCloneEvent = !!S.addEventListener,
    S[C.expando] = 1,
    y.attributes = !S.getAttribute(C.expando);
    var x = {
        option: [1, "<select multiple='multiple'>", "</select>"],
        legend: [1, "<fieldset>", "</fieldset>"],
        area: [1, "<map>", "</map>"],
        param: [1, "<object>", "</object>"],
        thead: [1, "<table>", "</table>"],
        tr: [2, "<table><tbody>", "</tbody></table>"],
        col: [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"],
        td: [3, "<table><tbody><tr>", "</tr></tbody></table>"],
        _default: y.htmlSerialize ? [0, "", ""] : [1, "X<div>", "</div>"]
    };
    function b(e, t) {
        var n, r, i = 0, o = "undefined" != typeof e.getElementsByTagName ? e.getElementsByTagName(t || "*") : "undefined" != typeof e.querySelectorAll ? e.querySelectorAll(t || "*") : undefined;
        if (!o)
            for (o = [],
            n = e.childNodes || e; null != (r = n[i]); i++)
                !t || C.nodeName(r, t) ? o.push(r) : C.merge(o, b(r, t));
        return t === undefined || t && C.nodeName(e, t) ? C.merge([e], o) : o
    }
    function we(e, t) {
        for (var n, r = 0; null != (n = e[r]); r++)
            C._data(n, "globalEval", !t || C._data(t[r], "globalEval"))
    }
    x.optgroup = x.option,
    x.tbody = x.tfoot = x.colgroup = x.caption = x.thead,
    x.th = x.td;
    var Te = /<|&#?\w+;/
      , Ce = /<tbody/i;
    function Ee(e) {
        ge.test(e.type) && (e.defaultChecked = e.checked)
    }
    function Ne(e, t, n, r, i) {
        for (var o, a, s, u, l, c, f, d = e.length, p = be(t), h = [], g = 0; g < d; g++)
            if ((a = e[g]) || 0 === a)
                if ("object" === C.type(a))
                    C.merge(h, a.nodeType ? [a] : a);
                else if (Te.test(a)) {
                    for (u = u || p.appendChild(t.createElement("div")),
                    l = (me.exec(a) || ["", ""])[1].toLowerCase(),
                    f = x[l] || x._default,
                    u.innerHTML = f[1] + C.htmlPrefilter(a) + f[2],
                    o = f[0]; o--; )
                        u = u.lastChild;
                    if (!y.leadingWhitespace && ve.test(a) && h.push(t.createTextNode(ve.exec(a)[0])),
                    !y.tbody)
                        for (o = (a = "table" !== l || Ce.test(a) ? "<table>" !== f[1] || Ce.test(a) ? 0 : u : u.firstChild) && a.childNodes.length; o--; )
                            C.nodeName(c = a.childNodes[o], "tbody") && !c.childNodes.length && a.removeChild(c);
                    for (C.merge(h, u.childNodes),
                    u.textContent = ""; u.firstChild; )
                        u.removeChild(u.firstChild);
                    u = p.lastChild
                } else
                    h.push(t.createTextNode(a));
        for (u && p.removeChild(u),
        y.appendChecked || C.grep(b(h, "input"), Ee),
        g = 0; a = h[g++]; )
            if (r && -1 < C.inArray(a, r))
                i && i.push(a);
            else if (s = C.contains(a.ownerDocument, a),
            u = b(p.appendChild(a), "script"),
            s && we(u),
            n)
                for (o = 0; a = u[o++]; )
                    ye.test(a.type || "") && n.push(a);
        return u = null,
        p
    }
    var ke, Se, Ae = g.createElement("div");
    for (ke in {
        submit: !0,
        change: !0,
        focusin: !0
    })
        (y[ke] = (Se = "on" + ke)in T) || (Ae.setAttribute(Se, "t"),
        y[ke] = !1 === Ae.attributes[Se].expando);
    var De = /^(?:input|select|textarea)$/i
      , je = /^key/
      , Le = /^(?:mouse|pointer|contextmenu|drag|drop)|click/
      , He = /^(?:focusinfocus|focusoutblur)$/
      , qe = /^([^.]*)(?:\.(.+)|)/;
    function _e() {
        return !0
    }
    function u() {
        return !1
    }
    function Fe() {
        try {
            return g.activeElement
        } catch (e) {}
    }
    function Me(e, t, n, r, i, o) {
        var a, s;
        if ("object" == typeof t) {
            for (s in "string" != typeof n && (r = r || n,
            n = undefined),
            t)
                Me(e, s, n, r, t[s], o);
            return e
        }
        if (null == r && null == i ? (i = n,
        r = n = undefined) : null == i && ("string" == typeof n ? (i = r,
        r = undefined) : (i = r,
        r = n,
        n = undefined)),
        !1 === i)
            i = u;
        else if (!i)
            return e;
        return 1 === o && (a = i,
        (i = function(e) {
            return C().off(e),
            a.apply(this, arguments)
        }
        ).guid = a.guid || (a.guid = C.guid++)),
        e.each(function() {
            C.event.add(this, t, i, r, n)
        })
    }
    C.event = {
        global: {},
        add: function(e, t, n, r, i) {
            var o, a, s, u, l, c, f, d, p, h = C._data(e);
            if (h)
                for (n.handler && (n = (s = n).handler,
                i = s.selector),
                n.guid || (n.guid = C.guid++),
                (o = h.events) || (o = h.events = {}),
                (l = h.handle) || ((l = h.handle = function(e) {
                    return void 0 === C || e && C.event.triggered === e.type ? undefined : C.event.dispatch.apply(l.elem, arguments)
                }
                ).elem = e),
                a = (t = (t || "").match(E) || [""]).length; a--; )
                    f = p = (d = qe.exec(t[a]) || [])[1],
                    d = (d[2] || "").split(".").sort(),
                    f && (u = C.event.special[f] || {},
                    f = (i ? u.delegateType : u.bindType) || f,
                    u = C.event.special[f] || {},
                    p = C.extend({
                        type: f,
                        origType: p,
                        data: r,
                        handler: n,
                        guid: n.guid,
                        selector: i,
                        needsContext: i && C.expr.match.needsContext.test(i),
                        namespace: d.join(".")
                    }, s),
                    (c = o[f]) || ((c = o[f] = []).delegateCount = 0,
                    u.setup && !1 !== u.setup.call(e, r, d, l) || (e.addEventListener ? e.addEventListener(f, l, !1) : e.attachEvent && e.attachEvent("on" + f, l))),
                    u.add && (u.add.call(e, p),
                    p.handler.guid || (p.handler.guid = n.guid)),
                    i ? c.splice(c.delegateCount++, 0, p) : c.push(p),
                    C.event.global[f] = !0)
        },
        remove: function(e, t, n, r, i) {
            var o, a, s, u, l, c, f, d, p, h, g, m = C.hasData(e) && C._data(e);
            if (m && (c = m.events)) {
                for (l = (t = (t || "").match(E) || [""]).length; l--; )
                    if (p = g = (s = qe.exec(t[l]) || [])[1],
                    h = (s[2] || "").split(".").sort(),
                    p) {
                        for (f = C.event.special[p] || {},
                        d = c[p = (r ? f.delegateType : f.bindType) || p] || [],
                        s = s[2] && new RegExp("(^|\\.)" + h.join("\\.(?:.*\\.|)") + "(\\.|$)"),
                        u = o = d.length; o--; )
                            a = d[o],
                            !i && g !== a.origType || n && n.guid !== a.guid || s && !s.test(a.namespace) || r && r !== a.selector && ("**" !== r || !a.selector) || (d.splice(o, 1),
                            a.selector && d.delegateCount--,
                            f.remove && f.remove.call(e, a));
                        u && !d.length && (f.teardown && !1 !== f.teardown.call(e, h, m.handle) || C.removeEvent(e, p, m.handle),
                        delete c[p])
                    } else
                        for (p in c)
                            C.event.remove(e, p + t[l], n, r, !0);
                C.isEmptyObject(c) && (delete m.handle,
                C._removeData(e, "events"))
            }
        },
        trigger: function(e, t, n, r) {
            var i, o, a, s, u, l, c = [n || g], f = m.call(e, "type") ? e.type : e, d = m.call(e, "namespace") ? e.namespace.split(".") : [], p = u = n = n || g;
            if (3 !== n.nodeType && 8 !== n.nodeType && !He.test(f + C.event.triggered) && (-1 < f.indexOf(".") && (f = (d = f.split(".")).shift(),
            d.sort()),
            o = f.indexOf(":") < 0 && "on" + f,
            (e = e[C.expando] ? e : new C.Event(f,"object" == typeof e && e)).isTrigger = r ? 2 : 3,
            e.namespace = d.join("."),
            e.rnamespace = e.namespace ? new RegExp("(^|\\.)" + d.join("\\.(?:.*\\.|)") + "(\\.|$)") : null,
            e.result = undefined,
            e.target || (e.target = n),
            t = null == t ? [e] : C.makeArray(t, [e]),
            s = C.event.special[f] || {},
            r || !s.trigger || !1 !== s.trigger.apply(n, t))) {
                if (!r && !s.noBubble && !C.isWindow(n)) {
                    for (a = s.delegateType || f,
                    He.test(a + f) || (p = p.parentNode); p; p = p.parentNode)
                        c.push(p),
                        u = p;
                    u === (n.ownerDocument || g) && c.push(u.defaultView || u.parentWindow || T)
                }
                for (l = 0; (p = c[l++]) && !e.isPropagationStopped(); )
                    e.type = 1 < l ? a : s.bindType || f,
                    (i = (C._data(p, "events") || {})[e.type] && C._data(p, "handle")) && i.apply(p, t),
                    (i = o && p[o]) && i.apply && v(p) && (e.result = i.apply(p, t),
                    !1 === e.result && e.preventDefault());
                if (e.type = f,
                !r && !e.isDefaultPrevented() && (!s._default || !1 === s._default.apply(c.pop(), t)) && v(n) && o && n[f] && !C.isWindow(n)) {
                    (u = n[o]) && (n[o] = null),
                    C.event.triggered = f;
                    try {
                        n[f]()
                    } catch (h) {}
                    C.event.triggered = undefined,
                    u && (n[o] = u)
                }
                return e.result
            }
        },
        dispatch: function(e) {
            e = C.event.fix(e);
            var t, n, r, i, o, a = c.call(arguments), s = (C._data(this, "events") || {})[e.type] || [], u = C.event.special[e.type] || {};
            if ((a[0] = e).delegateTarget = this,
            !u.preDispatch || !1 !== u.preDispatch.call(this, e)) {
                for (o = C.event.handlers.call(this, e, s),
                t = 0; (r = o[t++]) && !e.isPropagationStopped(); )
                    for (e.currentTarget = r.elem,
                    n = 0; (i = r.handlers[n++]) && !e.isImmediatePropagationStopped(); )
                        e.rnamespace && !e.rnamespace.test(i.namespace) || (e.handleObj = i,
                        e.data = i.data,
                        (i = ((C.event.special[i.origType] || {}).handle || i.handler).apply(r.elem, a)) !== undefined && !1 === (e.result = i) && (e.preventDefault(),
                        e.stopPropagation()));
                return u.postDispatch && u.postDispatch.call(this, e),
                e.result
            }
        },
        handlers: function(e, t) {
            var n, r, i, o, a = [], s = t.delegateCount, u = e.target;
            if (s && u.nodeType && ("click" !== e.type || isNaN(e.button) || e.button < 1))
                for (; u != this; u = u.parentNode || this)
                    if (1 === u.nodeType && (!0 !== u.disabled || "click" !== e.type)) {
                        for (r = [],
                        n = 0; n < s; n++)
                            r[i = (o = t[n]).selector + " "] === undefined && (r[i] = o.needsContext ? -1 < C(i, this).index(u) : C.find(i, this, null, [u]).length),
                            r[i] && r.push(o);
                        r.length && a.push({
                            elem: u,
                            handlers: r
                        })
                    }
            return s < t.length && a.push({
                elem: this,
                handlers: t.slice(s)
            }),
            a
        },
        fix: function(e) {
            if (e[C.expando])
                return e;
            var t, n, r, i = e.type, o = e, a = this.fixHooks[i];
            for (a || (this.fixHooks[i] = a = Le.test(i) ? this.mouseHooks : je.test(i) ? this.keyHooks : {}),
            r = a.props ? this.props.concat(a.props) : this.props,
            e = new C.Event(o),
            t = r.length; t--; )
                e[n = r[t]] = o[n];
            return e.target || (e.target = o.srcElement || g),
            3 === e.target.nodeType && (e.target = e.target.parentNode),
            e.metaKey = !!e.metaKey,
            a.filter ? a.filter(e, o) : e
        },
        props: "altKey bubbles cancelable ctrlKey currentTarget detail eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),
        fixHooks: {},
        keyHooks: {
            props: "char charCode key keyCode".split(" "),
            filter: function(e, t) {
                return null == e.which && (e.which = null != t.charCode ? t.charCode : t.keyCode),
                e
            }
        },
        mouseHooks: {
            props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),
            filter: function(e, t) {
                var n, r, i = t.button, o = t.fromElement;
                return null == e.pageX && null != t.clientX && (r = (n = e.target.ownerDocument || g).documentElement,
                n = n.body,
                e.pageX = t.clientX + (r && r.scrollLeft || n && n.scrollLeft || 0) - (r && r.clientLeft || n && n.clientLeft || 0),
                e.pageY = t.clientY + (r && r.scrollTop || n && n.scrollTop || 0) - (r && r.clientTop || n && n.clientTop || 0)),
                !e.relatedTarget && o && (e.relatedTarget = o === e.target ? t.toElement : o),
                e.which || i === undefined || (e.which = 1 & i ? 1 : 2 & i ? 3 : 4 & i ? 2 : 0),
                e
            }
        },
        special: {
            load: {
                noBubble: !0
            },
            focus: {
                trigger: function() {
                    if (this !== Fe() && this.focus)
                        try {
                            return this.focus(),
                            !1
                        } catch (e) {}
                },
                delegateType: "focusin"
            },
            blur: {
                trigger: function() {
                    if (this === Fe() && this.blur)
                        return this.blur(),
                        !1
                },
                delegateType: "focusout"
            },
            click: {
                trigger: function() {
                    if (C.nodeName(this, "input") && "checkbox" === this.type && this.click)
                        return this.click(),
                        !1
                },
                _default: function(e) {
                    return C.nodeName(e.target, "a")
                }
            },
            beforeunload: {
                postDispatch: function(e) {
                    e.result !== undefined && e.originalEvent && (e.originalEvent.returnValue = e.result)
                }
            }
        },
        simulate: function(e, t, n) {
            e = C.extend(new C.Event, n, {
                type: e,
                isSimulated: !0
            });
            C.event.trigger(e, null, t),
            e.isDefaultPrevented() && n.preventDefault()
        }
    },
    C.removeEvent = g.removeEventListener ? function(e, t, n) {
        e.removeEventListener && e.removeEventListener(t, n)
    }
    : function(e, t, n) {
        t = "on" + t;
        e.detachEvent && ("undefined" == typeof e[t] && (e[t] = null),
        e.detachEvent(t, n))
    }
    ,
    C.Event = function(e, t) {
        if (!(this instanceof C.Event))
            return new C.Event(e,t);
        e && e.type ? (this.originalEvent = e,
        this.type = e.type,
        this.isDefaultPrevented = e.defaultPrevented || e.defaultPrevented === undefined && !1 === e.returnValue ? _e : u) : this.type = e,
        t && C.extend(this, t),
        this.timeStamp = e && e.timeStamp || C.now(),
        this[C.expando] = !0
    }
    ,
    C.Event.prototype = {
        constructor: C.Event,
        isDefaultPrevented: u,
        isPropagationStopped: u,
        isImmediatePropagationStopped: u,
        preventDefault: function() {
            var e = this.originalEvent;
            this.isDefaultPrevented = _e,
            e && (e.preventDefault ? e.preventDefault() : e.returnValue = !1)
        },
        stopPropagation: function() {
            var e = this.originalEvent;
            this.isPropagationStopped = _e,
            e && !this.isSimulated && (e.stopPropagation && e.stopPropagation(),
            e.cancelBubble = !0)
        },
        stopImmediatePropagation: function() {
            var e = this.originalEvent;
            this.isImmediatePropagationStopped = _e,
            e && e.stopImmediatePropagation && e.stopImmediatePropagation(),
            this.stopPropagation()
        }
    },
    C.each({
        mouseenter: "mouseover",
        mouseleave: "mouseout",
        pointerenter: "pointerover",
        pointerleave: "pointerout"
    }, function(e, i) {
        C.event.special[e] = {
            delegateType: i,
            bindType: i,
            handle: function(e) {
                var t, n = e.relatedTarget, r = e.handleObj;
                return n && (n === this || C.contains(this, n)) || (e.type = r.origType,
                t = r.handler.apply(this, arguments),
                e.type = i),
                t
            }
        }
    }),
    y.submit || (C.event.special.submit = {
        setup: function() {
            if (C.nodeName(this, "form"))
                return !1;
            C.event.add(this, "click._submit keypress._submit", function(e) {
                e = e.target,
                e = C.nodeName(e, "input") || C.nodeName(e, "button") ? C.prop(e, "form") : undefined;
                e && !C._data(e, "submit") && (C.event.add(e, "submit._submit", function(e) {
                    e._submitBubble = !0
                }),
                C._data(e, "submit", !0))
            })
        },
        postDispatch: function(e) {
            e._submitBubble && (delete e._submitBubble,
            this.parentNode && !e.isTrigger && C.event.simulate("submit", this.parentNode, e))
        },
        teardown: function() {
            if (C.nodeName(this, "form"))
                return !1;
            C.event.remove(this, "._submit")
        }
    }),
    y.change || (C.event.special.change = {
        setup: function() {
            if (De.test(this.nodeName))
                return "checkbox" !== this.type && "radio" !== this.type || (C.event.add(this, "propertychange._change", function(e) {
                    "checked" === e.originalEvent.propertyName && (this._justChanged = !0)
                }),
                C.event.add(this, "click._change", function(e) {
                    this._justChanged && !e.isTrigger && (this._justChanged = !1),
                    C.event.simulate("change", this, e)
                })),
                !1;
            C.event.add(this, "beforeactivate._change", function(e) {
                e = e.target;
                De.test(e.nodeName) && !C._data(e, "change") && (C.event.add(e, "change._change", function(e) {
                    !this.parentNode || e.isSimulated || e.isTrigger || C.event.simulate("change", this.parentNode, e)
                }),
                C._data(e, "change", !0))
            })
        },
        handle: function(e) {
            var t = e.target;
            if (this !== t || e.isSimulated || e.isTrigger || "radio" !== t.type && "checkbox" !== t.type)
                return e.handleObj.handler.apply(this, arguments)
        },
        teardown: function() {
            return C.event.remove(this, "._change"),
            !De.test(this.nodeName)
        }
    }),
    y.focusin || C.each({
        focus: "focusin",
        blur: "focusout"
    }, function(n, r) {
        var i = function(e) {
            C.event.simulate(r, e.target, C.event.fix(e))
        };
        C.event.special[r] = {
            setup: function() {
                var e = this.ownerDocument || this
                  , t = C._data(e, r);
                t || e.addEventListener(n, i, !0),
                C._data(e, r, (t || 0) + 1)
            },
            teardown: function() {
                var e = this.ownerDocument || this
                  , t = C._data(e, r) - 1;
                t ? C._data(e, r, t) : (e.removeEventListener(n, i, !0),
                C._removeData(e, r))
            }
        }
    }),
    C.fn.extend({
        on: function(e, t, n, r) {
            return Me(this, e, t, n, r)
        },
        one: function(e, t, n, r) {
            return Me(this, e, t, n, r, 1)
        },
        off: function(e, t, n) {
            var r, i;
            if (e && e.preventDefault && e.handleObj)
                return r = e.handleObj,
                C(e.delegateTarget).off(r.namespace ? r.origType + "." + r.namespace : r.origType, r.selector, r.handler),
                this;
            if ("object" != typeof e)
                return !1 !== t && "function" != typeof t || (n = t,
                t = undefined),
                !1 === n && (n = u),
                this.each(function() {
                    C.event.remove(this, e, n, t)
                });
            for (i in e)
                this.off(i, t, e[i]);
            return this
        },
        trigger: function(e, t) {
            return this.each(function() {
                C.event.trigger(e, t, this)
            })
        },
        triggerHandler: function(e, t) {
            var n = this[0];
            if (n)
                return C.event.trigger(e, t, n, !0)
        }
    });
    var Oe = / jQuery\d+="(?:null|\d+)"/g
      , Re = new RegExp("<(?:" + xe + ")[\\s/>]","i")
      , Pe = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:-]+)[^>]*)\/>/gi
      , Be = /<script|<style|<link/i
      , We = /checked\s*(?:[^=]|=\s*.checked.)/i
      , Ie = /^true\/(.*)/
      , $e = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g
      , ze = be(g).appendChild(g.createElement("div"));
    function Xe(e, t) {
        return C.nodeName(e, "table") && C.nodeName(11 !== t.nodeType ? t : t.firstChild, "tr") ? e.getElementsByTagName("tbody")[0] || e.appendChild(e.ownerDocument.createElement("tbody")) : e
    }
    function Ue(e) {
        return e.type = (null !== C.find.attr(e, "type")) + "/" + e.type,
        e
    }
    function Ve(e) {
        var t = Ie.exec(e.type);
        return t ? e.type = t[1] : e.removeAttribute("type"),
        e
    }
    function Ye(e, t) {
        if (1 === t.nodeType && C.hasData(e)) {
            var n, r, i, e = C._data(e), o = C._data(t, e), a = e.events;
            if (a)
                for (n in delete o.handle,
                o.events = {},
                a)
                    for (r = 0,
                    i = a[n].length; r < i; r++)
                        C.event.add(t, n, a[n][r]);
            o.data && (o.data = C.extend({}, o.data))
        }
    }
    function w(n, r, i, o) {
        r = O.apply([], r);
        var e, t, a, s, u, l, c = 0, f = n.length, d = f - 1, p = r[0], h = C.isFunction(p);
        if (h || 1 < f && "string" == typeof p && !y.checkClone && We.test(p))
            return n.each(function(e) {
                var t = n.eq(e);
                h && (r[0] = p.call(this, e, t.html())),
                w(t, r, i, o)
            });
        if (f && (e = (l = Ne(r, n[0].ownerDocument, !1, n, o)).firstChild,
        1 === l.childNodes.length && (l = e),
        e || o)) {
            for (a = (s = C.map(b(l, "script"), Ue)).length; c < f; c++)
                t = l,
                c !== d && (t = C.clone(t, !0, !0),
                a && C.merge(s, b(t, "script"))),
                i.call(n[c], t, c);
            if (a)
                for (u = s[s.length - 1].ownerDocument,
                C.map(s, Ve),
                c = 0; c < a; c++)
                    t = s[c],
                    ye.test(t.type || "") && !C._data(t, "globalEval") && C.contains(u, t) && (t.src ? C._evalUrl && C._evalUrl(t.src) : C.globalEval((t.text || t.textContent || t.innerHTML || "").replace($e, "")));
            l = e = null
        }
        return n
    }
    function Je(e, t, n) {
        for (var r, i = t ? C.filter(t, e) : e, o = 0; null != (r = i[o]); o++)
            n || 1 !== r.nodeType || C.cleanData(b(r)),
            r.parentNode && (n && C.contains(r.ownerDocument, r) && we(b(r, "script")),
            r.parentNode.removeChild(r));
        return e
    }
    C.extend({
        htmlPrefilter: function(e) {
            return e.replace(Pe, "<$1></$2>")
        },
        clone: function(e, t, n) {
            var r, i, o, a, s, u = C.contains(e.ownerDocument, e);
            if (y.html5Clone || C.isXMLDoc(e) || !Re.test("<" + e.nodeName + ">") ? o = e.cloneNode(!0) : (ze.innerHTML = e.outerHTML,
            ze.removeChild(o = ze.firstChild)),
            !(y.noCloneEvent && y.noCloneChecked || 1 !== e.nodeType && 11 !== e.nodeType || C.isXMLDoc(e)))
                for (r = b(o),
                s = b(e),
                a = 0; null != (i = s[a]); ++a)
                    if (r[a]) {
                        f = c = l = p = d = void 0;
                        var l, c, f, d = i, p = r[a];
                        if (1 === p.nodeType) {
                            if (l = p.nodeName.toLowerCase(),
                            !y.noCloneEvent && p[C.expando]) {
                                for (c in (f = C._data(p)).events)
                                    C.removeEvent(p, c, f.handle);
                                p.removeAttribute(C.expando)
                            }
                            "script" === l && p.text !== d.text ? (Ue(p).text = d.text,
                            Ve(p)) : "object" === l ? (p.parentNode && (p.outerHTML = d.outerHTML),
                            y.html5Clone && d.innerHTML && !C.trim(p.innerHTML) && (p.innerHTML = d.innerHTML)) : "input" === l && ge.test(d.type) ? (p.defaultChecked = p.checked = d.checked,
                            p.value !== d.value && (p.value = d.value)) : "option" === l ? p.defaultSelected = p.selected = d.defaultSelected : "input" !== l && "textarea" !== l || (p.defaultValue = d.defaultValue)
                        }
                    }
            if (t)
                if (n)
                    for (s = s || b(e),
                    r = r || b(o),
                    a = 0; null != (i = s[a]); a++)
                        Ye(i, r[a]);
                else
                    Ye(e, o);
            return 0 < (r = b(o, "script")).length && we(r, !u && b(e, "script")),
            r = s = i = null,
            o
        },
        cleanData: function(e, t) {
            for (var n, r, i, o, a = 0, s = C.expando, u = C.cache, l = y.attributes, c = C.event.special; null != (n = e[a]); a++)
                if ((t || v(n)) && (o = (i = n[s]) && u[i])) {
                    if (o.events)
                        for (r in o.events)
                            c[r] ? C.event.remove(n, r) : C.removeEvent(n, r, o.handle);
                    u[i] && (delete u[i],
                    l || "undefined" == typeof n.removeAttribute ? n[s] = undefined : n.removeAttribute(s),
                    f.push(i))
                }
        }
    }),
    C.fn.extend({
        domManip: w,
        detach: function(e) {
            return Je(this, e, !0)
        },
        remove: function(e) {
            return Je(this, e)
        },
        text: function(e) {
            return d(this, function(e) {
                return e === undefined ? C.text(this) : this.empty().append((this[0] && this[0].ownerDocument || g).createTextNode(e))
            }, null, e, arguments.length)
        },
        append: function() {
            return w(this, arguments, function(e) {
                1 !== this.nodeType && 11 !== this.nodeType && 9 !== this.nodeType || Xe(this, e).appendChild(e)
            })
        },
        prepend: function() {
            return w(this, arguments, function(e) {
                var t;
                1 !== this.nodeType && 11 !== this.nodeType && 9 !== this.nodeType || (t = Xe(this, e)).insertBefore(e, t.firstChild)
            })
        },
        before: function() {
            return w(this, arguments, function(e) {
                this.parentNode && this.parentNode.insertBefore(e, this)
            })
        },
        after: function() {
            return w(this, arguments, function(e) {
                this.parentNode && this.parentNode.insertBefore(e, this.nextSibling)
            })
        },
        empty: function() {
            for (var e, t = 0; null != (e = this[t]); t++) {
                for (1 === e.nodeType && C.cleanData(b(e, !1)); e.firstChild; )
                    e.removeChild(e.firstChild);
                e.options && C.nodeName(e, "select") && (e.options.length = 0)
            }
            return this
        },
        clone: function(e, t) {
            return e = null != e && e,
            t = null == t ? e : t,
            this.map(function() {
                return C.clone(this, e, t)
            })
        },
        html: function(e) {
            return d(this, function(e) {
                var t = this[0] || {}
                  , n = 0
                  , r = this.length;
                if (e === undefined)
                    return 1 === t.nodeType ? t.innerHTML.replace(Oe, "") : undefined;
                if ("string" == typeof e && !Be.test(e) && (y.htmlSerialize || !Re.test(e)) && (y.leadingWhitespace || !ve.test(e)) && !x[(me.exec(e) || ["", ""])[1].toLowerCase()]) {
                    e = C.htmlPrefilter(e);
                    try {
                        for (; n < r; n++)
                            1 === (t = this[n] || {}).nodeType && (C.cleanData(b(t, !1)),
                            t.innerHTML = e);
                        t = 0
                    } catch (i) {}
                }
                t && this.empty().append(e)
            }, null, e, arguments.length)
        },
        replaceWith: function() {
            var n = [];
            return w(this, arguments, function(e) {
                var t = this.parentNode;
                C.inArray(this, n) < 0 && (C.cleanData(b(this)),
                t && t.replaceChild(e, this))
            }, n)
        }
    }),
    C.each({
        appendTo: "append",
        prependTo: "prepend",
        insertBefore: "before",
        insertAfter: "after",
        replaceAll: "replaceWith"
    }, function(e, a) {
        C.fn[e] = function(e) {
            for (var t, n = 0, r = [], i = C(e), o = i.length - 1; n <= o; n++)
                t = n === o ? this : this.clone(!0),
                C(i[n])[a](t),
                R.apply(r, t.get());
            return this.pushStack(r)
        }
    });
    var Ge, Ke = {
        HTML: "block",
        BODY: "block"
    };
    function Qe(e, t) {
        e = C(t.createElement(e)).appendTo(t.body),
        t = C.css(e[0], "display");
        return e.detach(),
        t
    }
    function Ze(e) {
        var t = g
          , n = Ke[e];
        return n || ("none" !== (n = Qe(e, t)) && n || ((t = ((Ge = (Ge || C("<iframe frameborder='0' width='0' height='0'/>")).appendTo(t.documentElement))[0].contentWindow || Ge[0].contentDocument).document).write(),
        t.close(),
        n = Qe(e, t),
        Ge.detach()),
        Ke[e] = n),
        n
    }
    var n, et, tt, nt, rt, it, ot, a, at = /^margin/, st = new RegExp("^(" + e + ")(?!px)[a-z%]+$","i"), ut = function(e, t, n, r) {
        var i, o = {};
        for (i in t)
            o[i] = e.style[i],
            e.style[i] = t[i];
        for (i in r = n.apply(e, r || []),
        t)
            e.style[i] = o[i];
        return r
    }, lt = g.documentElement;
    function t() {
        var e, t = g.documentElement;
        t.appendChild(ot),
        a.style.cssText = "-webkit-box-sizing:border-box;box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%",
        n = tt = it = !1,
        et = rt = !0,
        T.getComputedStyle && (e = T.getComputedStyle(a),
        n = "1%" !== (e || {}).top,
        it = "2px" === (e || {}).marginLeft,
        tt = "4px" === (e || {
            width: "4px"
        }).width,
        a.style.marginRight = "50%",
        et = "4px" === (e || {
            marginRight: "4px"
        }).marginRight,
        (e = a.appendChild(g.createElement("div"))).style.cssText = a.style.cssText = "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",
        e.style.marginRight = e.style.width = "0",
        a.style.width = "1px",
        rt = !parseFloat((T.getComputedStyle(e) || {}).marginRight),
        a.removeChild(e)),
        a.style.display = "none",
        (nt = 0 === a.getClientRects().length) && (a.style.display = "",
        a.innerHTML = "<table><tr><td></td><td>t</td></tr></table>",
        a.childNodes[0].style.borderCollapse = "separate",
        (e = a.getElementsByTagName("td"))[0].style.cssText = "margin:0;border:0;padding:0;display:none",
        (nt = 0 === e[0].offsetHeight) && (e[0].style.display = "",
        e[1].style.display = "none",
        nt = 0 === e[0].offsetHeight)),
        t.removeChild(ot)
    }
    ot = g.createElement("div"),
    (a = g.createElement("div")).style && (a.style.cssText = "float:left;opacity:.5",
    y.opacity = "0.5" === a.style.opacity,
    y.cssFloat = !!a.style.cssFloat,
    a.style.backgroundClip = "content-box",
    a.cloneNode(!0).style.backgroundClip = "",
    y.clearCloneStyle = "content-box" === a.style.backgroundClip,
    (ot = g.createElement("div")).style.cssText = "border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute",
    a.innerHTML = "",
    ot.appendChild(a),
    y.boxSizing = "" === a.style.boxSizing || "" === a.style.MozBoxSizing || "" === a.style.WebkitBoxSizing,
    C.extend(y, {
        reliableHiddenOffsets: function() {
            return null == n && t(),
            nt
        },
        boxSizingReliable: function() {
            return null == n && t(),
            tt
        },
        pixelMarginRight: function() {
            return null == n && t(),
            et
        },
        pixelPosition: function() {
            return null == n && t(),
            n
        },
        reliableMarginRight: function() {
            return null == n && t(),
            rt
        },
        reliableMarginLeft: function() {
            return null == n && t(),
            it
        }
    }));
    var l, p, ct = /^(top|right|bottom|left)$/;
    function ft(e, t) {
        return {
            get: function() {
                if (!e())
                    return (this.get = t).apply(this, arguments);
                delete this.get
            }
        }
    }
    T.getComputedStyle ? (l = function(e) {
        var t = e.ownerDocument.defaultView;
        return (t = t && t.opener ? t : T).getComputedStyle(e)
    }
    ,
    p = function(e, t, n) {
        var r, i, o = e.style;
        return "" !== (i = (n = n || l(e)) ? n.getPropertyValue(t) || n[t] : undefined) && i !== undefined || C.contains(e.ownerDocument, e) || (i = C.style(e, t)),
        n && !y.pixelMarginRight() && st.test(i) && at.test(t) && (e = o.width,
        t = o.minWidth,
        r = o.maxWidth,
        o.minWidth = o.maxWidth = o.width = i,
        i = n.width,
        o.width = e,
        o.minWidth = t,
        o.maxWidth = r),
        i === undefined ? i : i + ""
    }
    ) : lt.currentStyle && (l = function(e) {
        return e.currentStyle
    }
    ,
    p = function(e, t, n) {
        var r, i, o, a = e.style;
        return null == (n = (n = n || l(e)) ? n[t] : undefined) && a && a[t] && (n = a[t]),
        st.test(n) && !ct.test(t) && (r = a.left,
        (o = (i = e.runtimeStyle) && i.left) && (i.left = e.currentStyle.left),
        a.left = "fontSize" === t ? "1em" : n,
        n = a.pixelLeft + "px",
        a.left = r,
        o && (i.left = o)),
        n === undefined ? n : n + "" || "auto"
    }
    );
    var dt = /alpha\([^)]*\)/i
      , pt = /opacity\s*=\s*([^)]*)/i
      , ht = /^(none|table(?!-c[ea]).+)/
      , gt = new RegExp("^(" + e + ")(.*)$","i")
      , mt = {
        position: "absolute",
        visibility: "hidden",
        display: "block"
    }
      , yt = {
        letterSpacing: "0",
        fontWeight: "400"
    }
      , vt = ["Webkit", "O", "Moz", "ms"]
      , xt = g.createElement("div").style;
    function bt(e) {
        if (e in xt)
            return e;
        for (var t = e.charAt(0).toUpperCase() + e.slice(1), n = vt.length; n--; )
            if ((e = vt[n] + t)in xt)
                return e
    }
    function wt(e, t) {
        for (var n, r, i, o = [], a = 0, s = e.length; a < s; a++)
            (r = e[a]).style && (o[a] = C._data(r, "olddisplay"),
            n = r.style.display,
            t ? (o[a] || "none" !== n || (r.style.display = ""),
            "" === r.style.display && pe(r) && (o[a] = C._data(r, "olddisplay", Ze(r.nodeName)))) : (i = pe(r),
            (n && "none" !== n || !i) && C._data(r, "olddisplay", i ? n : C.css(r, "display"))));
        for (a = 0; a < s; a++)
            !(r = e[a]).style || t && "none" !== r.style.display && "" !== r.style.display || (r.style.display = t ? o[a] || "" : "none");
        return e
    }
    function Tt(e, t, n) {
        var r = gt.exec(t);
        return r ? Math.max(0, r[1] - (n || 0)) + (r[2] || "px") : t
    }
    function Ct(e, t, n, r, i) {
        for (var o = n === (r ? "border" : "content") ? 4 : "width" === t ? 1 : 0, a = 0; o < 4; o += 2)
            "margin" === n && (a += C.css(e, n + s[o], !0, i)),
            r ? ("content" === n && (a -= C.css(e, "padding" + s[o], !0, i)),
            "margin" !== n && (a -= C.css(e, "border" + s[o] + "Width", !0, i))) : (a += C.css(e, "padding" + s[o], !0, i),
            "padding" !== n && (a += C.css(e, "border" + s[o] + "Width", !0, i)));
        return a
    }
    function Et(e, t, n) {
        var r = !0
          , i = "width" === t ? e.offsetWidth : e.offsetHeight
          , o = l(e)
          , a = y.boxSizing && "border-box" === C.css(e, "boxSizing", !1, o);
        if (i <= 0 || null == i) {
            if (((i = p(e, t, o)) < 0 || null == i) && (i = e.style[t]),
            st.test(i))
                return i;
            r = a && (y.boxSizingReliable() || i === e.style[t]),
            i = parseFloat(i) || 0
        }
        return i + Ct(e, t, n || (a ? "border" : "content"), r, o) + "px"
    }
    function h(e, t, n, r, i) {
        return new h.prototype.init(e,t,n,r,i)
    }
    C.extend({
        cssHooks: {
            opacity: {
                get: function(e, t) {
                    if (t)
                        return "" === (t = p(e, "opacity")) ? "1" : t
                }
            }
        },
        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": y.cssFloat ? "cssFloat" : "styleFloat"
        },
        style: function(e, t, n, r) {
            if (e && 3 !== e.nodeType && 8 !== e.nodeType && e.style) {
                var i, o, a, s = C.camelCase(t), u = e.style;
                if (t = C.cssProps[s] || (C.cssProps[s] = bt(s) || s),
                a = C.cssHooks[t] || C.cssHooks[s],
                n === undefined)
                    return a && "get"in a && (i = a.get(e, !1, r)) !== undefined ? i : u[t];
                if ("string" === (o = typeof n) && (i = de.exec(n)) && i[1] && (n = he(e, t, i),
                o = "number"),
                null != n && n == n && ("number" === o && (n += i && i[3] || (C.cssNumber[s] ? "" : "px")),
                y.clearCloneStyle || "" !== n || 0 !== t.indexOf("background") || (u[t] = "inherit"),
                !(a && "set"in a && (n = a.set(e, n, r)) === undefined)))
                    try {
                        u[t] = n
                    } catch (l) {}
            }
        },
        css: function(e, t, n, r) {
            var i, o = C.camelCase(t);
            return t = C.cssProps[o] || (C.cssProps[o] = bt(o) || o),
            "normal" === (i = (i = (o = C.cssHooks[t] || C.cssHooks[o]) && "get"in o ? o.get(e, !0, n) : i) === undefined ? p(e, t, r) : i) && t in yt && (i = yt[t]),
            "" === n || n ? (o = parseFloat(i),
            !0 === n || isFinite(o) ? o || 0 : i) : i
        }
    }),
    C.each(["height", "width"], function(e, i) {
        C.cssHooks[i] = {
            get: function(e, t, n) {
                if (t)
                    return ht.test(C.css(e, "display")) && 0 === e.offsetWidth ? ut(e, mt, function() {
                        return Et(e, i, n)
                    }) : Et(e, i, n)
            },
            set: function(e, t, n) {
                var r = n && l(e);
                return Tt(0, t, n ? Ct(e, i, n, y.boxSizing && "border-box" === C.css(e, "boxSizing", !1, r), r) : 0)
            }
        }
    }),
    y.opacity || (C.cssHooks.opacity = {
        get: function(e, t) {
            return pt.test((t && e.currentStyle ? e.currentStyle : e.style).filter || "") ? .01 * parseFloat(RegExp.$1) + "" : t ? "1" : ""
        },
        set: function(e, t) {
            var n = e.style
              , e = e.currentStyle
              , r = C.isNumeric(t) ? "alpha(opacity=" + 100 * t + ")" : ""
              , i = e && e.filter || n.filter || "";
            ((n.zoom = 1) <= t || "" === t) && "" === C.trim(i.replace(dt, "")) && n.removeAttribute && (n.removeAttribute("filter"),
            "" === t || e && !e.filter) || (n.filter = dt.test(i) ? i.replace(dt, r) : i + " " + r)
        }
    }),
    C.cssHooks.marginRight = ft(y.reliableMarginRight, function(e, t) {
        if (t)
            return ut(e, {
                display: "inline-block"
            }, p, [e, "marginRight"])
    }),
    C.cssHooks.marginLeft = ft(y.reliableMarginLeft, function(e, t) {
        if (t)
            return (parseFloat(p(e, "marginLeft")) || (C.contains(e.ownerDocument, e) ? e.getBoundingClientRect().left - ut(e, {
                marginLeft: 0
            }, function() {
                return e.getBoundingClientRect().left
            }) : 0)) + "px"
    }),
    C.each({
        margin: "",
        padding: "",
        border: "Width"
    }, function(i, o) {
        C.cssHooks[i + o] = {
            expand: function(e) {
                for (var t = 0, n = {}, r = "string" == typeof e ? e.split(" ") : [e]; t < 4; t++)
                    n[i + s[t] + o] = r[t] || r[t - 2] || r[0];
                return n
            }
        },
        at.test(i) || (C.cssHooks[i + o].set = Tt)
    }),
    C.fn.extend({
        css: function(e, t) {
            return d(this, function(e, t, n) {
                var r, i, o = {}, a = 0;
                if (C.isArray(t)) {
                    for (r = l(e),
                    i = t.length; a < i; a++)
                        o[t[a]] = C.css(e, t[a], !1, r);
                    return o
                }
                return n !== undefined ? C.style(e, t, n) : C.css(e, t)
            }, e, t, 1 < arguments.length)
        },
        show: function() {
            return wt(this, !0)
        },
        hide: function() {
            return wt(this)
        },
        toggle: function(e) {
            return "boolean" == typeof e ? e ? this.show() : this.hide() : this.each(function() {
                pe(this) ? C(this).show() : C(this).hide()
            })
        }
    }),
    ((C.Tween = h).prototype = {
        constructor: h,
        init: function(e, t, n, r, i, o) {
            this.elem = e,
            this.prop = n,
            this.easing = i || C.easing._default,
            this.options = t,
            this.start = this.now = this.cur(),
            this.end = r,
            this.unit = o || (C.cssNumber[n] ? "" : "px")
        },
        cur: function() {
            var e = h.propHooks[this.prop];
            return (e && e.get ? e : h.propHooks._default).get(this)
        },
        run: function(e) {
            var t, n = h.propHooks[this.prop];
            return this.options.duration ? this.pos = t = C.easing[this.easing](e, this.options.duration * e, 0, 1, this.options.duration) : this.pos = t = e,
            this.now = (this.end - this.start) * t + this.start,
            this.options.step && this.options.step.call(this.elem, this.now, this),
            (n && n.set ? n : h.propHooks._default).set(this),
            this
        }
    }).init.prototype = h.prototype,
    (h.propHooks = {
        _default: {
            get: function(e) {
                return 1 !== e.elem.nodeType || null != e.elem[e.prop] && null == e.elem.style[e.prop] ? e.elem[e.prop] : (e = C.css(e.elem, e.prop, "")) && "auto" !== e ? e : 0
            },
            set: function(e) {
                C.fx.step[e.prop] ? C.fx.step[e.prop](e) : 1 !== e.elem.nodeType || null == e.elem.style[C.cssProps[e.prop]] && !C.cssHooks[e.prop] ? e.elem[e.prop] = e.now : C.style(e.elem, e.prop, e.now + e.unit)
            }
        }
    }).scrollTop = h.propHooks.scrollLeft = {
        set: function(e) {
            e.elem.nodeType && e.elem.parentNode && (e.elem[e.prop] = e.now)
        }
    },
    C.easing = {
        linear: function(e) {
            return e
        },
        swing: function(e) {
            return .5 - Math.cos(e * Math.PI) / 2
        },
        _default: "swing"
    },
    C.fx = h.prototype.init,
    C.fx.step = {};
    var N, Nt, k, S, kt = /^(?:toggle|show|hide)$/, St = /queueHooks$/;
    function At() {
        return T.setTimeout(function() {
            N = undefined
        }),
        N = C.now()
    }
    function Dt(e, t) {
        var n, r = {
            height: e
        }, i = 0;
        for (t = t ? 1 : 0; i < 4; i += 2 - t)
            r["margin" + (n = s[i])] = r["padding" + n] = e;
        return t && (r.opacity = r.width = e),
        r
    }
    function jt(e, t, n) {
        for (var r, i = (A.tweeners[t] || []).concat(A.tweeners["*"]), o = 0, a = i.length; o < a; o++)
            if (r = i[o].call(n, t, e))
                return r
    }
    function A(i, e, t) {
        var n, o, r, a, s, u, l, c = 0, f = A.prefilters.length, d = C.Deferred().always(function() {
            delete p.elem
        }), p = function() {
            if (o)
                return !1;
            for (var e = N || At(), e = Math.max(0, h.startTime + h.duration - e), t = 1 - (e / h.duration || 0), n = 0, r = h.tweens.length; n < r; n++)
                h.tweens[n].run(t);
            return d.notifyWith(i, [h, t, e]),
            t < 1 && r ? e : (d.resolveWith(i, [h]),
            !1)
        }, h = d.promise({
            elem: i,
            props: C.extend({}, e),
            opts: C.extend(!0, {
                specialEasing: {},
                easing: C.easing._default
            }, t),
            originalProperties: e,
            originalOptions: t,
            startTime: N || At(),
            duration: t.duration,
            tweens: [],
            createTween: function(e, t) {
                t = C.Tween(i, h.opts, e, t, h.opts.specialEasing[e] || h.opts.easing);
                return h.tweens.push(t),
                t
            },
            stop: function(e) {
                var t = 0
                  , n = e ? h.tweens.length : 0;
                if (o)
                    return this;
                for (o = !0; t < n; t++)
                    h.tweens[t].run(1);
                return e ? (d.notifyWith(i, [h, 1, 0]),
                d.resolveWith(i, [h, e])) : d.rejectWith(i, [h, e]),
                this
            }
        }), g = h.props, m = g, y = h.opts.specialEasing;
        for (r in m)
            if (s = y[a = C.camelCase(r)],
            u = m[r],
            C.isArray(u) && (s = u[1],
            u = m[r] = u[0]),
            r !== a && (m[a] = u,
            delete m[r]),
            (l = C.cssHooks[a]) && "expand"in l)
                for (r in u = l.expand(u),
                delete m[a],
                u)
                    r in m || (m[r] = u[r],
                    y[r] = s);
            else
                y[a] = s;
        for (; c < f; c++)
            if (n = A.prefilters[c].call(h, i, g, h.opts))
                return C.isFunction(n.stop) && (C._queueHooks(h.elem, h.opts.queue).stop = C.proxy(n.stop, n)),
                n;
        return C.map(g, jt, h),
        C.isFunction(h.opts.start) && h.opts.start.call(i, h),
        C.fx.timer(C.extend(p, {
            elem: i,
            anim: h,
            queue: h.opts.queue
        })),
        h.progress(h.opts.progress).done(h.opts.done, h.opts.complete).fail(h.opts.fail).always(h.opts.always)
    }
    C.Animation = C.extend(A, {
        tweeners: {
            "*": [function(e, t) {
                var n = this.createTween(e, t);
                return he(n.elem, e, de.exec(t), n),
                n
            }
            ]
        },
        tweener: function(e, t) {
            for (var n, r = 0, i = (e = C.isFunction(e) ? (t = e,
            ["*"]) : e.match(E)).length; r < i; r++)
                n = e[r],
                A.tweeners[n] = A.tweeners[n] || [],
                A.tweeners[n].unshift(t)
        },
        prefilters: [function(t, e, n) {
            var r, i, o, a, s, u, l, c = this, f = {}, d = t.style, p = t.nodeType && pe(t), h = C._data(t, "fxshow");
            for (r in n.queue || (null == (s = C._queueHooks(t, "fx")).unqueued && (s.unqueued = 0,
            u = s.empty.fire,
            s.empty.fire = function() {
                s.unqueued || u()
            }
            ),
            s.unqueued++,
            c.always(function() {
                c.always(function() {
                    s.unqueued--,
                    C.queue(t, "fx").length || s.empty.fire()
                })
            })),
            1 === t.nodeType && ("height"in e || "width"in e) && (n.overflow = [d.overflow, d.overflowX, d.overflowY],
            "inline" === ("none" === (l = C.css(t, "display")) ? C._data(t, "olddisplay") || Ze(t.nodeName) : l) && "none" === C.css(t, "float") && (y.inlineBlockNeedsLayout && "inline" !== Ze(t.nodeName) ? d.zoom = 1 : d.display = "inline-block")),
            n.overflow && (d.overflow = "hidden",
            y.shrinkWrapBlocks() || c.always(function() {
                d.overflow = n.overflow[0],
                d.overflowX = n.overflow[1],
                d.overflowY = n.overflow[2]
            })),
            e)
                if (i = e[r],
                kt.exec(i)) {
                    if (delete e[r],
                    o = o || "toggle" === i,
                    i === (p ? "hide" : "show")) {
                        if ("show" !== i || !h || h[r] === undefined)
                            continue;
                        p = !0
                    }
                    f[r] = h && h[r] || C.style(t, r)
                } else
                    l = undefined;
            if (C.isEmptyObject(f))
                "inline" === ("none" === l ? Ze(t.nodeName) : l) && (d.display = l);
            else
                for (r in h ? "hidden"in h && (p = h.hidden) : h = C._data(t, "fxshow", {}),
                o && (h.hidden = !p),
                p ? C(t).show() : c.done(function() {
                    C(t).hide()
                }),
                c.done(function() {
                    for (var e in C._removeData(t, "fxshow"),
                    f)
                        C.style(t, e, f[e])
                }),
                f)
                    a = jt(p ? h[r] : 0, r, c),
                    r in h || (h[r] = a.start,
                    p && (a.end = a.start,
                    a.start = "width" === r || "height" === r ? 1 : 0))
        }
        ],
        prefilter: function(e, t) {
            t ? A.prefilters.unshift(e) : A.prefilters.push(e)
        }
    }),
    C.speed = function(e, t, n) {
        var r = e && "object" == typeof e ? C.extend({}, e) : {
            complete: n || !n && t || C.isFunction(e) && e,
            duration: e,
            easing: n && t || t && !C.isFunction(t) && t
        };
        return r.duration = C.fx.off ? 0 : "number" == typeof r.duration ? r.duration : r.duration in C.fx.speeds ? C.fx.speeds[r.duration] : C.fx.speeds._default,
        null != r.queue && !0 !== r.queue || (r.queue = "fx"),
        r.old = r.complete,
        r.complete = function() {
            C.isFunction(r.old) && r.old.call(this),
            r.queue && C.dequeue(this, r.queue)
        }
        ,
        r
    }
    ,
    C.fn.extend({
        fadeTo: function(e, t, n, r) {
            return this.filter(pe).css("opacity", 0).show().end().animate({
                opacity: t
            }, e, n, r)
        },
        animate: function(t, e, n, r) {
            var i = C.isEmptyObject(t)
              , o = C.speed(e, n, r)
              , e = function() {
                var e = A(this, C.extend({}, t), o);
                (i || C._data(this, "finish")) && e.stop(!0)
            };
            return e.finish = e,
            i || !1 === o.queue ? this.each(e) : this.queue(o.queue, e)
        },
        stop: function(i, e, o) {
            var a = function(e) {
                var t = e.stop;
                delete e.stop,
                t(o)
            };
            return "string" != typeof i && (o = e,
            e = i,
            i = undefined),
            e && !1 !== i && this.queue(i || "fx", []),
            this.each(function() {
                var e = !0
                  , t = null != i && i + "queueHooks"
                  , n = C.timers
                  , r = C._data(this);
                if (t)
                    r[t] && r[t].stop && a(r[t]);
                else
                    for (t in r)
                        r[t] && r[t].stop && St.test(t) && a(r[t]);
                for (t = n.length; t--; )
                    n[t].elem !== this || null != i && n[t].queue !== i || (n[t].anim.stop(o),
                    e = !1,
                    n.splice(t, 1));
                !e && o || C.dequeue(this, i)
            })
        },
        finish: function(a) {
            return !1 !== a && (a = a || "fx"),
            this.each(function() {
                var e, t = C._data(this), n = t[a + "queue"], r = t[a + "queueHooks"], i = C.timers, o = n ? n.length : 0;
                for (t.finish = !0,
                C.queue(this, a, []),
                r && r.stop && r.stop.call(this, !0),
                e = i.length; e--; )
                    i[e].elem === this && i[e].queue === a && (i[e].anim.stop(!0),
                    i.splice(e, 1));
                for (e = 0; e < o; e++)
                    n[e] && n[e].finish && n[e].finish.call(this);
                delete t.finish
            })
        }
    }),
    C.each(["toggle", "show", "hide"], function(e, r) {
        var i = C.fn[r];
        C.fn[r] = function(e, t, n) {
            return null == e || "boolean" == typeof e ? i.apply(this, arguments) : this.animate(Dt(r, !0), e, t, n)
        }
    }),
    C.each({
        slideDown: Dt("show"),
        slideUp: Dt("hide"),
        slideToggle: Dt("toggle"),
        fadeIn: {
            opacity: "show"
        },
        fadeOut: {
            opacity: "hide"
        },
        fadeToggle: {
            opacity: "toggle"
        }
    }, function(e, r) {
        C.fn[e] = function(e, t, n) {
            return this.animate(r, e, t, n)
        }
    }),
    C.timers = [],
    C.fx.tick = function() {
        var e, t = C.timers, n = 0;
        for (N = C.now(); n < t.length; n++)
            (e = t[n])() || t[n] !== e || t.splice(n--, 1);
        t.length || C.fx.stop(),
        N = undefined
    }
    ,
    C.fx.timer = function(e) {
        C.timers.push(e),
        e() ? C.fx.start() : C.timers.pop()
    }
    ,
    C.fx.interval = 13,
    C.fx.start = function() {
        Nt = Nt || T.setInterval(C.fx.tick, C.fx.interval)
    }
    ,
    C.fx.stop = function() {
        T.clearInterval(Nt),
        Nt = null
    }
    ,
    C.fx.speeds = {
        slow: 600,
        fast: 200,
        _default: 400
    },
    C.fn.delay = function(r, e) {
        return r = C.fx && C.fx.speeds[r] || r,
        this.queue(e = e || "fx", function(e, t) {
            var n = T.setTimeout(e, r);
            t.stop = function() {
                T.clearTimeout(n)
            }
        })
    }
    ,
    k = g.createElement("input"),
    q = g.createElement("div"),
    S = g.createElement("select"),
    e = S.appendChild(g.createElement("option")),
    (q = g.createElement("div")).setAttribute("className", "t"),
    q.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
    F = q.getElementsByTagName("a")[0],
    k.setAttribute("type", "checkbox"),
    q.appendChild(k),
    (F = q.getElementsByTagName("a")[0]).style.cssText = "top:1px",
    y.getSetAttribute = "t" !== q.className,
    y.style = /top/.test(F.getAttribute("style")),
    y.hrefNormalized = "/a" === F.getAttribute("href"),
    y.checkOn = !!k.value,
    y.optSelected = e.selected,
    y.enctype = !!g.createElement("form").enctype,
    S.disabled = !0,
    y.optDisabled = !e.disabled,
    (k = g.createElement("input")).setAttribute("value", ""),
    y.input = "" === k.getAttribute("value"),
    k.value = "t",
    k.setAttribute("type", "radio"),
    y.radioValue = "t" === k.value;
    var Lt = /\r/g
      , Ht = /[\x20\t\r\n\f]+/g;
    C.fn.extend({
        val: function(t) {
            var n, e, r, i = this[0];
            return arguments.length ? (r = C.isFunction(t),
            this.each(function(e) {
                1 === this.nodeType && (null == (e = r ? t.call(this, e, C(this).val()) : t) ? e = "" : "number" == typeof e ? e += "" : C.isArray(e) && (e = C.map(e, function(e) {
                    return null == e ? "" : e + ""
                })),
                (n = C.valHooks[this.type] || C.valHooks[this.nodeName.toLowerCase()]) && "set"in n && n.set(this, e, "value") !== undefined || (this.value = e))
            })) : i ? (n = C.valHooks[i.type] || C.valHooks[i.nodeName.toLowerCase()]) && "get"in n && (e = n.get(i, "value")) !== undefined ? e : "string" == typeof (e = i.value) ? e.replace(Lt, "") : null == e ? "" : e : void 0
        }
    }),
    C.extend({
        valHooks: {
            option: {
                get: function(e) {
                    var t = C.find.attr(e, "value");
                    return null != t ? t : C.trim(C.text(e)).replace(Ht, " ")
                }
            },
            select: {
                get: function(e) {
                    for (var t, n = e.options, r = e.selectedIndex, i = "select-one" === e.type || r < 0, o = i ? null : [], a = i ? r + 1 : n.length, s = r < 0 ? a : i ? r : 0; s < a; s++)
                        if (((t = n[s]).selected || s === r) && (y.optDisabled ? !t.disabled : null === t.getAttribute("disabled")) && (!t.parentNode.disabled || !C.nodeName(t.parentNode, "optgroup"))) {
                            if (t = C(t).val(),
                            i)
                                return t;
                            o.push(t)
                        }
                    return o
                },
                set: function(e, t) {
                    for (var n, r, i = e.options, o = C.makeArray(t), a = i.length; a--; )
                        if (r = i[a],
                        -1 < C.inArray(C.valHooks.option.get(r), o))
                            try {
                                r.selected = n = !0
                            } catch (s) {
                                r.scrollHeight
                            }
                        else
                            r.selected = !1;
                    return n || (e.selectedIndex = -1),
                    i
                }
            }
        }
    }),
    C.each(["radio", "checkbox"], function() {
        C.valHooks[this] = {
            set: function(e, t) {
                if (C.isArray(t))
                    return e.checked = -1 < C.inArray(C(e).val(), t)
            }
        },
        y.checkOn || (C.valHooks[this].get = function(e) {
            return null === e.getAttribute("value") ? "on" : e.value
        }
        )
    });
    var D, qt, j = C.expr.attrHandle, _t = /^(?:checked|selected)$/i, L = y.getSetAttribute, Ft = y.input, Mt = (C.fn.extend({
        attr: function(e, t) {
            return d(this, C.attr, e, t, 1 < arguments.length)
        },
        removeAttr: function(e) {
            return this.each(function() {
                C.removeAttr(this, e)
            })
        }
    }),
    C.extend({
        attr: function(e, t, n) {
            var r, i, o = e.nodeType;
            if (3 !== o && 8 !== o && 2 !== o)
                return "undefined" == typeof e.getAttribute ? C.prop(e, t, n) : (1 === o && C.isXMLDoc(e) || (t = t.toLowerCase(),
                i = C.attrHooks[t] || (C.expr.match.bool.test(t) ? qt : D)),
                n !== undefined ? null === n ? void C.removeAttr(e, t) : i && "set"in i && (r = i.set(e, n, t)) !== undefined ? r : (e.setAttribute(t, n + ""),
                n) : !(i && "get"in i && null !== (r = i.get(e, t))) && null == (r = C.find.attr(e, t)) ? undefined : r)
        },
        attrHooks: {
            type: {
                set: function(e, t) {
                    var n;
                    if (!y.radioValue && "radio" === t && C.nodeName(e, "input"))
                        return n = e.value,
                        e.setAttribute("type", t),
                        n && (e.value = n),
                        t
                }
            }
        },
        removeAttr: function(e, t) {
            var n, r, i = 0, o = t && t.match(E);
            if (o && 1 === e.nodeType)
                for (; n = o[i++]; )
                    r = C.propFix[n] || n,
                    C.expr.match.bool.test(n) ? Ft && L || !_t.test(n) ? e[r] = !1 : e[C.camelCase("default-" + n)] = e[r] = !1 : C.attr(e, n, ""),
                    e.removeAttribute(L ? n : r)
        }
    }),
    qt = {
        set: function(e, t, n) {
            return !1 === t ? C.removeAttr(e, n) : Ft && L || !_t.test(n) ? e.setAttribute(!L && C.propFix[n] || n, n) : e[C.camelCase("default-" + n)] = e[n] = !0,
            n
        }
    },
    C.each(C.expr.match.bool.source.match(/\w+/g), function(e, t) {
        var o = j[t] || C.find.attr;
        Ft && L || !_t.test(t) ? j[t] = function(e, t, n) {
            var r, i;
            return n || (i = j[t],
            j[t] = r,
            r = null != o(e, t, n) ? t.toLowerCase() : null,
            j[t] = i),
            r
        }
        : j[t] = function(e, t, n) {
            if (!n)
                return e[C.camelCase("default-" + t)] ? t.toLowerCase() : null
        }
    }),
    Ft && L || (C.attrHooks.value = {
        set: function(e, t, n) {
            if (!C.nodeName(e, "input"))
                return D && D.set(e, t, n);
            e.defaultValue = t
        }
    }),
    L || (D = {
        set: function(e, t, n) {
            var r = e.getAttributeNode(n);
            if (r || e.setAttributeNode(r = e.ownerDocument.createAttribute(n)),
            r.value = t += "",
            "value" === n || t === e.getAttribute(n))
                return t
        }
    },
    j.id = j.name = j.coords = function(e, t, n) {
        if (!n)
            return (n = e.getAttributeNode(t)) && "" !== n.value ? n.value : null
    }
    ,
    C.valHooks.button = {
        get: function(e, t) {
            t = e.getAttributeNode(t);
            if (t && t.specified)
                return t.value
        },
        set: D.set
    },
    C.attrHooks.contenteditable = {
        set: function(e, t, n) {
            D.set(e, "" !== t && t, n)
        }
    },
    C.each(["width", "height"], function(e, n) {
        C.attrHooks[n] = {
            set: function(e, t) {
                if ("" === t)
                    return e.setAttribute(n, "auto"),
                    t
            }
        }
    })),
    y.style || (C.attrHooks.style = {
        get: function(e) {
            return e.style.cssText || undefined
        },
        set: function(e, t) {
            return e.style.cssText = t + ""
        }
    }),
    /^(?:input|select|textarea|button|object)$/i), Ot = /^(?:a|area)$/i, Rt = (C.fn.extend({
        prop: function(e, t) {
            return d(this, C.prop, e, t, 1 < arguments.length)
        },
        removeProp: function(t) {
            return t = C.propFix[t] || t,
            this.each(function() {
                try {
                    this[t] = undefined,
                    delete this[t]
                } catch (e) {}
            })
        }
    }),
    C.extend({
        prop: function(e, t, n) {
            var r, i, o = e.nodeType;
            if (3 !== o && 8 !== o && 2 !== o)
                return 1 === o && C.isXMLDoc(e) || (t = C.propFix[t] || t,
                i = C.propHooks[t]),
                n !== undefined ? i && "set"in i && (r = i.set(e, n, t)) !== undefined ? r : e[t] = n : i && "get"in i && null !== (r = i.get(e, t)) ? r : e[t]
        },
        propHooks: {
            tabIndex: {
                get: function(e) {
                    var t = C.find.attr(e, "tabindex");
                    return t ? parseInt(t, 10) : Mt.test(e.nodeName) || Ot.test(e.nodeName) && e.href ? 0 : -1
                }
            }
        },
        propFix: {
            "for": "htmlFor",
            "class": "className"
        }
    }),
    y.hrefNormalized || C.each(["href", "src"], function(e, t) {
        C.propHooks[t] = {
            get: function(e) {
                return e.getAttribute(t, 4)
            }
        }
    }),
    y.optSelected || (C.propHooks.selected = {
        get: function(e) {
            e = e.parentNode;
            return e && (e.selectedIndex,
            e.parentNode && e.parentNode.selectedIndex),
            null
        },
        set: function(e) {
            e = e.parentNode;
            e && (e.selectedIndex,
            e.parentNode && e.parentNode.selectedIndex)
        }
    }),
    C.each(["tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable"], function() {
        C.propFix[this.toLowerCase()] = this
    }),
    y.enctype || (C.propFix.enctype = "encoding"),
    /[\t\r\n\f]/g);
    function H(e) {
        return C.attr(e, "class") || ""
    }
    C.fn.extend({
        addClass: function(t) {
            var e, n, r, i, o, a, s = 0;
            if (C.isFunction(t))
                return this.each(function(e) {
                    C(this).addClass(t.call(this, e, H(this)))
                });
            if ("string" == typeof t && t)
                for (e = t.match(E) || []; n = this[s++]; )
                    if (a = H(n),
                    r = 1 === n.nodeType && (" " + a + " ").replace(Rt, " ")) {
                        for (o = 0; i = e[o++]; )
                            r.indexOf(" " + i + " ") < 0 && (r += i + " ");
                        a !== (a = C.trim(r)) && C.attr(n, "class", a)
                    }
            return this
        },
        removeClass: function(t) {
            var e, n, r, i, o, a, s = 0;
            if (C.isFunction(t))
                return this.each(function(e) {
                    C(this).removeClass(t.call(this, e, H(this)))
                });
            if (!arguments.length)
                return this.attr("class", "");
            if ("string" == typeof t && t)
                for (e = t.match(E) || []; n = this[s++]; )
                    if (a = H(n),
                    r = 1 === n.nodeType && (" " + a + " ").replace(Rt, " ")) {
                        for (o = 0; i = e[o++]; )
                            for (; -1 < r.indexOf(" " + i + " "); )
                                r = r.replace(" " + i + " ", " ");
                        a !== (a = C.trim(r)) && C.attr(n, "class", a)
                    }
            return this
        },
        toggleClass: function(i, t) {
            var o = typeof i;
            return "boolean" == typeof t && "string" == o ? t ? this.addClass(i) : this.removeClass(i) : C.isFunction(i) ? this.each(function(e) {
                C(this).toggleClass(i.call(this, e, H(this), t), t)
            }) : this.each(function() {
                var e, t, n, r;
                if ("string" == o)
                    for (t = 0,
                    n = C(this),
                    r = i.match(E) || []; e = r[t++]; )
                        n.hasClass(e) ? n.removeClass(e) : n.addClass(e);
                else
                    i !== undefined && "boolean" != o || ((e = H(this)) && C._data(this, "__className__", e),
                    C.attr(this, "class", !e && !1 !== i && C._data(this, "__className__") || ""))
            })
        },
        hasClass: function(e) {
            for (var t, n = 0, r = " " + e + " "; t = this[n++]; )
                if (1 === t.nodeType && -1 < (" " + H(t) + " ").replace(Rt, " ").indexOf(r))
                    return !0;
            return !1
        }
    }),
    C.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "), function(e, n) {
        C.fn[n] = function(e, t) {
            return 0 < arguments.length ? this.on(n, null, e, t) : this.trigger(n)
        }
    }),
    C.fn.extend({
        hover: function(e, t) {
            return this.mouseenter(e).mouseleave(t || e)
        }
    });
    var q = T.location
      , Pt = C.now()
      , Bt = /\?/
      , Wt = /(,)|(\[|{)|(}|])|"(?:[^"\\\r\n]|\\["\\\/bfnrt]|\\u[\da-fA-F]{4})*"\s*:?|true|false|null|-?(?!0\d)\d+(?:\.\d+|)(?:[eE][+-]?\d+|)/g
      , It = (C.parseJSON = function(e) {
        if (T.JSON && T.JSON.parse)
            return T.JSON.parse(e + "");
        var i, o = null, t = C.trim(e + "");
        return t && !C.trim(t.replace(Wt, function(e, t, n, r) {
            return 0 === (o = i && t ? 0 : o) ? e : (i = n || t,
            o += !r - !n,
            "")
        })) ? Function("return " + t)() : C.error("Invalid JSON: " + e)
    }
    ,
    C.parseXML = function(e) {
        var t;
        if (!e || "string" != typeof e)
            return null;
        try {
            T.DOMParser ? t = (new T.DOMParser).parseFromString(e, "text/xml") : ((t = new T.ActiveXObject("Microsoft.XMLDOM"))["async"] = "false",
            t.loadXML(e))
        } catch (n) {
            t = undefined
        }
        return t && t.documentElement && !t.getElementsByTagName("parsererror").length || C.error("Invalid XML: " + e),
        t
    }
    ,
    /#.*$/)
      , $t = /([?&])_=[^&]*/
      , zt = /^(.*?):[ \t]*([^\r\n]*)\r?$/gm
      , Xt = /^(?:GET|HEAD)$/
      , Ut = /^\/\//
      , Vt = /^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/
      , Yt = {}
      , Jt = {}
      , Gt = "*/".concat("*")
      , Kt = q.href
      , _ = Vt.exec(Kt.toLowerCase()) || [];
    function Qt(o) {
        return function(e, t) {
            "string" != typeof e && (t = e,
            e = "*");
            var n, r = 0, i = e.toLowerCase().match(E) || [];
            if (C.isFunction(t))
                for (; n = i[r++]; )
                    "+" === n.charAt(0) ? (n = n.slice(1) || "*",
                    (o[n] = o[n] || []).unshift(t)) : (o[n] = o[n] || []).push(t)
        }
    }
    function Zt(t, r, i, o) {
        var a = {}
          , s = t === Jt;
        function u(e) {
            var n;
            return a[e] = !0,
            C.each(t[e] || [], function(e, t) {
                t = t(r, i, o);
                return "string" != typeof t || s || a[t] ? s ? !(n = t) : void 0 : (r.dataTypes.unshift(t),
                u(t),
                !1)
            }),
            n
        }
        return u(r.dataTypes[0]) || !a["*"] && u("*")
    }
    function en(e, t) {
        var n, r, i = C.ajaxSettings.flatOptions || {};
        for (r in t)
            t[r] !== undefined && ((i[r] ? e : n = n || {})[r] = t[r]);
        return n && C.extend(!0, e, n),
        e
    }
    function tn(e, t, n, r) {
        var i, o, a, s, u, l = {}, c = e.dataTypes.slice();
        if (c[1])
            for (a in e.converters)
                l[a.toLowerCase()] = e.converters[a];
        for (o = c.shift(); o; )
            if (e.responseFields[o] && (n[e.responseFields[o]] = t),
            !u && r && e.dataFilter && (t = e.dataFilter(t, e.dataType)),
            u = o,
            o = c.shift())
                if ("*" === o)
                    o = u;
                else if ("*" !== u && u !== o) {
                    if (!(a = l[u + " " + o] || l["* " + o]))
                        for (i in l)
                            if ((s = i.split(" "))[1] === o && (a = l[u + " " + s[0]] || l["* " + s[0]])) {
                                !0 === a ? a = l[i] : !0 !== l[i] && (o = s[0],
                                c.unshift(s[1]));
                                break
                            }
                    if (!0 !== a)
                        if (a && e["throws"])
                            t = a(t);
                        else
                            try {
                                t = a(t)
                            } catch (f) {
                                return {
                                    state: "parsererror",
                                    error: a ? f : "No conversion from " + u + " to " + o
                                }
                            }
                }
        return {
            state: "success",
            data: t
        }
    }
    function nn(e) {
        if (!C.contains(e.ownerDocument || g, e))
            return !0;
        for (; e && 1 === e.nodeType; ) {
            if ("none" === ((t = e).style && t.style.display || C.css(t, "display")) || "hidden" === e.type)
                return !0;
            e = e.parentNode
        }
        var t;
        return !1
    }
    C.extend({
        active: 0,
        lastModified: {},
        etag: {},
        ajaxSettings: {
            url: Kt,
            type: "GET",
            isLocal: /^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(_[1]),
            global: !0,
            processData: !0,
            "async": !0,
            contentType: "application/x-www-form-urlencoded; charset=UTF-8",
            accepts: {
                "*": Gt,
                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": C.parseJSON,
                "text xml": C.parseXML
            },
            flatOptions: {
                url: !0,
                context: !0
            }
        },
        ajaxSetup: function(e, t) {
            return t ? en(en(e, C.ajaxSettings), t) : en(C.ajaxSettings, e)
        },
        ajaxPrefilter: Qt(Yt),
        ajaxTransport: Qt(Jt),
        ajax: function(e, t) {
            "object" == typeof e && (t = e,
            e = undefined);
            var n, u, l, c, f, d, r, p = C.ajaxSetup({}, t = t || {}), h = p.context || p, g = p.context && (h.nodeType || h.jquery) ? C(h) : C.event, m = C.Deferred(), y = C.Callbacks("once memory"), v = p.statusCode || {}, i = {}, o = {}, x = 0, a = "canceled", b = {
                readyState: 0,
                getResponseHeader: function(e) {
                    var t;
                    if (2 === x) {
                        if (!r)
                            for (r = {}; t = zt.exec(l); )
                                r[t[1].toLowerCase()] = t[2];
                        t = r[e.toLowerCase()]
                    }
                    return null == t ? null : t
                },
                getAllResponseHeaders: function() {
                    return 2 === x ? l : null
                },
                setRequestHeader: function(e, t) {
                    var n = e.toLowerCase();
                    return x || (e = o[n] = o[n] || e,
                    i[e] = t),
                    this
                },
                overrideMimeType: function(e) {
                    return x || (p.mimeType = e),
                    this
                },
                statusCode: function(e) {
                    if (e)
                        if (x < 2)
                            for (var t in e)
                                v[t] = [v[t], e[t]];
                        else
                            b.always(e[b.status]);
                    return this
                },
                abort: function(e) {
                    e = e || a;
                    return d && d.abort(e),
                    s(0, e),
                    this
                }
            };
            if (m.promise(b).complete = y.add,
            b.success = b.done,
            b.error = b.fail,
            p.url = ((e || p.url || Kt) + "").replace(It, "").replace(Ut, _[1] + "//"),
            p.type = t.method || t.type || p.method || p.type,
            p.dataTypes = C.trim(p.dataType || "*").toLowerCase().match(E) || [""],
            null == p.crossDomain && (e = Vt.exec(p.url.toLowerCase()),
            p.crossDomain = !(!e || e[1] === _[1] && e[2] === _[2] && (e[3] || ("http:" === e[1] ? "80" : "443")) === (_[3] || ("http:" === _[1] ? "80" : "443")))),
            p.data && p.processData && "string" != typeof p.data && (p.data = C.param(p.data, p.traditional)),
            Zt(Yt, p, t, b),
            2 === x)
                return b;
            for (n in (f = C.event && p.global) && 0 == C.active++ && C.event.trigger("ajaxStart"),
            p.type = p.type.toUpperCase(),
            p.hasContent = !Xt.test(p.type),
            u = p.url,
            p.hasContent || (p.data && (u = p.url += (Bt.test(u) ? "&" : "?") + p.data,
            delete p.data),
            !1 === p.cache && (p.url = $t.test(u) ? u.replace($t, "$1_=" + Pt++) : u + (Bt.test(u) ? "&" : "?") + "_=" + Pt++)),
            p.ifModified && (C.lastModified[u] && b.setRequestHeader("If-Modified-Since", C.lastModified[u]),
            C.etag[u] && b.setRequestHeader("If-None-Match", C.etag[u])),
            (p.data && p.hasContent && !1 !== p.contentType || t.contentType) && b.setRequestHeader("Content-Type", p.contentType),
            b.setRequestHeader("Accept", p.dataTypes[0] && p.accepts[p.dataTypes[0]] ? p.accepts[p.dataTypes[0]] + ("*" !== p.dataTypes[0] ? ", " + Gt + "; q=0.01" : "") : p.accepts["*"]),
            p.headers)
                b.setRequestHeader(n, p.headers[n]);
            if (p.beforeSend && (!1 === p.beforeSend.call(h, b, p) || 2 === x))
                return b.abort();
            for (n in a = "abort",
            {
                success: 1,
                error: 1,
                complete: 1
            })
                b[n](p[n]);
            if (d = Zt(Jt, p, t, b)) {
                if (b.readyState = 1,
                f && g.trigger("ajaxSend", [b, p]),
                2 === x)
                    return b;
                p["async"] && 0 < p.timeout && (c = T.setTimeout(function() {
                    b.abort("timeout")
                }, p.timeout));
                try {
                    x = 1,
                    d.send(i, s)
                } catch (w) {
                    if (!(x < 2))
                        throw w;
                    s(-1, w)
                }
            } else
                s(-1, "No Transport");
            function s(e, t, n, r) {
                var i, o, a, s = t;
                2 !== x && (x = 2,
                c && T.clearTimeout(c),
                d = undefined,
                l = r || "",
                b.readyState = 0 < e ? 4 : 0,
                r = 200 <= e && e < 300 || 304 === e,
                n && (a = function(e, t, n) {
                    for (var r, i, o, a, s = e.contents, u = e.dataTypes; "*" === u[0]; )
                        u.shift(),
                        i === undefined && (i = e.mimeType || t.getResponseHeader("Content-Type"));
                    if (i)
                        for (a in s)
                            if (s[a] && s[a].test(i)) {
                                u.unshift(a);
                                break
                            }
                    if (u[0]in n)
                        o = u[0];
                    else {
                        for (a in n) {
                            if (!u[0] || e.converters[a + " " + u[0]]) {
                                o = a;
                                break
                            }
                            r = r || a
                        }
                        o = o || r
                    }
                    if (o)
                        return o !== u[0] && u.unshift(o),
                        n[o]
                }(p, b, n)),
                a = tn(p, a, b, r),
                r ? (p.ifModified && ((n = b.getResponseHeader("Last-Modified")) && (C.lastModified[u] = n),
                (n = b.getResponseHeader("etag")) && (C.etag[u] = n)),
                204 === e || "HEAD" === p.type ? s = "nocontent" : 304 === e ? s = "notmodified" : (s = a.state,
                i = a.data,
                r = !(o = a.error))) : (o = s,
                !e && s || (s = "error",
                e < 0 && (e = 0))),
                b.status = e,
                b.statusText = (t || s) + "",
                r ? m.resolveWith(h, [i, s, b]) : m.rejectWith(h, [b, s, o]),
                b.statusCode(v),
                v = undefined,
                f && g.trigger(r ? "ajaxSuccess" : "ajaxError", [b, p, r ? i : o]),
                y.fireWith(h, [b, s]),
                f && (g.trigger("ajaxComplete", [b, p]),
                --C.active || C.event.trigger("ajaxStop")))
            }
            return b
        },
        getJSON: function(e, t, n) {
            return C.get(e, t, n, "json")
        },
        getScript: function(e, t) {
            return C.get(e, undefined, t, "script")
        }
    }),
    C.each(["get", "post"], function(e, i) {
        C[i] = function(e, t, n, r) {
            return C.isFunction(t) && (r = r || n,
            n = t,
            t = undefined),
            C.ajax(C.extend({
                url: e,
                type: i,
                dataType: r,
                data: t,
                success: n
            }, C.isPlainObject(e) && e))
        }
    }),
    C._evalUrl = function(e) {
        return C.ajax({
            url: e,
            type: "GET",
            dataType: "script",
            cache: !0,
            "async": !1,
            global: !1,
            "throws": !0
        })
    }
    ,
    C.fn.extend({
        wrapAll: function(t) {
            return C.isFunction(t) ? this.each(function(e) {
                C(this).wrapAll(t.call(this, e))
            }) : (this[0] && (e = C(t, this[0].ownerDocument).eq(0).clone(!0),
            this[0].parentNode && e.insertBefore(this[0]),
            e.map(function() {
                for (var e = this; e.firstChild && 1 === e.firstChild.nodeType; )
                    e = e.firstChild;
                return e
            }).append(this)),
            this);
            var e
        },
        wrapInner: function(n) {
            return C.isFunction(n) ? this.each(function(e) {
                C(this).wrapInner(n.call(this, e))
            }) : this.each(function() {
                var e = C(this)
                  , t = e.contents();
                t.length ? t.wrapAll(n) : e.append(n)
            })
        },
        wrap: function(t) {
            var n = C.isFunction(t);
            return this.each(function(e) {
                C(this).wrapAll(n ? t.call(this, e) : t)
            })
        },
        unwrap: function() {
            return this.parent().each(function() {
                C.nodeName(this, "body") || C(this).replaceWith(this.childNodes)
            }).end()
        }
    }),
    C.expr.filters.hidden = function(e) {
        return y.reliableHiddenOffsets() ? e.offsetWidth <= 0 && e.offsetHeight <= 0 && !e.getClientRects().length : nn(e)
    }
    ,
    C.expr.filters.visible = function(e) {
        return !C.expr.filters.hidden(e)
    }
    ;
    var rn = /%20/g
      , on = /\[\]$/
      , an = /\r?\n/g
      , sn = /^(?:submit|button|image|reset|file)$/i
      , un = /^(?:input|select|textarea|keygen)/i;
    C.param = function(e, t) {
        var n, r = [], i = function(e, t) {
            t = C.isFunction(t) ? t() : null == t ? "" : t,
            r[r.length] = encodeURIComponent(e) + "=" + encodeURIComponent(t)
        };
        if (t === undefined && (t = C.ajaxSettings && C.ajaxSettings.traditional),
        C.isArray(e) || e.jquery && !C.isPlainObject(e))
            C.each(e, function() {
                i(this.name, this.value)
            });
        else
            for (n in e)
                !function o(n, e, r, i) {
                    if (C.isArray(e))
                        C.each(e, function(e, t) {
                            r || on.test(n) ? i(n, t) : o(n + "[" + ("object" == typeof t && null != t ? e : "") + "]", t, r, i)
                        });
                    else if (r || "object" !== C.type(e))
                        i(n, e);
                    else
                        for (var t in e)
                            o(n + "[" + t + "]", e[t], r, i)
                }(n, e[n], t, i);
        return r.join("&").replace(rn, "+")
    }
    ,
    C.fn.extend({
        serialize: function() {
            return C.param(this.serializeArray())
        },
        serializeArray: function() {
            return this.map(function() {
                var e = C.prop(this, "elements");
                return e ? C.makeArray(e) : this
            }).filter(function() {
                var e = this.type;
                return this.name && !C(this).is(":disabled") && un.test(this.nodeName) && !sn.test(e) && (this.checked || !ge.test(e))
            }).map(function(e, t) {
                var n = C(this).val();
                return null == n ? null : C.isArray(n) ? C.map(n, function(e) {
                    return {
                        name: t.name,
                        value: e.replace(an, "\r\n")
                    }
                }) : {
                    name: t.name,
                    value: n.replace(an, "\r\n")
                }
            }).get()
        }
    }),
    C.ajaxSettings.xhr = T.ActiveXObject !== undefined ? function() {
        return this.isLocal ? dn() : 8 < g.documentMode ? fn() : /^(get|post|head|put|delete|options)$/i.test(this.type) && fn() || dn()
    }
    : fn;
    var ln = 0
      , cn = {}
      , F = C.ajaxSettings.xhr();
    function fn() {
        try {
            return new T.XMLHttpRequest
        } catch (e) {}
    }
    function dn() {
        try {
            return new T.ActiveXObject("Microsoft.XMLHTTP")
        } catch (e) {}
    }
    T.attachEvent && T.attachEvent("onunload", function() {
        for (var e in cn)
            cn[e](undefined, !0)
    }),
    y.cors = !!F && "withCredentials"in F,
    (F = y.ajax = !!F) && C.ajaxTransport(function(l) {
        var c;
        if (!l.crossDomain || y.cors)
            return {
                send: function(e, a) {
                    var t, s = l.xhr(), u = ++ln;
                    if (s.open(l.type, l.url, l["async"], l.username, l.password),
                    l.xhrFields)
                        for (t in l.xhrFields)
                            s[t] = l.xhrFields[t];
                    for (t in l.mimeType && s.overrideMimeType && s.overrideMimeType(l.mimeType),
                    l.crossDomain || e["X-Requested-With"] || (e["X-Requested-With"] = "XMLHttpRequest"),
                    e)
                        e[t] !== undefined && s.setRequestHeader(t, e[t] + "");
                    s.send(l.hasContent && l.data || null),
                    c = function(e, t) {
                        var n, r, i;
                        if (c && (t || 4 === s.readyState))
                            if (delete cn[u],
                            c = undefined,
                            s.onreadystatechange = C.noop,
                            t)
                                4 !== s.readyState && s.abort();
                            else {
                                i = {},
                                n = s.status,
                                "string" == typeof s.responseText && (i.text = s.responseText);
                                try {
                                    r = s.statusText
                                } catch (o) {
                                    r = ""
                                }
                                n || !l.isLocal || l.crossDomain ? 1223 === n && (n = 204) : n = i.text ? 200 : 404
                            }
                        i && a(n, r, i, s.getAllResponseHeaders())
                    }
                    ,
                    l["async"] ? 4 === s.readyState ? T.setTimeout(c) : s.onreadystatechange = cn[u] = c : c()
                },
                abort: function() {
                    c && c(undefined, !0)
                }
            }
    }),
    C.ajaxSetup({
        accepts: {
            script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"
        },
        contents: {
            script: /\b(?:java|ecma)script\b/
        },
        converters: {
            "text script": function(e) {
                return C.globalEval(e),
                e
            }
        }
    }),
    C.ajaxPrefilter("script", function(e) {
        e.cache === undefined && (e.cache = !1),
        e.crossDomain && (e.type = "GET",
        e.global = !1)
    }),
    C.ajaxTransport("script", function(t) {
        var r, i;
        if (t.crossDomain)
            return i = g.head || C("head")[0] || g.documentElement,
            {
                send: function(e, n) {
                    (r = g.createElement("script"))["async"] = !0,
                    t.scriptCharset && (r.charset = t.scriptCharset),
                    r.src = t.url,
                    r.onload = r.onreadystatechange = function(e, t) {
                        !t && r.readyState && !/loaded|complete/.test(r.readyState) || (r.onload = r.onreadystatechange = null,
                        r.parentNode && r.parentNode.removeChild(r),
                        r = null,
                        t || n(200, "success"))
                    }
                    ,
                    i.insertBefore(r, i.firstChild)
                },
                abort: function() {
                    r && r.onload(undefined, !0)
                }
            }
    });
    var pn = []
      , hn = /(=)\?(?=&|$)|\?\?/
      , gn = (C.ajaxSetup({
        jsonp: "callback",
        jsonpCallback: function() {
            var e = pn.pop() || C.expando + "_" + Pt++;
            return this[e] = !0,
            e
        }
    }),
    C.ajaxPrefilter("json jsonp", function(e, t, n) {
        var r, i, o, a = !1 !== e.jsonp && (hn.test(e.url) ? "url" : "string" == typeof e.data && 0 === (e.contentType || "").indexOf("application/x-www-form-urlencoded") && hn.test(e.data) && "data");
        if (a || "jsonp" === e.dataTypes[0])
            return r = e.jsonpCallback = C.isFunction(e.jsonpCallback) ? e.jsonpCallback() : e.jsonpCallback,
            a ? e[a] = e[a].replace(hn, "$1" + r) : !1 !== e.jsonp && (e.url += (Bt.test(e.url) ? "&" : "?") + e.jsonp + "=" + r),
            e.converters["script json"] = function() {
                return o || C.error(r + " was not called"),
                o[0]
            }
            ,
            e.dataTypes[0] = "json",
            i = T[r],
            T[r] = function() {
                o = arguments
            }
            ,
            n.always(function() {
                i === undefined ? C(T).removeProp(r) : T[r] = i,
                e[r] && (e.jsonpCallback = t.jsonpCallback,
                pn.push(r)),
                o && C.isFunction(i) && i(o[0]),
                o = i = undefined
            }),
            "script"
    }),
    C.parseHTML = function(e, t, n) {
        if (!e || "string" != typeof e)
            return null;
        "boolean" == typeof t && (n = t,
        t = !1),
        t = t || g;
        var r = J.exec(e)
          , n = !n && [];
        return r ? [t.createElement(r[1])] : (r = Ne([e], t, n),
        n && n.length && C(n).remove(),
        C.merge([], r.childNodes))
    }
    ,
    C.fn.load);
    function mn(e) {
        return C.isWindow(e) ? e : 9 === e.nodeType && (e.defaultView || e.parentWindow)
    }
    return C.fn.load = function(e, t, n) {
        if ("string" != typeof e && gn)
            return gn.apply(this, arguments);
        var r, i, o, a = this, s = e.indexOf(" ");
        return -1 < s && (r = C.trim(e.slice(s, e.length)),
        e = e.slice(0, s)),
        C.isFunction(t) ? (n = t,
        t = undefined) : t && "object" == typeof t && (i = "POST"),
        0 < a.length && C.ajax({
            url: e,
            type: i || "GET",
            dataType: "html",
            data: t
        }).done(function(e) {
            o = arguments,
            a.html(r ? C("<div>").append(C.parseHTML(e)).find(r) : e)
        }).always(n && function(e, t) {
            a.each(function() {
                n.apply(this, o || [e.responseText, t, e])
            })
        }
        ),
        this
    }
    ,
    C.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"], function(e, t) {
        C.fn[t] = function(e) {
            return this.on(t, e)
        }
    }),
    C.expr.filters.animated = function(t) {
        return C.grep(C.timers, function(e) {
            return t === e.elem
        }).length
    }
    ,
    C.offset = {
        setOffset: function(e, t, n) {
            var r, i, o, a, s = C.css(e, "position"), u = C(e), l = {};
            "static" === s && (e.style.position = "relative"),
            o = u.offset(),
            r = C.css(e, "top"),
            a = C.css(e, "left"),
            s = ("absolute" === s || "fixed" === s) && -1 < C.inArray("auto", [r, a]) ? (i = (s = u.position()).top,
            s.left) : (i = parseFloat(r) || 0,
            parseFloat(a) || 0),
            null != (t = C.isFunction(t) ? t.call(e, n, C.extend({}, o)) : t).top && (l.top = t.top - o.top + i),
            null != t.left && (l.left = t.left - o.left + s),
            "using"in t ? t.using.call(e, l) : u.css(l)
        }
    },
    C.fn.extend({
        offset: function(t) {
            if (arguments.length)
                return t === undefined ? this : this.each(function(e) {
                    C.offset.setOffset(this, t, e)
                });
            var e, n = {
                top: 0,
                left: 0
            }, r = this[0], i = r && r.ownerDocument;
            return i ? (e = i.documentElement,
            C.contains(e, r) ? ("undefined" != typeof r.getBoundingClientRect && (n = r.getBoundingClientRect()),
            r = mn(i),
            {
                top: n.top + (r.pageYOffset || e.scrollTop) - (e.clientTop || 0),
                left: n.left + (r.pageXOffset || e.scrollLeft) - (e.clientLeft || 0)
            }) : n) : void 0
        },
        position: function() {
            var e, t, n, r;
            if (this[0])
                return n = {
                    top: 0,
                    left: 0
                },
                r = this[0],
                "fixed" === C.css(r, "position") ? t = r.getBoundingClientRect() : (e = this.offsetParent(),
                t = this.offset(),
                (n = C.nodeName(e[0], "html") ? n : e.offset()).top += C.css(e[0], "borderTopWidth", !0),
                n.left += C.css(e[0], "borderLeftWidth", !0)),
                {
                    top: t.top - n.top - C.css(r, "marginTop", !0),
                    left: t.left - n.left - C.css(r, "marginLeft", !0)
                }
        },
        offsetParent: function() {
            return this.map(function() {
                for (var e = this.offsetParent; e && !C.nodeName(e, "html") && "static" === C.css(e, "position"); )
                    e = e.offsetParent;
                return e || lt
            })
        }
    }),
    C.each({
        scrollLeft: "pageXOffset",
        scrollTop: "pageYOffset"
    }, function(t, i) {
        var o = /Y/.test(i);
        C.fn[t] = function(e) {
            return d(this, function(e, t, n) {
                var r = mn(e);
                if (n === undefined)
                    return r ? i in r ? r[i] : r.document.documentElement[t] : e[t];
                r ? r.scrollTo(o ? C(r).scrollLeft() : n, o ? n : C(r).scrollTop()) : e[t] = n
            }, t, e, arguments.length, null)
        }
    }),
    C.each(["top", "left"], function(e, n) {
        C.cssHooks[n] = ft(y.pixelPosition, function(e, t) {
            if (t)
                return t = p(e, n),
                st.test(t) ? C(e).position()[n] + "px" : t
        })
    }),
    C.each({
        Height: "height",
        Width: "width"
    }, function(o, a) {
        C.each({
            padding: "inner" + o,
            content: a,
            "": "outer" + o
        }, function(r, e) {
            C.fn[e] = function(e, t) {
                var n = arguments.length && (r || "boolean" != typeof e)
                  , i = r || (!0 === e || !0 === t ? "margin" : "border");
                return d(this, function(e, t, n) {
                    var r;
                    return C.isWindow(e) ? e.document.documentElement["client" + o] : 9 === e.nodeType ? (r = e.documentElement,
                    Math.max(e.body["scroll" + o], r["scroll" + o], e.body["offset" + o], r["offset" + o], r["client" + o])) : n === undefined ? C.css(e, t, i) : C.style(e, t, n, i)
                }, a, n ? e : undefined, n, null)
            }
        })
    }),
    C.fn.extend({
        bind: function(e, t, n) {
            return this.on(e, null, t, n)
        },
        unbind: function(e, t) {
            return this.off(e, null, t)
        },
        delegate: function(e, t, n, r) {
            return this.on(t, e, n, r)
        },
        undelegate: function(e, t, n) {
            return 1 === arguments.length ? this.off(e, "**") : this.off(t, e || "**", n)
        }
    }),
    C.fn.size = function() {
        return this.length
    }
    ,
    C.fn.andSelf = C.fn.addBack,
    layui.define(function(e) {
        e("jquery", layui.$ = C)
    }),
    C
});
!function(p) {
    "use strict";
    var h, f, e, n = p.layui && layui.define, c = {
        getPath: (e = document.currentScript ? document.currentScript.src : function() {
            for (var e, t = document.scripts, i = t.length - 1, n = i; 0 < n; n--)
                if ("interactive" === t[n].readyState) {
                    e = t[n].src;
                    break
                }
            return e || t[i].src
        }(),
        (p.LAYUI_GLOBAL || {}).layer_dir || e.substring(0, e.lastIndexOf("/") + 1)),
        config: {},
        end: {},
        minIndex: 0,
        minLeft: [],
        btn: ["&#x786E;&#x5B9A;", "&#x53D6;&#x6D88;"],
        type: ["dialog", "page", "iframe", "loading", "tips"],
        getStyle: function(e, t) {
            e = e.currentStyle || p.getComputedStyle(e, null);
            return e[e.getPropertyValue ? "getPropertyValue" : "getAttribute"](t)
        },
        link: function(e, i, t) {
            var n, a, o, s, r, l;
            m.path && (n = document.getElementsByTagName("head")[0],
            a = document.createElement("link"),
            o = ((t = "string" == typeof i ? i : t) || e).replace(/\.|\//g, ""),
            s = "layuicss-" + o,
            r = "creating",
            l = 0,
            a.rel = "stylesheet",
            a.href = m.path + e,
            a.id = s,
            document.getElementById(s) || n.appendChild(a),
            "function" == typeof i && function f(e) {
                var t = document.getElementById(s);
                return 100 < ++l ? p.console && console.error(o + ".css: Invalid") : void (1989 === parseInt(c.getStyle(t, "width")) ? (e === r && t.removeAttribute("lay-status"),
                t.getAttribute("lay-status") === r ? setTimeout(f, 100) : i()) : (t.setAttribute("lay-status", r),
                setTimeout(function() {
                    f(r)
                }, 100)))
            }())
        }
    }, m = {
        v: "3.5.1",
        ie: (e = navigator.userAgent.toLowerCase(),
        !!(p.ActiveXObject || "ActiveXObject"in p) && ((e.match(/msie\s(\d+)/) || [])[1] || "11")),
        index: p.layer && p.layer.v ? 1e5 : 0,
        path: c.getPath,
        config: function(e, t) {
            return m.cache = c.config = h.extend({}, c.config, e = e || {}),
            m.path = c.config.path || m.path,
            "string" == typeof e.extend && (e.extend = [e.extend]),
            c.config.path && m.ready(),
            e.extend && (n ? layui.addcss("modules/layer/" + e.extend) : c.link("theme/" + e.extend)),
            this
        },
        ready: function(e) {
            var t = "layer"
              , i = (n ? "modules/layer/" : "theme/") + "default/layer.css?v=" + m.v;
            return n ? layui.addcss(i, e, t) : c.link(i, e, t),
            this
        },
        alert: function(e, t, i) {
            var n = "function" == typeof t;
            return m.open(h.extend({
                content: e,
                yes: i = n ? t : i
            }, n ? {} : t))
        },
        confirm: function(e, t, i, n) {
            var a = "function" == typeof t;
            return a && (n = i,
            i = t),
            m.open(h.extend({
                content: e,
                btn: c.btn,
                yes: i,
                btn2: n
            }, a ? {} : t))
        },
        msg: function(e, t, i) {
            var n = "function" == typeof t
              , a = c.config.skin
              , a = (a ? a + " " + a + "-msg" : "") || "layui-layer-msg"
              , o = d.anim.length - 1;
            return n && (i = t),
            m.open(h.extend({
                content: e,
                time: 3e3,
                shade: !1,
                skin: a,
                title: !1,
                closeBtn: !1,
                btn: !1,
                resize: !1,
                end: i
            }, n && !c.config.skin ? {
                skin: a + " layui-layer-hui",
                anim: o
            } : (-1 !== (t = t || {}).icon && (void 0 !== t.icon || c.config.skin) || (t.skin = a + " " + (t.skin || "layui-layer-hui")),
            t)))
        },
        load: function(e, t) {
            return m.open(h.extend({
                type: 3,
                icon: e || 0,
                resize: !1,
                shade: .01
            }, t))
        },
        tips: function(e, t, i) {
            return m.open(h.extend({
                type: 4,
                content: [e, t],
                closeBtn: !1,
                time: 3e3,
                shade: !1,
                resize: !1,
                fixed: !1,
                maxWidth: 260
            }, i))
        }
    }, t = function(e) {
        var t = this
          , i = function() {
            t.creat()
        };
        t.index = ++m.index,
        t.config.maxWidth = h(f).width() - 30,
        t.config = h.extend({}, t.config, c.config, e),
        document.body ? i() : setTimeout(function() {
            i()
        }, 30)
    }, d = (t.pt = t.prototype,
    ["layui-layer", ".layui-layer-title", ".layui-layer-main", ".layui-layer-dialog", "layui-layer-iframe", "layui-layer-content", "layui-layer-btn", "layui-layer-close"]), i = (d.anim = ["layer-anim-00", "layer-anim-01", "layer-anim-02", "layer-anim-03", "layer-anim-04", "layer-anim-05", "layer-anim-06"],
    d.SHADE = "layui-layer-shade",
    d.MOVE = "layui-layer-move",
    t.pt.config = {
        type: 0,
        shade: .3,
        fixed: !0,
        move: d[1],
        title: "&#x4FE1;&#x606F;",
        offset: "auto",
        area: "auto",
        closeBtn: 1,
        time: 0,
        zIndex: 19891014,
        maxWidth: 360,
        anim: 0,
        isOutAnim: !0,
        minStack: !0,
        icon: -1,
        moveType: 1,
        resize: !0,
        scrollbar: !0,
        tips: 2
    },
    t.pt.vessel = function(e, t) {
        var i = this.index
          , n = this.config
          , a = n.zIndex + i
          , o = "object" == typeof n.title
          , s = n.maxmin && (1 === n.type || 2 === n.type)
          , o = n.title ? '<div class="layui-layer-title" style="' + (o ? n.title[1] : "") + '">' + (o ? n.title[0] : n.title) + "</div>" : "";
        return n.zIndex = a,
        t([n.shade ? '<div class="' + d.SHADE + '" id="' + d.SHADE + i + '" times="' + i + '" style="z-index:' + (a - 1) + '; "></div>' : "", '<div class="' + d[0] + " layui-layer-" + c.type[n.type] + (0 != n.type && 2 != n.type || n.shade ? "" : " layui-layer-border") + " " + (n.skin || "") + '" id="' + d[0] + i + '" type="' + c.type[n.type] + '" times="' + i + '" showtime="' + n.time + '" conType="' + (e ? "object" : "string") + '" style="z-index: ' + a + "; width:" + n.area[0] + ";height:" + n.area[1] + ";position:" + (n.fixed ? "fixed;" : "absolute;") + '">' + (e && 2 != n.type ? "" : o) + '<div id="' + (n.id || "") + '" class="layui-layer-content' + (0 == n.type && -1 !== n.icon ? " layui-layer-padding" : "") + (3 == n.type ? " layui-layer-loading" + n.icon : "") + '">' + (0 == n.type && -1 !== n.icon ? '<i class="layui-layer-ico layui-layer-ico' + n.icon + '"></i>' : "") + ((1 != n.type || !e) && n.content || "") + '</div><span class="layui-layer-setwin">' + (i = s ? '<a class="layui-layer-min" href="javascript:;"><cite></cite></a><a class="layui-layer-ico layui-layer-max" href="javascript:;"></a>' : "",
        n.closeBtn && (i += '<a class="layui-layer-ico ' + d[7] + " " + d[7] + (n.title ? n.closeBtn : 4 == n.type ? "1" : "2") + '" href="javascript:;"></a>'),
        i) + "</span>" + (n.btn ? function() {
            var e = "";
            "string" == typeof n.btn && (n.btn = [n.btn]);
            for (var t = 0, i = n.btn.length; t < i; t++)
                e += '<a class="' + d[6] + t + '">' + n.btn[t] + "</a>";
            return '<div class="' + d[6] + " layui-layer-btn-" + (n.btnAlign || "") + '">' + e + "</div>"
        }() : "") + (n.resize ? '<span class="layui-layer-resize"></span>' : "") + "</div>"], o, h('<div class="' + d.MOVE + '" id="' + d.MOVE + '"></div>')),
        this
    }
    ,
    t.pt.creat = function() {
        var e, n = this, a = n.config, o = n.index, s = "object" == typeof (l = a.content), r = h("body");
        if (!a.id || !h("#" + a.id)[0]) {
            switch ("string" == typeof a.area && (a.area = "auto" === a.area ? ["", ""] : [a.area, ""]),
            a.shift && (a.anim = a.shift),
            6 == m.ie && (a.fixed = !1),
            a.type) {
            case 0:
                a.btn = "btn"in a ? a.btn : c.btn[0],
                m.closeAll("dialog");
                break;
            case 2:
                var l = a.content = s ? a.content : [a.content || "", "auto"];
                a.content = '<iframe scrolling="' + (a.content[1] || "auto") + '" allowtransparency="true" id="' + d[4] + o + '" name="' + d[4] + o + '" onload="this.className=\'\';" class="layui-layer-load" frameborder="0" src="' + a.content[0] + '"></iframe>';
                break;
            case 3:
                delete a.title,
                delete a.closeBtn,
                -1 === a.icon && a.icon,
                m.closeAll("loading");
                break;
            case 4:
                s || (a.content = [a.content, "body"]),
                a.follow = a.content[1],
                a.content = a.content[0] + '<i class="layui-layer-TipsG"></i>',
                delete a.title,
                a.tips = "object" == typeof a.tips ? a.tips : [a.tips, !0],
                a.tipsMore || m.closeAll("tips")
            }
            n.vessel(s, function(e, t, i) {
                r.append(e[0]),
                s ? 2 == a.type || 4 == a.type ? h("body").append(e[1]) : l.parents("." + d[0])[0] || (l.data("display", l.css("display")).show().addClass("layui-layer-wrap").wrap(e[1]),
                h("#" + d[0] + o).find("." + d[5]).before(t)) : r.append(e[1]),
                h("#" + d.MOVE)[0] || r.append(c.moveElem = i),
                n.layero = h("#" + d[0] + o),
                n.shadeo = h("#" + d.SHADE + o),
                a.scrollbar || d.html.css("overflow", "hidden").attr("layer-full", o)
            }).auto(o),
            n.shadeo.css({
                "background-color": a.shade[1] || "#000",
                opacity: a.shade[0] || a.shade
            }),
            2 == a.type && 6 == m.ie && n.layero.find("iframe").attr("src", l[0]),
            4 == a.type ? n.tips() : (n.offset(),
            parseInt(c.getStyle(document.getElementById(d.MOVE), "z-index")) || (n.layero.css("visibility", "hidden"),
            m.ready(function() {
                n.offset(),
                n.layero.css("visibility", "visible")
            }))),
            a.fixed && f.on("resize", function() {
                n.offset(),
                (/^\d+%$/.test(a.area[0]) || /^\d+%$/.test(a.area[1])) && n.auto(o),
                4 == a.type && n.tips()
            }),
            a.time <= 0 || setTimeout(function() {
                m.close(n.index)
            }, a.time),
            n.move().callback(),
            d.anim[a.anim] && (e = "layer-anim " + d.anim[a.anim],
            n.layero.addClass(e).one("webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend", function() {
                h(this).removeClass(e)
            })),
            a.isOutAnim && n.layero.data("isOutAnim", !0)
        }
    }
    ,
    t.pt.auto = function(e) {
        var t = this.config
          , i = h("#" + d[0] + e)
          , n = ("" === t.area[0] && 0 < t.maxWidth && (m.ie && m.ie < 8 && t.btn && i.width(i.innerWidth()),
        i.outerWidth() > t.maxWidth && i.width(t.maxWidth)),
        [i.innerWidth(), i.innerHeight()])
          , a = i.find(d[1]).outerHeight() || 0
          , o = i.find("." + d[6]).outerHeight() || 0
          , e = function(e) {
            (e = i.find(e)).height(n[1] - a - o - 2 * (0 | parseFloat(e.css("padding-top"))))
        };
        return 2 === t.type ? e("iframe") : "" === t.area[1] ? 0 < t.maxHeight && i.outerHeight() > t.maxHeight ? (n[1] = t.maxHeight,
        e("." + d[5])) : t.fixed && n[1] >= f.height() && (n[1] = f.height(),
        e("." + d[5])) : e("." + d[5]),
        this
    }
    ,
    t.pt.offset = function() {
        var e = this
          , t = e.config
          , i = e.layero
          , n = [i.outerWidth(), i.outerHeight()]
          , a = "object" == typeof t.offset;
        e.offsetTop = (f.height() - n[1]) / 2,
        e.offsetLeft = (f.width() - n[0]) / 2,
        a ? (e.offsetTop = t.offset[0],
        e.offsetLeft = t.offset[1] || e.offsetLeft) : "auto" !== t.offset && ("t" === t.offset ? e.offsetTop = 0 : "r" === t.offset ? e.offsetLeft = f.width() - n[0] : "b" === t.offset ? e.offsetTop = f.height() - n[1] : "l" === t.offset ? e.offsetLeft = 0 : "lt" === t.offset ? (e.offsetTop = 0,
        e.offsetLeft = 0) : "lb" === t.offset ? (e.offsetTop = f.height() - n[1],
        e.offsetLeft = 0) : "rt" === t.offset ? (e.offsetTop = 0,
        e.offsetLeft = f.width() - n[0]) : "rb" === t.offset ? (e.offsetTop = f.height() - n[1],
        e.offsetLeft = f.width() - n[0]) : e.offsetTop = t.offset),
        t.fixed || (e.offsetTop = /%$/.test(e.offsetTop) ? f.height() * parseFloat(e.offsetTop) / 100 : parseFloat(e.offsetTop),
        e.offsetLeft = /%$/.test(e.offsetLeft) ? f.width() * parseFloat(e.offsetLeft) / 100 : parseFloat(e.offsetLeft),
        e.offsetTop += f.scrollTop(),
        e.offsetLeft += f.scrollLeft()),
        i.attr("minLeft") && (e.offsetTop = f.height() - (i.find(d[1]).outerHeight() || 0),
        e.offsetLeft = i.css("left")),
        i.css({
            top: e.offsetTop,
            left: e.offsetLeft
        })
    }
    ,
    t.pt.tips = function() {
        var e = this.config
          , t = this.layero
          , i = [t.outerWidth(), t.outerHeight()]
          , n = h(e.follow)
          , a = {
            width: (n = n[0] ? n : h("body")).outerWidth(),
            height: n.outerHeight(),
            top: n.offset().top,
            left: n.offset().left
        }
          , o = t.find(".layui-layer-TipsG")
          , n = e.tips[0];
        e.tips[1] || o.remove(),
        a.autoLeft = function() {
            0 < a.left + i[0] - f.width() ? (a.tipLeft = a.left + a.width - i[0],
            o.css({
                right: 12,
                left: "auto"
            })) : a.tipLeft = a.left
        }
        ,
        a.where = [function() {
            a.autoLeft(),
            a.tipTop = a.top - i[1] - 10,
            o.removeClass("layui-layer-TipsB").addClass("layui-layer-TipsT").css("border-right-color", e.tips[1])
        }
        , function() {
            a.tipLeft = a.left + a.width + 10,
            a.tipTop = a.top,
            o.removeClass("layui-layer-TipsL").addClass("layui-layer-TipsR").css("border-bottom-color", e.tips[1])
        }
        , function() {
            a.autoLeft(),
            a.tipTop = a.top + a.height + 10,
            o.removeClass("layui-layer-TipsT").addClass("layui-layer-TipsB").css("border-right-color", e.tips[1])
        }
        , function() {
            a.tipLeft = a.left - i[0] - 10,
            a.tipTop = a.top,
            o.removeClass("layui-layer-TipsR").addClass("layui-layer-TipsL").css("border-bottom-color", e.tips[1])
        }
        ],
        a.where[n - 1](),
        1 === n ? a.top - (f.scrollTop() + i[1] + 16) < 0 && a.where[2]() : 2 === n ? 0 < f.width() - (a.left + a.width + i[0] + 16) || a.where[3]() : 3 === n ? 0 < a.top - f.scrollTop() + a.height + i[1] + 16 - f.height() && a.where[0]() : 4 === n && 0 < i[0] + 16 - a.left && a.where[1](),
        t.find("." + d[5]).css({
            "background-color": e.tips[1],
            "padding-right": e.closeBtn ? "30px" : ""
        }),
        t.css({
            left: a.tipLeft - (e.fixed ? f.scrollLeft() : 0),
            top: a.tipTop - (e.fixed ? f.scrollTop() : 0)
        })
    }
    ,
    t.pt.move = function() {
        var o = this
          , s = o.config
          , e = h(document)
          , r = o.layero
          , t = r.find(s.move)
          , i = r.find(".layui-layer-resize")
          , l = {};
        return s.move && t.css("cursor", "move"),
        t.on("mousedown", function(e) {
            e.preventDefault(),
            s.move && (l.moveStart = !0,
            l.offset = [e.clientX - parseFloat(r.css("left")), e.clientY - parseFloat(r.css("top"))],
            c.moveElem.css("cursor", "move").show())
        }),
        i.on("mousedown", function(e) {
            e.preventDefault(),
            l.resizeStart = !0,
            l.offset = [e.clientX, e.clientY],
            l.area = [r.outerWidth(), r.outerHeight()],
            c.moveElem.css("cursor", "se-resize").show()
        }),
        e.on("mousemove", function(e) {
            var t, i, n, a;
            l.moveStart && (n = e.clientX - l.offset[0],
            a = e.clientY - l.offset[1],
            t = "fixed" === r.css("position"),
            e.preventDefault(),
            l.stX = t ? 0 : f.scrollLeft(),
            l.stY = t ? 0 : f.scrollTop(),
            s.moveOut || (t = f.width() - r.outerWidth() + l.stX,
            i = f.height() - r.outerHeight() + l.stY,
            t < (n = n < l.stX ? l.stX : n) && (n = t),
            i < (a = a < l.stY ? l.stY : a) && (a = i)),
            r.css({
                left: n,
                top: a
            })),
            s.resize && l.resizeStart && (n = e.clientX - l.offset[0],
            a = e.clientY - l.offset[1],
            e.preventDefault(),
            m.style(o.index, {
                width: l.area[0] + n,
                height: l.area[1] + a
            }),
            l.isResize = !0,
            s.resizing && s.resizing(r))
        }).on("mouseup", function(e) {
            l.moveStart && (delete l.moveStart,
            c.moveElem.hide(),
            s.moveEnd && s.moveEnd(r)),
            l.resizeStart && (delete l.resizeStart,
            c.moveElem.hide())
        }),
        o
    }
    ,
    t.pt.callback = function() {
        var t = this
          , i = t.layero
          , n = t.config;
        t.openLayer(),
        n.success && (2 == n.type ? i.find("iframe").on("load", function() {
            n.success(i, t.index, t)
        }) : n.success(i, t.index, t)),
        6 == m.ie && t.IE6(i),
        i.find("." + d[6]).children("a").on("click", function() {
            var e = h(this).index();
            0 === e ? n.yes ? n.yes(t.index, i) : n.btn1 ? n.btn1(t.index, i) : m.close(t.index) : !1 !== (n["btn" + (e + 1)] && n["btn" + (e + 1)](t.index, i)) && m.close(t.index)
        }),
        i.find("." + d[7]).on("click", function() {
            !1 !== (n.cancel && n.cancel(t.index, i)) && m.close(t.index)
        }),
        n.shadeClose && t.shadeo.on("click", function() {
            m.close(t.index)
        }),
        i.find(".layui-layer-min").on("click", function() {
            !1 !== (n.min && n.min(i, t.index)) && m.min(t.index, n)
        }),
        i.find(".layui-layer-max").on("click", function() {
            h(this).hasClass("layui-layer-maxmin") ? (m.restore(t.index),
            n.restore && n.restore(i, t.index)) : (m.full(t.index, n),
            setTimeout(function() {
                n.full && n.full(i, t.index)
            }, 100))
        }),
        n.end && (c.end[t.index] = n.end)
    }
    ,
    c.reselect = function() {
        h.each(h("select"), function(e, t) {
            var i = h(this);
            i.parents("." + d[0])[0] || 1 == i.attr("layer") && h("." + d[0]).length < 1 && i.removeAttr("layer").show()
        })
    }
    ,
    t.pt.IE6 = function(e) {
        h("select").each(function(e, t) {
            var i = h(this);
            i.parents("." + d[0])[0] || "none" !== i.css("display") && i.attr({
                layer: "1"
            }).hide()
        })
    }
    ,
    t.pt.openLayer = function() {
        m.zIndex = this.config.zIndex,
        m.setTop = function(e) {
            return m.zIndex = parseInt(e[0].style.zIndex),
            e.on("mousedown", function() {
                m.zIndex++,
                e.css("z-index", m.zIndex + 1)
            }),
            m.zIndex
        }
    }
    ,
    c.record = function(e) {
        var t = [e.width(), e.height(), e.position().top, e.position().left + parseFloat(e.css("margin-left"))];
        e.find(".layui-layer-max").addClass("layui-layer-maxmin"),
        e.attr({
            area: t
        })
    }
    ,
    c.rescollbar = function(e) {
        d.html.attr("layer-full") == e && (d.html[0].style.removeProperty ? d.html[0].style.removeProperty("overflow") : d.html[0].style.removeAttribute("overflow"),
        d.html.removeAttr("layer-full"))
    }
    ,
    (p.layer = m).getChildFrame = function(e, t) {
        return t = t || h("." + d[4]).attr("times"),
        h("#" + d[0] + t).find("iframe").contents().find(e)
    }
    ,
    m.getFrameIndex = function(e) {
        return h("#" + e).parents("." + d[4]).attr("times")
    }
    ,
    m.iframeAuto = function(e) {
        var t, i, n;
        e && (t = m.getChildFrame("html", e).outerHeight(),
        i = (e = h("#" + d[0] + e)).find(d[1]).outerHeight() || 0,
        n = e.find("." + d[6]).outerHeight() || 0,
        e.css({
            height: t + i + n
        }),
        e.find("iframe").css({
            height: t
        }))
    }
    ,
    m.iframeSrc = function(e, t) {
        h("#" + d[0] + e).find("iframe").attr("src", t)
    }
    ,
    m.style = function(e, t, i) {
        var e = h("#" + d[0] + e)
          , n = e.find(".layui-layer-content")
          , a = e.attr("type")
          , o = e.find(d[1]).outerHeight() || 0
          , s = e.find("." + d[6]).outerHeight() || 0;
        e.attr("minLeft");
        a !== c.type[3] && a !== c.type[4] && (i || (parseFloat(t.width) <= 260 && (t.width = 260),
        parseFloat(t.height) - o - s <= 64 && (t.height = 64 + o + s)),
        e.css(t),
        s = e.find("." + d[6]).outerHeight() || 0,
        a === c.type[2] ? e.find("iframe").css({
            height: parseFloat(t.height) - o - s
        }) : n.css({
            height: parseFloat(t.height) - o - s - parseFloat(n.css("padding-top")) - parseFloat(n.css("padding-bottom"))
        }))
    }
    ,
    m.min = function(e, t) {
        t = t || {};
        var i = h("#" + d[0] + e)
          , n = h("#" + d.SHADE + e)
          , a = i.find(d[1]).outerHeight() || 0
          , o = i.attr("minLeft") || 181 * c.minIndex + "px"
          , s = i.css("position")
          , r = {
            width: 180,
            height: a,
            position: "fixed",
            overflow: "hidden"
        };
        c.record(i),
        c.minLeft[0] && (o = c.minLeft[0],
        c.minLeft.shift()),
        t.minStack && (r.left = o,
        r.top = f.height() - a,
        i.attr("minLeft") || c.minIndex++,
        i.attr("minLeft", o)),
        i.attr("position", s),
        m.style(e, r, !0),
        i.find(".layui-layer-min").hide(),
        "page" === i.attr("type") && i.find(d[4]).hide(),
        c.rescollbar(e),
        n.hide()
    }
    ,
    m.restore = function(e) {
        var t = h("#" + d[0] + e)
          , i = h("#" + d.SHADE + e)
          , n = t.attr("area").split(",");
        t.attr("type");
        m.style(e, {
            width: parseFloat(n[0]),
            height: parseFloat(n[1]),
            top: parseFloat(n[2]),
            left: parseFloat(n[3]),
            position: t.attr("position"),
            overflow: "visible"
        }, !0),
        t.find(".layui-layer-max").removeClass("layui-layer-maxmin"),
        t.find(".layui-layer-min").show(),
        "page" === t.attr("type") && t.find(d[4]).show(),
        c.rescollbar(e),
        i.show()
    }
    ,
    m.full = function(t) {
        var i = h("#" + d[0] + t);
        c.record(i),
        d.html.attr("layer-full") || d.html.css("overflow", "hidden").attr("layer-full", t),
        clearTimeout(void 0),
        setTimeout(function() {
            var e = "fixed" === i.css("position");
            m.style(t, {
                top: e ? 0 : f.scrollTop(),
                left: e ? 0 : f.scrollLeft(),
                width: f.width(),
                height: f.height()
            }, !0),
            i.find(".layui-layer-min").hide()
        }, 100)
    }
    ,
    m.title = function(e, t) {
        h("#" + d[0] + (t || m.index)).find(d[1]).html(e)
    }
    ,
    m.close = function(a, o) {
        var s, e, r = h("#" + d[0] + a), l = r.attr("type");
        r[0] && (s = "layui-layer-wrap",
        e = function() {
            if (l === c.type[1] && "object" === r.attr("conType")) {
                r.children(":not(." + d[5] + ")").remove();
                for (var e = r.find("." + s), t = 0; t < 2; t++)
                    e.unwrap();
                e.css("display", e.data("display")).removeClass(s)
            } else {
                if (l === c.type[2])
                    try {
                        var i = h("#" + d[4] + a)[0];
                        i.contentWindow.document.write(""),
                        i.contentWindow.close(),
                        r.find("." + d[5])[0].removeChild(i)
                    } catch (n) {}
                r[0].innerHTML = "",
                r.remove()
            }
            "function" == typeof c.end[a] && c.end[a](),
            delete c.end[a],
            "function" == typeof o && o()
        }
        ,
        r.data("isOutAnim") && r.addClass("layer-anim layer-anim-close"),
        h("#layui-layer-moves, #" + d.SHADE + a).remove(),
        6 == m.ie && c.reselect(),
        c.rescollbar(a),
        r.attr("minLeft") && (c.minIndex--,
        c.minLeft.push(r.attr("minLeft"))),
        m.ie && m.ie < 10 || !r.data("isOutAnim") ? e() : setTimeout(function() {
            e()
        }, 200))
    }
    ,
    m.closeAll = function(n, a) {
        "function" == typeof n && (a = n,
        n = null);
        var o = h("." + d[0]);
        h.each(o, function(e) {
            var t = h(this)
              , i = n ? t.attr("type") === n : 1;
            i && m.close(t.attr("times"), e === o.length - 1 ? a : null)
        }),
        0 === o.length && "function" == typeof a && a()
    }
    ,
    m.cache || {}), g = function(e) {
        return i.skin ? " " + i.skin + " " + i.skin + "-" + e : ""
    };
    m.prompt = function(i, n) {
        var e = "";
        "function" == typeof (i = i || {}) && (n = i),
        i.area && (e = 'style="width: ' + (t = i.area)[0] + "; height: " + t[1] + ';"',
        delete i.area);
        var a, t = 2 == i.formType ? '<textarea class="layui-layer-input"' + e + "></textarea>" : '<input type="' + (1 == i.formType ? "password" : "text") + '" class="layui-layer-input">', o = i.success;
        return delete i.success,
        m.open(h.extend({
            type: 1,
            btn: ["&#x786E;&#x5B9A;", "&#x53D6;&#x6D88;"],
            content: t,
            skin: "layui-layer-prompt" + g("prompt"),
            maxWidth: f.width(),
            success: function(e) {
                (a = e.find(".layui-layer-input")).val(i.value || "").focus(),
                "function" == typeof o && o(e)
            },
            resize: !1,
            yes: function(e) {
                var t = a.val();
                "" === t ? a.focus() : t.length > (i.maxlength || 500) ? m.tips("&#x6700;&#x591A;&#x8F93;&#x5165;" + (i.maxlength || 500) + "&#x4E2A;&#x5B57;&#x6570;", a, {
                    tips: 1
                }) : n && n(t, e, a)
            }
        }, i))
    }
    ,
    m.tab = function(n) {
        var a = (n = n || {}).tab || {}
          , o = "layui-this"
          , s = n.success;
        return delete n.success,
        m.open(h.extend({
            type: 1,
            skin: "layui-layer-tab" + g("tab"),
            resize: !1,
            title: function() {
                var e = a.length
                  , t = 1
                  , i = "";
                if (0 < e)
                    for (i = '<span class="' + o + '">' + a[0].title + "</span>"; t < e; t++)
                        i += "<span>" + a[t].title + "</span>";
                return i
            }(),
            content: '<ul class="layui-layer-tabmain">' + function() {
                var e = a.length
                  , t = 1
                  , i = "";
                if (0 < e)
                    for (i = '<li class="layui-layer-tabli ' + o + '">' + (a[0].content || "no content") + "</li>"; t < e; t++)
                        i += '<li class="layui-layer-tabli">' + (a[t].content || "no  content") + "</li>";
                return i
            }() + "</ul>",
            success: function(e) {
                var t = e.find(".layui-layer-title").children()
                  , i = e.find(".layui-layer-tabmain").children();
                t.on("mousedown", function(e) {
                    e.stopPropagation ? e.stopPropagation() : e.cancelBubble = !0;
                    var e = h(this)
                      , t = e.index();
                    e.addClass(o).siblings().removeClass(o),
                    i.eq(t).show().siblings().hide(),
                    "function" == typeof n.change && n.change(t)
                }),
                "function" == typeof s && s(e)
            }
        }, n))
    }
    ,
    m.photos = function(i, e, n) {
        var a = {};
        if ((i = i || {}).photos) {
            var t = !("string" == typeof i.photos || i.photos instanceof h)
              , o = t ? i.photos : {}
              , s = o.data || []
              , r = o.start || 0
              , l = (a.imgIndex = 1 + (0 | r),
            i.img = i.img || "img",
            i.success);
            if (delete i.success,
            t) {
                if (0 === s.length)
                    return m.msg("&#x6CA1;&#x6709;&#x56FE;&#x7247;")
            } else {
                var f = h(i.photos)
                  , c = function() {
                    s = [],
                    f.find(i.img).each(function(e) {
                        var t = h(this);
                        t.attr("layer-index", e),
                        s.push({
                            alt: t.attr("alt"),
                            pid: t.attr("layer-pid"),
                            src: t.attr("layer-src") || t.attr("src"),
                            thumb: t.attr("src")
                        })
                    })
                };
                if (c(),
                0 === s.length)
                    return;
                if (e || f.on("click", i.img, function() {
                    c();
                    var e = h(this).attr("layer-index");
                    m.photos(h.extend(i, {
                        photos: {
                            start: e,
                            data: s,
                            tab: i.tab
                        },
                        full: i.full
                    }), !0)
                }),
                !e)
                    return
            }
            a.imgprev = function(e) {
                a.imgIndex--,
                a.imgIndex < 1 && (a.imgIndex = s.length),
                a.tabimg(e)
            }
            ,
            a.imgnext = function(e, t) {
                a.imgIndex++,
                a.imgIndex > s.length && (a.imgIndex = 1,
                t) || a.tabimg(e)
            }
            ,
            a.keyup = function(e) {
                var t;
                a.end || (t = e.keyCode,
                e.preventDefault(),
                37 === t ? a.imgprev(!0) : 39 === t ? a.imgnext(!0) : 27 === t && m.close(a.index))
            }
            ,
            a.tabimg = function(e) {
                if (!(s.length <= 1))
                    return o.start = a.imgIndex - 1,
                    m.close(a.index),
                    m.photos(i, !0, e)
            }
            ,
            a.event = function() {
                a.bigimg.find(".layui-layer-imgprev").on("click", function(e) {
                    e.preventDefault(),
                    a.imgprev(!0)
                }),
                a.bigimg.find(".layui-layer-imgnext").on("click", function(e) {
                    e.preventDefault(),
                    a.imgnext(!0)
                }),
                h(document).on("keyup", a.keyup)
            }
            ,
            a.loadi = m.load(1, {
                shade: !("shade"in i) && .9,
                scrollbar: !1
            });
            var t = s[r].src
              , d = function(e) {
                var t;
                m.close(a.loadi),
                n && (i.anim = -1),
                a.index = m.open(h.extend({
                    type: 1,
                    id: "layui-layer-photos",
                    area: (e = [e.width, e.height],
                    t = [h(p).width() - 100, h(p).height() - 100],
                    !i.full && (e[0] > t[0] || e[1] > t[1]) && ((t = [e[0] / t[0], e[1] / t[1]])[1] < t[0] ? (e[0] = e[0] / t[0],
                    e[1] = e[1] / t[0]) : t[0] < t[1] && (e[0] = e[0] / t[1],
                    e[1] = e[1] / t[1])),
                    [e[0] + "px", e[1] + "px"]),
                    title: !1,
                    shade: .9,
                    shadeClose: !0,
                    closeBtn: !1,
                    move: ".layui-layer-phimg img",
                    moveType: 1,
                    scrollbar: !1,
                    moveOut: !0,
                    anim: 5,
                    isOutAnim: !1,
                    skin: "layui-layer-photos" + g("photos"),
                    content: '<div class="layui-layer-phimg"><img src="' + s[r].src + '" alt="' + (s[r].alt || "") + '" layer-pid="' + s[r].pid + '">' + (1 < s.length ? '<div class="layui-layer-imgsee"><span class="layui-layer-imguide"><a href="javascript:;" class="layui-layer-iconext layui-layer-imgprev"></a><a href="javascript:;" class="layui-layer-iconext layui-layer-imgnext"></a></span><div class="layui-layer-imgbar" style="display:' + (n ? "block" : "") + '"><span class="layui-layer-imgtit"><a href="javascript:;">' + (s[r].alt || "") + "</a><em>" + a.imgIndex + " / " + s.length + "</em></span></div></div>" : "") + "</div>",
                    success: function(e, t) {
                        a.bigimg = e.find(".layui-layer-phimg"),
                        a.imgsee = e.find(".layui-layer-imgbar"),
                        a.event(e),
                        i.tab && i.tab(s[r], e),
                        "function" == typeof l && l(e)
                    },
                    end: function() {
                        a.end = !0,
                        h(document).off("keyup", a.keyup)
                    }
                }, i))
            }
              , u = function() {
                m.close(a.loadi),
                m.msg("&#x5F53;&#x524D;&#x56FE;&#x7247;&#x5730;&#x5740;&#x5F02;&#x5E38;<br>&#x662F;&#x5426;&#x7EE7;&#x7EED;&#x67E5;&#x770B;&#x4E0B;&#x4E00;&#x5F20;&#xFF1F;", {
                    time: 3e4,
                    btn: ["&#x4E0B;&#x4E00;&#x5F20;", "&#x4E0D;&#x770B;&#x4E86;"],
                    yes: function() {
                        1 < s.length && a.imgnext(!0, !0)
                    }
                })
            }
              , y = new Image;
            (y.src = t,
            y.complete) ? d(y) : (y.onload = function() {
                y.onload = null,
                d(y)
            }
            ,
            y.onerror = function(e) {
                y.onerror = null,
                u(e)
            }
            )
        }
    }
    ,
    c.run = function(e) {
        f = (h = e)(p),
        d.html = h("html"),
        m.open = function(e) {
            return new t(e).index
        }
    }
    ,
    p.layui && layui.define ? (m.ready(),
    layui.define("jquery", function(e) {
        m.path = layui.cache.dir,
        c.run(layui.$),
        e("layer", p.layer = m)
    })) : "function" == typeof define && define.amd ? define(["jquery"], function() {
        return c.run(p.jQuery),
        m
    }) : (m.ready(),
    c.run(p.jQuery))
}(window);
layui.define("jquery", function(e) {
    "use strict";
    var u = layui.$
      , a = layui.hint()
      , o = {
        fixbar: function(t) {
            var e, i, n = "layui-fixbar", o = "layui-fixbar-top", a = u(document), r = u("body"), l = ((t = u.extend({
                showHeight: 200
            }, t)).bar1 = !0 === t.bar1 ? "&#xe606;" : t.bar1,
            t.bar2 = !0 === t.bar2 ? "&#xe607;" : t.bar2,
            t.bgcolor = t.bgcolor ? "background-color:" + t.bgcolor : "",
            [t.bar1, t.bar2, "&#xe604;"]), l = u(['<ul class="' + n + '">', t.bar1 ? '<li class="layui-icon" lay-type="bar1" style="' + t.bgcolor + '">' + l[0] + "</li>" : "", t.bar2 ? '<li class="layui-icon" lay-type="bar2" style="' + t.bgcolor + '">' + l[1] + "</li>" : "", '<li class="layui-icon ' + o + '" lay-type="top" style="' + t.bgcolor + '">' + l[2] + "</li>", "</ul>"].join("")), c = l.find("." + o), g = function() {
                a.scrollTop() >= t.showHeight ? e || (c.show(),
                e = 1) : e && (c.hide(),
                e = 0)
            };
            u("." + n)[0] || ("object" == typeof t.css && l.css(t.css),
            r.append(l),
            g(),
            l.find("li").on("click", function() {
                var e = u(this).attr("lay-type");
                "top" === e && u("html,body").animate({
                    scrollTop: 0
                }, 200),
                t.click && t.click.call(this, e)
            }),
            a.on("scroll", function() {
                clearTimeout(i),
                i = setTimeout(function() {
                    g()
                }, 100)
            }))
        },
        countdown: function(e, t, ss, i) {
            var n = this
              , o = "function" == typeof t
              , a = new Date(e).getTime()
              , r = new Date(!t || o ? (new Date).getTime() : t).getTime()
              , a = a - r
              , l = [Math.floor(a / 864e5), Math.floor(a / 36e5) % 24, Math.floor(a / 6e4) % 60, Math.floor(a / 1e3) % 60]
              , o = (o && (i = t),
            setTimeout(function() {
                n.countdown(e, r + 1e3, ss, i)
            }, 1e3));

            return i && i(0 < a ? l : [0, 0, 0, 0], t, o, ss),
            a <= 0 && clearTimeout(o),
            o
        },
        timeAgo: function(e, t) {
            var i = this
              , n = [[], []]
              , o = (new Date).getTime() - new Date(e).getTime();
            return 26784e5 < o ? (o = new Date(e),
            n[0][0] = i.digit(o.getFullYear(), 4),
            n[0][1] = i.digit(o.getMonth() + 1),
            n[0][2] = i.digit(o.getDate()),
            t || (n[1][0] = i.digit(o.getHours()),
            n[1][1] = i.digit(o.getMinutes()),
            n[1][2] = i.digit(o.getSeconds())),
            n[0].join("-") + " " + n[1].join(":")) : 864e5 <= o ? (o / 1e3 / 60 / 60 / 24 | 0) + "\u5929\u524d" : 36e5 <= o ? (o / 1e3 / 60 / 60 | 0) + "\u5c0f\u65f6\u524d" : 18e4 <= o ? (o / 1e3 / 60 | 0) + "\u5206\u949f\u524d" : o < 0 ? "\u672a\u6765" : "\u521a\u521a"
        },
        digit: function(e, t) {
            var i = "";
            t = t || 2;
            for (var n = (e = String(e)).length; n < t; n++)
                i += "0";
            return e < Math.pow(10, t) ? i + (0 | e) : e
        },
        toDateString: function(e, t) {
            if (null === e || "" === e)
                return "";
            var i = this
              , n = new Date(function() {
                if (e)
                    return !isNaN(e) && "string" == typeof e ? parseInt(e) : e
            }() || new Date)
              , o = [i.digit(n.getFullYear(), 4), i.digit(n.getMonth() + 1), i.digit(n.getDate())]
              , i = [i.digit(n.getHours()), i.digit(n.getMinutes()), i.digit(n.getSeconds())];
            return n.getDate() ? (t = t || "yyyy-MM-dd HH:mm:ss").replace(/yyyy/g, o[0]).replace(/MM/g, o[1]).replace(/dd/g, o[2]).replace(/HH/g, i[0]).replace(/mm/g, i[1]).replace(/ss/g, i[2]) : (a.error('Invalid Msec for "util.toDateString(Msec)"'),
            "")
        },
        escape: function(e) {
            return e === undefined || null === e ? "" : /[<"'>]|&(?=#[a-zA-Z0-9]+)/g.test(e += "") ? e.replace(/&(?!#?[a-zA-Z0-9]+;)/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/'/g, "&#39;").replace(/"/g, "&quot;") : e
        },
        unescape: function(e) {
            return e !== undefined && null !== e || (e = ""),
            (e += "").replace(/\&amp;/g, "&").replace(/\&lt;/g, "<").replace(/\&gt;/g, ">").replace(/\&#39;/g, "'").replace(/\&quot;/g, '"')
        },
        toVisibleArea: function(e) {
            var t, i, n, o, a, r, l, c;
            (e = u.extend({
                margin: 160,
                duration: 200,
                type: "y"
            }, e)).scrollElem[0] && e.thisElem[0] && (t = e.scrollElem,
            l = e.thisElem,
            n = (a = "y" === e.type) ? "top" : "left",
            o = t[i = a ? "scrollTop" : "scrollLeft"](),
            a = t[a ? "height" : "width"](),
            r = t.offset()[n],
            c = {},
            ((l = l.offset()[n] - r) > a - e.margin || l < e.margin) && (c[i] = l - a / 2 + o,
            t.animate(c, e.duration)))
        },
        event: function(i, n, e) {
            var t = u("body");
            return e = e || "click",
            n = o.event[i] = u.extend(!0, o.event[i], n) || {},
            o.event.UTIL_EVENT_CALLBACK = o.event.UTIL_EVENT_CALLBACK || {},
            t.off(e, "*[" + i + "]", o.event.UTIL_EVENT_CALLBACK[i]),
            o.event.UTIL_EVENT_CALLBACK[i] = function() {
                var e = u(this)
                  , t = e.attr(i);
                "function" == typeof n[t] && n[t].call(this, e)
            }
            ,
            t.on(e, "*[" + i + "]", o.event.UTIL_EVENT_CALLBACK[i]),
            n
        }
    };
    o.on = o.event,
    e("util", o)
});
layui.define(["jquery", "laytpl", "lay"], function(e) {
    "use strict";
    var n, i, t, s = layui.$, m = layui.laytpl, a = layui.hint(), l = layui.device().mobile ? "click" : "mousedown", o = "dropdown", r = "layui_" + o + "_index", c = {
        config: {},
        index: layui[o] ? layui[o].index + 1e4 : 0,
        set: function(e) {
            var i = this;
            return i.config = s.extend({}, i.config, e),
            i
        },
        on: function(e, i) {
            return layui.onevent.call(this, o, e, i)
        }
    }, p = function() {
        var i = this
          , e = i.config
          , t = e.id;
        return p.that[t] = i,
        {
            config: e,
            reload: function(e) {
                i.reload.call(i, e)
            }
        }
    }, u = "layui-menu-item-up", d = "layui-menu-item-down", y = "layui-menu-body-title", f = "layui-menu-item-group", g = "layui-menu-item-parent", h = "layui-menu-item-checked", v = "layui-menu-item-checked2", w = "layui-menu-body-panel", C = "layui-menu-body-panel-left", V = "." + f + ">." + y, k = function(e) {
        var i = this;
        i.index = ++c.index,
        i.config = s.extend({}, i.config, c.config, e),
        i.init()
    };
    k.prototype.config = {
        trigger: "click",
        content: "",
        className: "",
        style: "",
        show: !1,
        isAllowSpread: !0,
        isSpreadItem: !0,
        data: [],
        delay: 300
    },
    k.prototype.reload = function(e) {
        var i = this;
        i.config = s.extend({}, i.config, e),
        i.init(!0)
    }
    ,
    k.prototype.init = function(e) {
        var i = this
          , t = i.config
          , n = t.elem = s(t.elem);
        return 1 < n.length ? (layui.each(n, function() {
            c.render(s.extend({}, t, {
                elem: this
            }))
        }),
        i) : !e && n[0] && n.data(r) ? (n = p.getThis(n.data(r))) ? n.reload(t) : void 0 : (t.id = "id"in t ? t.id : i.index,
        t.show && i.render(e),
        void i.events())
    }
    ,
    k.prototype.render = function(e) {
        var n = this
          , u = n.config
          , i = s("body")
          , d = function(r, e) {
            return layui.each(e, function(e, i) {
                var t, n = i.child && 0 < i.child.length, a = ("isSpreadItem"in i ? i : u).isSpreadItem, l = i.templet ? m(i.templet).render(i) : u.templet ? m(u.templet).render(i) : i.title, o = (n && (i.type = i.type || "parent"),
                i.type ? {
                    group: "group",
                    parent: "parent",
                    "-": "-"
                }[i.type] || "parent" : "");
                ("-" === o || i.title || i.id || n) && ((l = s(["<li" + (t = {
                    group: "layui-menu-item-group" + (u.isAllowSpread ? a ? " layui-menu-item-down" : " layui-menu-item-up" : ""),
                    parent: g,
                    "-": "layui-menu-item-divider"
                },
                n || o ? ' class="' + t[o] + '"' : "") + ">", (t = "href"in i ? '<a href="' + i.href + '" target="' + (i.target || "_self") + '">' + l + "</a>" : l,
                n ? '<div class="' + y + '">' + t + ("parent" === o ? '<i class="layui-icon layui-icon-right"></i>' : "group" === o && u.isAllowSpread ? '<i class="layui-icon layui-icon-' + (a ? "up" : "down") + '"></i>' : "") + "</div>" : '<div class="' + y + '">' + t + "</div>"), "</li>"].join(""))).data("item", i),
                n && (a = s('<div class="layui-panel layui-menu-body-panel"></div>'),
                t = s("<ul></ul>"),
                "parent" === o ? (a.append(d(t, i.child)),
                l.append(a)) : l.append(d(t, i.child))),
                r.append(l))
            }),
            r
        }
          , t = ['<div class="layui-dropdown layui-border-box layui-panel layui-anim layui-anim-downbit">', "</div>"].join("");
        !(e = "contextmenu" !== u.trigger && !lay.isTopElem(u.elem[0]) ? e : !0) && u.elem.data(r + "_opened") || (n.elemView = s(t),
        n.elemView.append(u.content || (e = s('<ul class="layui-menu layui-dropdown-menu"></ul>'),
        0 < u.data.length ? d(e, u.data) : e.html('<li class="layui-menu-item-none">no menu</li>'),
        e)),
        u.className && n.elemView.addClass(u.className),
        u.style && n.elemView.attr("style", u.style),
        c.thisId = u.id,
        n.remove(),
        i.append(n.elemView),
        u.elem.data(r + "_opened", !0),
        n.position(),
        (p.prevElem = n.elemView).data("prevElem", u.elem),
        n.elemView.find(".layui-menu").on(l, function(e) {
            layui.stope(e)
        }),
        n.elemView.find(".layui-menu li").on("click", function(e) {
            var i = s(this)
              , t = i.data("item") || {};
            t.child && 0 < t.child.length || "-" === t.type || (n.remove(),
            "function" == typeof u.click && u.click(t, i))
        }),
        n.elemView.find(V).on("click", function(e) {
            var i = s(this).parent();
            "group" === (i.data("item") || {}).type && u.isAllowSpread && p.spread(i)
        }),
        "mouseenter" === u.trigger && n.elemView.on("mouseenter", function() {
            clearTimeout(p.timer)
        }).on("mouseleave", function() {
            n.delayRemove()
        }))
    }
    ,
    k.prototype.position = function(e) {
        var i = this.config;
        lay.position(i.elem[0], this.elemView[0], {
            position: i.position,
            e: this.e,
            clickType: "contextmenu" === i.trigger ? "right" : null,
            align: i.align || null
        })
    }
    ,
    k.prototype.remove = function() {
        this.config;
        var e = p.prevElem;
        e && (e.data("prevElem") && e.data("prevElem").data(r + "_opened", !1),
        e.remove())
    }
    ,
    k.prototype.delayRemove = function() {
        var e = this
          , i = e.config;
        clearTimeout(p.timer),
        p.timer = setTimeout(function() {
            e.remove()
        }, i.delay)
    }
    ,
    k.prototype.events = function() {
        var i = this
          , t = i.config;
        "hover" === t.trigger && (t.trigger = "mouseenter"),
        i.prevElem && i.prevElem.off(t.trigger, i.prevElemCallback),
        i.prevElem = t.elem,
        i.prevElemCallback = function(e) {
            clearTimeout(p.timer),
            i.e = e,
            i.render(),
            e.preventDefault(),
            "function" == typeof t.ready && t.ready(i.elemView, t.elem, i.e.target)
        }
        ,
        t.elem.on(t.trigger, i.prevElemCallback),
        "mouseenter" === t.trigger && t.elem.on("mouseleave", function() {
            i.delayRemove()
        })
    }
    ,
    p.that = {},
    p.getThis = function(e) {
        var i = p.that[e];
        return i || a.error(e ? o + " instance with ID '" + e + "' not found" : "ID argument required"),
        i
    }
    ,
    p.spread = function(e) {
        var i = e.children("." + y).find(".layui-icon");
        e.hasClass(u) ? (e.removeClass(u).addClass(d),
        i.removeClass("layui-icon-down").addClass("layui-icon-up")) : (e.removeClass(d).addClass(u),
        i.removeClass("layui-icon-up").addClass("layui-icon-down"))
    }
    ,
    n = s(window),
    i = s(document),
    n.on("resize", function() {
        if (c.thisId) {
            var e = p.getThis(c.thisId);
            if (e) {
                if (!e.elemView[0] || !s(".layui-dropdown")[0])
                    return !1;
                "contextmenu" === e.config.trigger ? e.remove() : e.position()
            }
        }
    }),
    i.on(l, function(e) {
        var i, t;
        !c.thisId || (i = p.getThis(c.thisId)) && (t = i.config,
        !lay.isTopElem(t.elem[0]) && "contextmenu" !== t.trigger && (e.target === t.elem[0] || t.elem.find(e.target)[0] || e.target === i.elemView[0] || i.elemView && i.elemView.find(e.target)[0]) || i.remove())
    }),
    t = ".layui-menu:not(.layui-dropdown-menu) li",
    i.on("click", t, function(e) {
        var i = s(this)
          , t = i.parents(".layui-menu").eq(0)
          , n = i.hasClass(f) || i.hasClass(g)
          , a = t.attr("lay-filter") || t.attr("id")
          , l = lay.options(this);
        i.hasClass("layui-menu-item-divider") || n || (t.find("." + h).removeClass(h),
        t.find("." + v).removeClass(v),
        i.addClass(h),
        i.parents("." + g).addClass(v),
        layui.event.call(this, o, "click(" + a + ")", l))
    }),
    i.on("click", t + V, function(e) {
        var i = s(this).parents("." + f + ":eq(0)")
          , t = lay.options(i[0]);
        "isAllowSpread"in t && !t.isAllowSpread || p.spread(i)
    }),
    t = ".layui-menu ." + g,
    i.on("mouseenter", t, function(e) {
        var i, t = s(this).find("." + w);
        t[0] && ((i = t[0].getBoundingClientRect()).right > n.width() && (t.addClass(C),
        (i = t[0].getBoundingClientRect()).left < 0 && t.removeClass(C)),
        i.bottom > n.height() && t.eq(0).css("margin-top", -(i.bottom - n.height() + 5)))
    }).on("mouseleave", t, function(e) {
        var i = s(this).children("." + w);
        i.removeClass(C),
        i.css("margin-top", 0)
    }),
    c.reload = function(e, i) {
        e = p.getThis(e);
        return e ? (e.reload(i),
        p.call(e)) : this
    }
    ,
    c.render = function(e) {
        e = new k(e);
        return p.call(e)
    }
    ,
    e(o, c)
});
layui.define("jquery", function(e) {
    "use strict";
    var h = layui.$
      , t = {
        config: {},
        index: layui.slider ? layui.slider.index + 1e4 : 0,
        set: function(e) {
            var i = this;
            return i.config = h.extend({}, i.config, e),
            i
        },
        on: function(e, i) {
            return layui.onevent.call(this, a, e, i)
        }
    }
      , a = "slider"
      , c = "layui-disabled"
      , y = "layui-slider-bar"
      , g = "layui-slider-wrap"
      , b = "layui-slider-wrap-btn"
      , x = "layui-slider-tips"
      , T = "layui-slider-input-txt"
      , w = "layui-slider-hover"
      , i = function(e) {
        var i = this;
        i.index = ++t.index,
        i.config = h.extend({}, i.config, t.config, e),
        i.render()
    };
    i.prototype.config = {
        type: "default",
        min: 0,
        max: 100,
        value: 0,
        step: 1,
        showstep: !1,
        tips: !0,
        input: !1,
        range: !1,
        height: 200,
        disabled: !1,
        theme: "#009688"
    },
    i.prototype.render = function() {
        var a, n = this, l = n.config, e = (l.step < 1 && (l.step = 1),
        l.max < l.min && (l.max = l.min + l.step),
        l.range ? (l.value = "object" == typeof l.value ? l.value : [l.min, l.value],
        i = Math.min(l.value[0], l.value[1]),
        s = Math.max(l.value[0], l.value[1]),
        l.value[0] = i > l.min ? i : l.min,
        l.value[1] = s > l.min ? s : l.min,
        l.value[0] = l.value[0] > l.max ? l.max : l.value[0],
        l.value[1] = l.value[1] > l.max ? l.max : l.value[1],
        i = Math.floor((l.value[0] - l.min) / (l.max - l.min) * 100),
        t = (s = Math.floor((l.value[1] - l.min) / (l.max - l.min) * 100)) - i + "%",
        i += "%",
        s += "%") : ("object" == typeof l.value && (l.value = Math.min.apply(null, l.value)),
        l.value < l.min && (l.value = l.min),
        l.value > l.max && (l.value = l.max),
        t = Math.floor((l.value - l.min) / (l.max - l.min) * 100) + "%"),
        l.disabled ? "#c2c2c2" : l.theme), i = '<div class="layui-slider ' + ("vertical" === l.type ? "layui-slider-vertical" : "") + '">' + (l.tips ? '<div class="' + x + '"></div>' : "") + '<div class="layui-slider-bar" style="background:' + e + "; " + ("vertical" === l.type ? "height" : "width") + ":" + t + ";" + ("vertical" === l.type ? "bottom" : "left") + ":" + (i || 0) + ';"></div><div class="layui-slider-wrap" style="' + ("vertical" === l.type ? "bottom" : "left") + ":" + (i || t) + ';"><div class="layui-slider-wrap-btn" style="border: 2px solid ' + e + ';"></div></div>' + (l.range ? '<div class="layui-slider-wrap" style="' + ("vertical" === l.type ? "bottom" : "left") + ":" + s + ';"><div class="layui-slider-wrap-btn" style="border: 2px solid ' + e + ';"></div></div>' : "") + "</div>", t = h(l.elem), s = t.next(".layui-slider");
        if (s[0] && s.remove(),
        n.elemTemp = h(i),
        l.range ? (n.elemTemp.find("." + g).eq(0).data("value", l.value[0]),
        n.elemTemp.find("." + g).eq(1).data("value", l.value[1])) : n.elemTemp.find("." + g).data("value", l.value),
        t.html(n.elemTemp),
        "vertical" === l.type && n.elemTemp.height(l.height + "px"),
        l.showstep) {
            for (var o = (l.max - l.min) / l.step, r = "", u = 1; u < 1 + o; u++) {
                var d = 100 * u / o;
                d < 100 && (r += '<div class="layui-slider-step" style="' + ("vertical" === l.type ? "bottom" : "left") + ":" + d + '%"></div>')
            }
            n.elemTemp.append(r)
        }
        l.input && !l.range && (e = h('<div class="layui-slider-input layui-input"><div class="layui-slider-input-txt"><input type="text" class="layui-input"></div><div class="layui-slider-input-btn"><i class="layui-icon layui-icon-up"></i><i class="layui-icon layui-icon-down"></i></div></div>'),
        t.css("position", "relative"),
        t.append(e),
        t.find("." + T).children("input").val(l.value),
        "vertical" === l.type ? e.css({
            left: 0,
            top: -48
        }) : n.elemTemp.css("margin-right", e.outerWidth() + 15)),
        l.disabled ? (n.elemTemp.addClass(c),
        n.elemTemp.find("." + b).addClass(c)) : n.slide(),
        n.elemTemp.find("." + b).on("mouseover", function() {
            var e = "vertical" === l.type ? l.height : n.elemTemp[0].offsetWidth
              , i = n.elemTemp.find("." + g)
              , t = ("vertical" === l.type ? e - h(this).parent()[0].offsetTop - i.height() : h(this).parent()[0].offsetLeft) / e * 100
              , i = h(this).parent().data("value")
              , e = l.setTips ? l.setTips(i) : i;
            n.elemTemp.find("." + x).html(e),
            clearTimeout(a),
            a = setTimeout(function() {
                "vertical" === l.type ? n.elemTemp.find("." + x).css({
                    bottom: t + "%",
                    "margin-bottom": "20px",
                    display: "inline-block"
                }) : n.elemTemp.find("." + x).css({
                    left: t + "%",
                    display: "inline-block"
                })
            }, 300)
        }).on("mouseout", function() {
            clearTimeout(a),
            n.elemTemp.find("." + x).css("display", "none")
        })
    }
    ,
    i.prototype.slide = function(e, i, t) {
        var o = this.config
          , r = this.elemTemp
          , u = function() {
            return "vertical" === o.type ? o.height : r[0].offsetWidth
        }
          , d = r.find("." + g)
          , s = r.next(".layui-slider-input")
          , c = s.children("." + T).children("input").val()
          , m = 100 / ((o.max - o.min) / Math.ceil(o.step))
          , v = function(e, i) {
            e = 100 < (e = 100 < Math.ceil(e) * m ? Math.ceil(e) * m : Math.round(e) * m) ? 100 : e,
            d.eq(i).css("vertical" === o.type ? "bottom" : "left", e + "%");
            var t, a = p(d[0].offsetLeft), n = o.range ? p(d[1].offsetLeft) : 0, l = ("vertical" === o.type ? (r.find("." + x).css({
                bottom: e + "%",
                "margin-bottom": "20px"
            }),
            a = p(u() - d[0].offsetTop - d.height()),
            n = o.range ? p(u() - d[1].offsetTop - d.height()) : 0) : r.find("." + x).css("left", e + "%"),
            a = 100 < a ? 100 : a,
            n = 100 < n ? 100 : n,
            Math.min(a, n)), a = Math.abs(a - n), n = ("vertical" === o.type ? r.find("." + y).css({
                height: a + "%",
                bottom: l + "%"
            }) : r.find("." + y).css({
                width: a + "%",
                left: l + "%"
            }),
            o.min + Math.round((o.max - o.min) * e / 100));
            c = n,
            s.children("." + T).children("input").val(c),
            d.eq(i).data("value", n),
            r.find("." + x).html(o.setTips ? o.setTips(n) : n),
            o.range && (t = [d.eq(0).data("value"), d.eq(1).data("value")])[0] > t[1] && t.reverse(),
            o.change && o.change(o.range ? t : n)
        }
          , p = function(e) {
            var i = e / u() * 100 / m
              , t = Math.round(i) * m;
            return t = e == u() ? Math.ceil(i) * m : t
        }
          , f = h(['<div class="layui-auxiliar-moving" id="LAY-slider-moving"></div'].join(""));
        if ("set" === e)
            return v(i, t);
        r.find("." + b).each(function(l) {
            var s = h(this);
            s.on("mousedown", function(e) {
                e = e || window.event;
                var i, t, a = s.parent()[0].offsetLeft, n = e.clientX;
                "vertical" === o.type && (a = u() - s.parent()[0].offsetTop - d.height(),
                n = e.clientY);
                e = function(e) {
                    e = e || window.event;
                    var i = a + ("vertical" === o.type ? n - e.clientY : e.clientX - n)
                      , i = (i = (i = i < 0 ? 0 : i) > u() ? u() : i) / u() * 100 / m;
                    v(i, l),
                    s.addClass(w),
                    r.find("." + x).show(),
                    e.preventDefault()
                }
                ,
                i = function() {
                    s.removeClass(w),
                    r.find("." + x).hide()
                }
                ,
                t = function() {
                    i && i(),
                    f.remove()
                }
                ,
                h("#LAY-slider-moving")[0] || h("body").append(f),
                f.on("mousemove", e),
                f.on("mouseup", t).on("mouseleave", t)
            })
        }),
        r.on("click", function(e) {
            var i = h("." + b)
              , t = h(this);
            !i.is(event.target) && 0 === i.has(event.target).length && i.length && (t = (i = (i = (i = "vertical" === o.type ? u() - e.clientY + t.offset().top - h(window).scrollTop() : e.clientX - t.offset().left - h(window).scrollLeft()) < 0 ? 0 : i) > u() ? u() : i) / u() * 100 / m,
            i = o.range ? "vertical" === o.type ? Math.abs(i - parseInt(h(d[0]).css("bottom"))) > Math.abs(i - parseInt(h(d[1]).css("bottom"))) ? 1 : 0 : Math.abs(i - d[0].offsetLeft) > Math.abs(i - d[1].offsetLeft) ? 1 : 0 : 0,
            v(t, i),
            e.preventDefault())
        }),
        s.children(".layui-slider-input-btn").children("i").each(function(i) {
            h(this).on("click", function() {
                c = s.children("." + T).children("input").val();
                var e = ((c = 1 == i ? c - o.step < o.min ? o.min : Number(c) - o.step : Number(c) + o.step > o.max ? o.max : Number(c) + o.step) - o.min) / (o.max - o.min) * 100 / m;
                v(e, 0)
            })
        });
        var a = function() {
            var e = this.value
              , e = (e = (e = (e = isNaN(e) ? 0 : e) < o.min ? o.min : e) > o.max ? o.max : e,
            ((this.value = e) - o.min) / (o.max - o.min) * 100 / m);
            v(e, 0)
        };
        s.children("." + T).children("input").on("keydown", function(e) {
            13 === e.keyCode && (e.preventDefault(),
            a.call(this))
        }).on("change", a)
    }
    ,
    i.prototype.events = function() {
        this.config
    }
    ,
    t.render = function(e) {
        e = new i(e);
        return function() {
            var t = this
              , a = t.config;
            return {
                setValue: function(e, i) {
                    return a.value = e,
                    t.slide("set", e, i || 0)
                },
                config: a
            }
        }
        .call(e)
    }
    ,
    e(a, t)
});
layui.define(["jquery", "lay"], function(e) {
    "use strict";
    var y = layui.jquery
      , o = layui.lay
      , r = layui.device().mobile ? "click" : "mousedown"
      , i = {
        config: {},
        index: layui.colorpicker ? layui.colorpicker.index + 1e4 : 0,
        set: function(e) {
            var i = this;
            return i.config = y.extend({}, i.config, e),
            i
        },
        on: function(e, i) {
            return layui.onevent.call(this, "colorpicker", e, i)
        }
    }
      , n = "layui-colorpicker"
      , l = ".layui-colorpicker-main"
      , m = "layui-icon-down"
      , x = "layui-icon-close"
      , P = "layui-colorpicker-trigger-span"
      , C = "layui-colorpicker-trigger-i"
      , B = "layui-colorpicker-side-slider"
      , w = "layui-colorpicker-basis"
      , D = "layui-colorpicker-alpha-bgcolor"
      , j = "layui-colorpicker-alpha-slider"
      , E = "layui-colorpicker-basis-cursor"
      , F = "layui-colorpicker-main-input"
      , H = function(e) {
        var i = {
            h: 0,
            s: 0,
            b: 0
        }
          , o = Math.min(e.r, e.g, e.b)
          , r = Math.max(e.r, e.g, e.b)
          , n = r - o;
        return i.b = r,
        i.s = 0 != r ? 255 * n / r : 0,
        0 != i.s ? e.r == r ? i.h = (e.g - e.b) / n : e.g == r ? i.h = 2 + (e.b - e.r) / n : i.h = 4 + (e.r - e.g) / n : i.h = -1,
        r == o && (i.h = 0),
        i.h *= 60,
        i.h < 0 && (i.h += 360),
        i.s *= 100 / 255,
        i.b *= 100 / 255,
        i
    }
      , M = function(e) {
        var i, o = {}, r = e.h, n = 255 * e.s / 100, e = 255 * e.b / 100;
        return 0 == n ? o.r = o.g = o.b = e : (e = r % 60 * ((i = e) - (n = (255 - n) * e / 255)) / 60,
        (r = 360 == r ? 0 : r) < 60 ? (o.r = i,
        o.b = n,
        o.g = n + e) : r < 120 ? (o.g = i,
        o.b = n,
        o.r = i - e) : r < 180 ? (o.g = i,
        o.r = n,
        o.b = n + e) : r < 240 ? (o.b = i,
        o.r = n,
        o.g = i - e) : r < 300 ? (o.b = i,
        o.g = n,
        o.r = n + e) : r < 360 ? (o.r = i,
        o.g = n,
        o.b = i - e) : (o.r = 0,
        o.g = 0,
        o.b = 0)),
        {
            r: Math.round(o.r),
            g: Math.round(o.g),
            b: Math.round(o.b)
        }
    }
      , f = function(e) {
        var e = M(e)
          , o = [e.r.toString(16), e.g.toString(16), e.b.toString(16)];
        return y.each(o, function(e, i) {
            1 == i.length && (o[e] = "0" + i)
        }),
        o.join("")
    }
      , Y = function(e) {
        e = e.match(/[0-9]{1,3}/g) || [];
        return {
            r: e[0],
            g: e[1],
            b: e[2]
        }
    }
      , I = y(window)
      , t = y(document)
      , c = function(e) {
        this.index = ++i.index,
        this.config = y.extend({}, this.config, i.config, e),
        this.render()
    };
    c.prototype.config = {
        color: "",
        size: null,
        alpha: !1,
        format: "hex",
        predefine: !1,
        colors: ["#009688", "#5FB878", "#1E9FFF", "#FF5722", "#FFB800", "#01AAED", "#999", "#c00", "#ff8c00", "#ffd700", "#90ee90", "#00ced1", "#1e90ff", "#c71585", "rgb(0, 186, 189)", "rgb(255, 120, 0)", "rgb(250, 212, 0)", "#393D49", "rgba(0,0,0,.5)", "rgba(255, 69, 0, 0.68)", "rgba(144, 240, 144, 0.5)", "rgba(31, 147, 255, 0.73)"]
    },
    c.prototype.render = function() {
        var e = this
          , i = e.config
          , o = y(['<div class="layui-unselect layui-colorpicker">', "<span " + ("rgb" == i.format && i.alpha ? 'class="layui-colorpicker-trigger-bgcolor"' : "") + ">", '<span class="layui-colorpicker-trigger-span" ', 'lay-type="' + ("rgb" == i.format ? i.alpha ? "rgba" : "torgb" : "") + '" ', 'style="' + (o = "",
        i.color ? (o = i.color,
        3 < (i.color.match(/[0-9]{1,3}/g) || []).length && (i.alpha && "rgb" == i.format || (o = "#" + f(H(Y(i.color))))),
        "background: " + o) : o) + '">', '<i class="layui-icon layui-colorpicker-trigger-i ' + (i.color ? m : x) + '"></i>', "</span>", "</span>", "</div>"].join(""))
          , r = y(i.elem);
        i.size && o.addClass("layui-colorpicker-" + i.size),
        r.addClass("layui-inline").html(e.elemColorBox = o),
        e.color = e.elemColorBox.find("." + P)[0].style.background,
        e.events()
    }
    ,
    c.prototype.renderPicker = function() {
        var o, e = this, i = e.config, r = e.elemColorBox[0], i = e.elemPicker = y(['<div id="layui-colorpicker' + e.index + '" data-index="' + e.index + '" class="layui-anim layui-anim-downbit layui-colorpicker-main">', '<div class="layui-colorpicker-main-wrapper">', '<div class="layui-colorpicker-basis">', '<div class="layui-colorpicker-basis-white"></div>', '<div class="layui-colorpicker-basis-black"></div>', '<div class="layui-colorpicker-basis-cursor"></div>', "</div>", '<div class="layui-colorpicker-side">', '<div class="layui-colorpicker-side-slider"></div>', "</div>", "</div>", '<div class="layui-colorpicker-main-alpha ' + (i.alpha ? "layui-show" : "") + '">', '<div class="layui-colorpicker-alpha-bgcolor">', '<div class="layui-colorpicker-alpha-slider"></div>', "</div>", "</div>", i.predefine ? (o = ['<div class="layui-colorpicker-main-pre">'],
        layui.each(i.colors, function(e, i) {
            o.push(['<div class="layui-colorpicker-pre' + (3 < (i.match(/[0-9]{1,3}/g) || []).length ? " layui-colorpicker-pre-isalpha" : "") + '">', '<div style="background:' + i + '"></div>', "</div>"].join(""))
        }),
        o.push("</div>"),
        o.join("")) : "", '<div class="layui-colorpicker-main-input">', '<div class="layui-inline">', '<input type="text" class="layui-input">', "</div>", '<div class="layui-btn-container">', '<button class="layui-btn layui-btn-primary layui-btn-sm" colorpicker-events="clear">\u6e05\u7a7a</button>', '<button class="layui-btn layui-btn-sm" colorpicker-events="confirm">\u786e\u5b9a</button>', "</div", "</div>", "</div>"].join(""));
        e.elemColorBox.find("." + P)[0];
        y(l)[0] && y(l).data("index") == e.index ? e.removePicker(c.thisElemInd) : (e.removePicker(c.thisElemInd),
        y("body").append(i)),
        c.thisElemInd = e.index,
        c.thisColor = r.style.background,
        e.position(),
        e.pickerEvents()
    }
    ,
    c.prototype.removePicker = function(e) {
        this.config;
        return y("#layui-colorpicker" + (e || this.index)).remove(),
        this
    }
    ,
    c.prototype.position = function() {
        var e = this
          , i = e.config;
        return o.position(e.bindElem || e.elemColorBox[0], e.elemPicker[0], {
            position: i.position,
            align: "center"
        }),
        e
    }
    ,
    c.prototype.val = function() {
        var e, i = this, o = (i.config,
        i.elemColorBox.find("." + P)), r = i.elemPicker.find("." + F), n = o[0].style.backgroundColor;
        n ? (e = H(Y(n)),
        o = o.attr("lay-type"),
        i.select(e.h, e.s, e.b),
        "torgb" === o && r.find("input").val(n),
        "rgba" === o && (e = Y(n),
        3 == (n.match(/[0-9]{1,3}/g) || []).length ? (r.find("input").val("rgba(" + e.r + ", " + e.g + ", " + e.b + ", 1)"),
        i.elemPicker.find("." + j).css("left", 280)) : (r.find("input").val(n),
        o = 280 * n.slice(n.lastIndexOf(",") + 1, n.length - 1),
        i.elemPicker.find("." + j).css("left", o)),
        i.elemPicker.find("." + D)[0].style.background = "linear-gradient(to right, rgba(" + e.r + ", " + e.g + ", " + e.b + ", 0), rgb(" + e.r + ", " + e.g + ", " + e.b + "))")) : (i.select(0, 100, 100),
        r.find("input").val(""),
        i.elemPicker.find("." + D)[0].style.background = "",
        i.elemPicker.find("." + j).css("left", 280))
    }
    ,
    c.prototype.side = function() {
        var n = this
          , l = n.config
          , t = n.elemColorBox.find("." + P)
          , c = t.attr("lay-type")
          , a = n.elemPicker.find(".layui-colorpicker-side")
          , e = n.elemPicker.find("." + B)
          , s = n.elemPicker.find("." + w)
          , r = n.elemPicker.find("." + E)
          , d = n.elemPicker.find("." + D)
          , f = n.elemPicker.find("." + j)
          , u = e[0].offsetTop / 180 * 360
          , p = 100 - (r[0].offsetTop + 3) / 180 * 100
          , g = (r[0].offsetLeft + 3) / 260 * 100
          , h = Math.round(f[0].offsetLeft / 280 * 100) / 100
          , v = n.elemColorBox.find("." + C)
          , i = n.elemPicker.find(".layui-colorpicker-pre").children("div")
          , b = function(e, i, o, r) {
            n.select(e, i, o);
            e = M({
                h: e,
                s: i,
                b: o
            });
            v.addClass(m).removeClass(x),
            t[0].style.background = "rgb(" + e.r + ", " + e.g + ", " + e.b + ")",
            "torgb" === c && n.elemPicker.find("." + F).find("input").val("rgb(" + e.r + ", " + e.g + ", " + e.b + ")"),
            "rgba" === c && (f.css("left", 280 * r),
            n.elemPicker.find("." + F).find("input").val("rgba(" + e.r + ", " + e.g + ", " + e.b + ", " + r + ")"),
            t[0].style.background = "rgba(" + e.r + ", " + e.g + ", " + e.b + ", " + r + ")",
            d[0].style.background = "linear-gradient(to right, rgba(" + e.r + ", " + e.g + ", " + e.b + ", 0), rgb(" + e.r + ", " + e.g + ", " + e.b + "))"),
            l.change && l.change(n.elemPicker.find("." + F).find("input").val())
        }
          , o = y(['<div class="layui-auxiliar-moving" id="LAY-colorpicker-moving"></div>'].join(""))
          , k = function(e) {
            y("#LAY-colorpicker-moving")[0] || y("body").append(o),
            o.on("mousemove", e),
            o.on("mouseup", function() {
                o.remove()
            }).on("mouseleave", function() {
                o.remove()
            })
        };
        e.on("mousedown", function(e) {
            var r = this.offsetTop
              , n = e.clientY;
            k(function(e) {
                var i = r + (e.clientY - n)
                  , o = a[0].offsetHeight
                  , o = (i = o < (i = i < 0 ? 0 : i) ? o : i) / 180 * 360;
                b(u = o, g, p, h),
                e.preventDefault()
            }),
            e.preventDefault()
        }),
        a.on("click", function(e) {
            var i = e.clientY - y(this).offset().top
              , i = (i = (i = i < 0 ? 0 : i) > this.offsetHeight ? this.offsetHeight : i) / 180 * 360;
            b(u = i, g, p, h),
            e.preventDefault()
        }),
        r.on("mousedown", function(e) {
            var l = this.offsetTop
              , t = this.offsetLeft
              , c = e.clientY
              , a = e.clientX;
            layui.stope(e),
            k(function(e) {
                var i = l + (e.clientY - c)
                  , o = t + (e.clientX - a)
                  , r = s[0].offsetHeight - 3
                  , n = s[0].offsetWidth - 3
                  , n = ((o = n < (o = o < -3 ? -3 : o) ? n : o) + 3) / 260 * 100
                  , o = 100 - ((i = r < (i = i < -3 ? -3 : i) ? r : i) + 3) / 180 * 100;
                b(u, g = n, p = o, h),
                e.preventDefault()
            }),
            e.preventDefault()
        }),
        s.on("mousedown", function(e) {
            var i = e.clientY - y(this).offset().top - 3 + I.scrollTop()
              , o = e.clientX - y(this).offset().left - 3 + I.scrollLeft()
              , o = ((i = i < -3 ? -3 : i) > this.offsetHeight - 3 && (i = this.offsetHeight - 3),
            ((o = (o = o < -3 ? -3 : o) > this.offsetWidth - 3 ? this.offsetWidth - 3 : o) + 3) / 260 * 100)
              , i = 100 - (i + 3) / 180 * 100;
            b(u, g = o, p = i, h),
            layui.stope(e),
            e.preventDefault(),
            r.trigger(e, "mousedown")
        }),
        f.on("mousedown", function(e) {
            var r = this.offsetLeft
              , n = e.clientX;
            k(function(e) {
                var i = r + (e.clientX - n)
                  , o = d[0].offsetWidth
                  , o = (o < (i = i < 0 ? 0 : i) && (i = o),
                Math.round(i / 280 * 100) / 100);
                b(u, g, p, h = o),
                e.preventDefault()
            }),
            e.preventDefault()
        }),
        d.on("click", function(e) {
            var i = e.clientX - y(this).offset().left
              , i = ((i = i < 0 ? 0 : i) > this.offsetWidth && (i = this.offsetWidth),
            Math.round(i / 280 * 100) / 100);
            b(u, g, p, h = i),
            e.preventDefault()
        }),
        i.each(function() {
            y(this).on("click", function() {
                y(this).parent(".layui-colorpicker-pre").addClass("selected").siblings().removeClass("selected");
                var e = this.style.backgroundColor
                  , i = H(Y(e))
                  , o = e.slice(e.lastIndexOf(",") + 1, e.length - 1);
                u = i.h,
                g = i.s,
                p = i.b,
                3 == (e.match(/[0-9]{1,3}/g) || []).length && (o = 1),
                h = o,
                b(i.h, i.s, i.b, o)
            })
        })
    }
    ,
    c.prototype.select = function(e, i, o, r) {
        var n = this
          , l = (n.config,
        f({
            h: e,
            s: 100,
            b: 100
        }))
          , t = f({
            h: e,
            s: i,
            b: o
        })
          , e = e / 360 * 180
          , o = 180 - o / 100 * 180 - 3
          , i = i / 100 * 260 - 3;
        n.elemPicker.find("." + B).css("top", e),
        n.elemPicker.find("." + w)[0].style.background = "#" + l,
        n.elemPicker.find("." + E).css({
            top: o,
            left: i
        }),
        "change" !== r && n.elemPicker.find("." + F).find("input").val("#" + t)
    }
    ,
    c.prototype.pickerEvents = function() {
        var c = this
          , a = c.config
          , s = c.elemColorBox.find("." + P)
          , d = c.elemPicker.find("." + F + " input")
          , o = {
            clear: function(e) {
                s[0].style.background = "",
                c.elemColorBox.find("." + C).removeClass(m).addClass(x),
                c.color = "",
                a.done && a.done(""),
                c.removePicker()
            },
            confirm: function(e, i) {
                var o, r, n = d.val(), l = n, t = {};
                if (-1 < n.indexOf(",") ? (t = H(Y(n)),
                c.select(t.h, t.s, t.b),
                s[0].style.background = l = "#" + f(t),
                3 < (n.match(/[0-9]{1,3}/g) || []).length && "rgba" === s.attr("lay-type") && (o = 280 * n.slice(n.lastIndexOf(",") + 1, n.length - 1),
                c.elemPicker.find("." + j).css("left", o),
                l = s[0].style.background = n)) : (3 == (o = -1 < (o = n).indexOf("#") ? o.substring(1) : o).length && (o = (r = o.split(""))[0] + r[0] + r[1] + r[1] + r[2] + r[2]),
                r = {
                    r: (o = parseInt(o, 16)) >> 16,
                    g: (65280 & o) >> 8,
                    b: 255 & o
                },
                t = H(r),
                s[0].style.background = l = "#" + f(t),
                c.elemColorBox.find("." + C).removeClass(x).addClass(m)),
                "change" === i)
                    return c.select(t.h, t.s, t.b, i),
                    void (a.change && a.change(l));
                c.color = n,
                a.done && a.done(n),
                c.removePicker()
            }
        };
        c.elemPicker.on("click", "*[colorpicker-events]", function() {
            var e = y(this)
              , i = e.attr("colorpicker-events");
            o[i] && o[i].call(this, e)
        }),
        d.on("keyup", function(e) {
            var i = y(this);
            o.confirm.call(this, i, 13 === e.keyCode ? null : "change")
        })
    }
    ,
    c.prototype.events = function() {
        var i = this
          , e = i.config
          , o = i.elemColorBox.find("." + P);
        i.elemColorBox.on("click", function() {
            i.renderPicker(),
            y(l)[0] && (i.val(),
            i.side())
        }),
        e.elem[0] && !i.elemColorBox[0].eventHandler && (t.on(r, function(e) {
            y(e.target).hasClass(n) || y(e.target).parents("." + n)[0] || y(e.target).hasClass(l.replace(/\./g, "")) || y(e.target).parents(l)[0] || i.elemPicker && (i.color ? (e = H(Y(i.color)),
            i.select(e.h, e.s, e.b)) : i.elemColorBox.find("." + C).removeClass(m).addClass(x),
            o[0].style.background = i.color || "",
            i.removePicker())
        }),
        I.on("resize", function() {
            if (!i.elemPicker || !y(l)[0])
                return !1;
            i.position()
        }),
        i.elemColorBox[0].eventHandler = !0)
    }
    ,
    i.render = function(e) {
        e = new c(e);
        return function() {
            return {
                config: this.config
            }
        }
        .call(e)
    }
    ,
    e("colorpicker", i)
});
layui.define("jquery", function(t) {
    "use strict";
    var u = layui.$
      , d = (layui.hint(),
    layui.device())
      , c = "element"
      , r = "layui-this"
      , y = "layui-show"
      , i = function() {
        this.config = {}
    }
      , h = (i.prototype.set = function(t) {
        return u.extend(!0, this.config, t),
        this
    }
    ,
    i.prototype.on = function(t, i) {
        return layui.onevent.call(this, c, t, i)
    }
    ,
    i.prototype.tabAdd = function(t, i) {
        var a, t = u(".layui-tab[lay-filter=" + t + "]"), e = t.children(".layui-tab-title"), l = e.children(".layui-tab-bar"), t = t.children(".layui-tab-content"), n = "<li" + (a = [],
        layui.each(i, function(t, i) {
            /^(title|content)$/.test(t) || a.push("lay-" + t + '="' + i + '"')
        }),
        0 < a.length && a.unshift(""),
        a.join(" ")) + ">" + (i.title || "unnaming") + "</li>";
        return l[0] ? l.before(n) : e.append(n),
        t.append('<div class="layui-tab-item">' + (i.content || "") + "</div>"),
        C.hideTabMore(!0),
        C.tabAuto(),
        this
    }
    ,
    i.prototype.tabDelete = function(t, i) {
        t = u(".layui-tab[lay-filter=" + t + "]").children(".layui-tab-title").find('>li[lay-id="' + i + '"]');
        return C.tabDelete(null, t),
        this
    }
    ,
    i.prototype.tabChange = function(t, i) {
        t = u(".layui-tab[lay-filter=" + t + "]").children(".layui-tab-title").find('>li[lay-id="' + i + '"]');
        return C.tabClick.call(t[0], null, null, t),
        this
    }
    ,
    i.prototype.tab = function(a) {
        a = a || {},
        e.on("click", a.headerElem, function(t) {
            var i = u(this).index();
            C.tabClick.call(this, t, i, null, a)
        })
    }
    ,
    i.prototype.progress = function(t, i) {
        var a = "layui-progress"
          , t = u("." + a + "[lay-filter=" + t + "]").find("." + a + "-bar")
          , a = t.find("." + a + "-text");
        return t.css("width", i).attr("lay-percent", i),
        a.text(i),
        this
    }
    ,
    ".layui-nav")
      , f = "layui-nav-item"
      , l = "layui-nav-bar"
      , p = "layui-nav-tree"
      , b = "layui-nav-child"
      , v = "layui-nav-more"
      , m = "layui-anim layui-anim-upbit"
      , C = {
        tabClick: function(t, i, a, e) {
            e = e || {};
            var a = a || u(this)
              , i = i || a.parent().children("li").index(a)
              , l = e.headerElem ? a.parent() : a.parents(".layui-tab").eq(0)
              , e = e.bodyElem ? u(e.bodyElem) : l.children(".layui-tab-content").children(".layui-tab-item")
              , n = a.find("a")
              , n = "javascript:;" !== n.attr("href") && "_blank" === n.attr("target")
              , s = "string" == typeof a.attr("lay-unselect")
              , o = l.attr("lay-filter");
            n || s || (a.addClass(r).siblings().removeClass(r),
            e.eq(i).addClass(y).siblings().removeClass(y)),
            layui.event.call(this, c, "tab(" + o + ")", {
                elem: l,
                index: i
            })
        },
        tabDelete: function(t, i) {
            var i = i || u(this).parent()
              , a = i.index()
              , e = i.parents(".layui-tab").eq(0)
              , l = e.children(".layui-tab-content").children(".layui-tab-item")
              , n = e.attr("lay-filter");
            i.hasClass(r) && (i.next()[0] && i.next().is("li") ? C.tabClick.call(i.next()[0], null, a + 1) : i.prev()[0] && i.prev().is("li") && C.tabClick.call(i.prev()[0], null, a - 1)),
            i.remove(),
            l.eq(a).remove(),
            setTimeout(function() {
                C.tabAuto()
            }, 50),
            layui.event.call(this, c, "tabDelete(" + n + ")", {
                elem: e,
                index: a
            })
        },
        tabAuto: function() {
            var e = "layui-tab-bar"
              , l = "layui-tab-close"
              , n = this;
            u(".layui-tab").each(function() {
                var t = u(this)
                  , i = t.children(".layui-tab-title")
                  , a = (t.children(".layui-tab-content").children(".layui-tab-item"),
                'lay-stope="tabmore"')
                  , a = u('<span class="layui-unselect layui-tab-bar" ' + a + "><i " + a + ' class="layui-icon">&#xe61a;</i></span>');
                n === window && 8 != d.ie && C.hideTabMore(!0),
                t.attr("lay-allowClose") && i.find("li").each(function() {
                    var t, i = u(this);
                    i.find("." + l)[0] || ((t = u('<i class="layui-icon layui-icon-close layui-unselect ' + l + '"></i>')).on("click", C.tabDelete),
                    i.append(t))
                }),
                "string" != typeof t.attr("lay-unauto") && (i.prop("scrollWidth") > i.outerWidth() + 1 ? i.find("." + e)[0] || (i.append(a),
                t.attr("overflow", ""),
                a.on("click", function(t) {
                    i[this.title ? "removeClass" : "addClass"]("layui-tab-more"),
                    this.title = this.title ? "" : "\u6536\u7f29"
                })) : (i.find("." + e).remove(),
                t.removeAttr("overflow")))
            })
        },
        hideTabMore: function(t) {
            var i = u(".layui-tab-title");
            !0 !== t && "tabmore" === u(t.target).attr("lay-stope") || (i.removeClass("layui-tab-more"),
            i.find(".layui-tab-bar").attr("title", ""))
        },
        clickThis: function() {
            var t = u(this)
              , i = t.parents(h)
              , a = i.attr("lay-filter")
              , e = t.parent()
              , l = t.siblings("." + b)
              , n = "string" == typeof e.attr("lay-unselect");
            "javascript:;" !== t.attr("href") && "_blank" === t.attr("target") || n || l[0] || (i.find("." + r).removeClass(r),
            e.addClass(r)),
            i.hasClass(p) && (l.removeClass(m),
            l[0] && (e["none" === l.css("display") ? "addClass" : "removeClass"](f + "ed"),
            "all" === i.attr("lay-shrink") && e.siblings().removeClass(f + "ed"))),
            layui.event.call(this, c, "nav(" + a + ")", t)
        },
        collapse: function() {
            var t = u(this)
              , i = t.find(".layui-colla-icon")
              , a = t.siblings(".layui-colla-content")
              , e = t.parents(".layui-collapse").eq(0)
              , l = e.attr("lay-filter")
              , n = "none" === a.css("display");
            "string" == typeof e.attr("lay-accordion") && ((e = e.children(".layui-colla-item").children("." + y)).siblings(".layui-colla-title").children(".layui-colla-icon").html("&#xe602;"),
            e.removeClass(y)),
            a[n ? "addClass" : "removeClass"](y),
            i.html(n ? "&#xe61a;" : "&#xe602;"),
            layui.event.call(this, c, "collapse(" + l + ")", {
                title: t,
                content: a,
                show: n
            })
        }
    }
      , a = (i.prototype.render = i.prototype.init = function(t, i) {
        var a = i ? '[lay-filter="' + i + '"]' : ""
          , i = {
            tab: function() {
                C.tabAuto.call({})
            },
            nav: function() {
                var s = {}
                  , o = {}
                  , c = {}
                  , r = "layui-nav-title";
                u(h + a).each(function(t) {
                    var i = u(this)
                      , a = u('<span class="' + l + '"></span>')
                      , e = i.find("." + f);
                    i.find("." + l)[0] || (i.append(a),
                    (i.hasClass(p) ? e.find("dd,>." + r) : e).on("mouseenter", function() {
                        !function(t, i, a) {
                            var e, l = u(this), n = l.find("." + b);
                            i.hasClass(p) ? n[0] || (e = l.children("." + r),
                            t.css({
                                top: l.offset().top - i.offset().top,
                                height: (e[0] ? e : l).outerHeight(),
                                opacity: 1
                            })) : (n.addClass(m),
                            n.hasClass("layui-nav-child-c") && n.css({
                                left: -(n.outerWidth() - l.width()) / 2
                            }),
                            n[0] ? t.css({
                                left: t.position().left + t.width() / 2,
                                width: 0,
                                opacity: 0
                            }) : t.css({
                                left: l.position().left + parseFloat(l.css("marginLeft")),
                                top: l.position().top + l.height() - t.height()
                            }),
                            s[a] = setTimeout(function() {
                                t.css({
                                    width: n[0] ? 0 : l.width(),
                                    opacity: n[0] ? 0 : 1
                                })
                            }, d.ie && d.ie < 10 ? 0 : 200),
                            clearTimeout(c[a]),
                            "block" === n.css("display") && clearTimeout(o[a]),
                            o[a] = setTimeout(function() {
                                n.addClass(y),
                                l.find("." + v).addClass(v + "d")
                            }, 300))
                        }
                        .call(this, a, i, t)
                    }).on("mouseleave", function() {
                        i.hasClass(p) ? a.css({
                            height: 0,
                            opacity: 0
                        }) : (clearTimeout(o[t]),
                        o[t] = setTimeout(function() {
                            i.find("." + b).removeClass(y),
                            i.find("." + v).removeClass(v + "d")
                        }, 300))
                    }),
                    i.on("mouseleave", function() {
                        clearTimeout(s[t]),
                        c[t] = setTimeout(function() {
                            i.hasClass(p) || a.css({
                                width: 0,
                                left: a.position().left + a.width() / 2,
                                opacity: 0
                            })
                        }, 200)
                    })),
                    e.find("a").each(function() {
                        var t = u(this);
                        t.parent();
                        t.siblings("." + b)[0] && !t.children("." + v)[0] && t.append('<i class="layui-icon layui-icon-down ' + v + '"></i>'),
                        t.off("click", C.clickThis).on("click", C.clickThis)
                    })
                })
            },
            breadcrumb: function() {
                u(".layui-breadcrumb" + a).each(function() {
                    var t = u(this)
                      , i = "lay-separator"
                      , a = t.attr(i) || "/"
                      , e = t.find("a");
                    e.next("span[" + i + "]")[0] || (e.each(function(t) {
                        t !== e.length - 1 && u(this).after("<span " + i + ">" + a + "</span>")
                    }),
                    t.css("visibility", "visible"))
                })
            },
            progress: function() {
                var e = "layui-progress";
                u("." + e + a).each(function() {
                    var t = u(this)
                      , i = t.find(".layui-progress-bar")
                      , a = i.attr("lay-percent");
                    i.css("width", /^.+\/.+$/.test(a) ? 100 * new Function("return " + a)() + "%" : a),
                    t.attr("lay-showPercent") && setTimeout(function() {
                        i.html('<span class="' + e + '-text">' + a + "</span>")
                    }, 350)
                })
            },
            collapse: function() {
                u(".layui-collapse" + a).each(function() {
                    u(this).find(".layui-colla-item").each(function() {
                        var t = u(this)
                          , i = t.find(".layui-colla-title")
                          , t = "none" === t.find(".layui-colla-content").css("display");
                        i.find(".layui-colla-icon").remove(),
                        i.append('<i class="layui-icon layui-colla-icon">' + (t ? "&#xe602;" : "&#xe61a;") + "</i>"),
                        i.off("click", C.collapse).on("click", C.collapse)
                    })
                })
            }
        };
        return i[t] ? i[t]() : layui.each(i, function(t, i) {
            i()
        })
    }
    ,
    new i)
      , e = u(document);
    u(function() {
        a.render()
    });
    e.on("click", ".layui-tab-title li", C.tabClick),
    e.on("click", C.hideTabMore),
    u(window).on("resize", C.tabAuto),
    t(c, a)
});
layui.define("layer", function(e) {
    "use strict";
    var v = layui.$
      , t = layui.layer
      , r = layui.hint()
      , y = layui.device()
      , i = {
        config: {},
        set: function(e) {
            var t = this;
            return t.config = v.extend({}, t.config, e),
            t
        },
        on: function(e, t) {
            return layui.onevent.call(this, n, e, t)
        }
    }
      , n = "upload"
      , o = "layui-upload-file"
      , a = "layui-upload-form"
      , F = "layui-upload-iframe"
      , b = "layui-upload-choose"
      , x = function(e) {
        var t = this;
        t.config = v.extend({}, t.config, i.config, e),
        t.render()
    };
    x.prototype.config = {
        accept: "images",
        exts: "",
        auto: !0,
        bindAction: "",
        url: "",
        force: "",
        field: "file",
        acceptMime: "",
        method: "post",
        data: {},
        drag: !0,
        size: 0,
        number: 0,
        multiple: !1
    },
    x.prototype.render = function(e) {
        var t = this;
        (e = t.config).elem = v(e.elem),
        e.bindAction = v(e.bindAction),
        t.file(),
        t.events()
    }
    ,
    x.prototype.file = function() {
        var e = this
          , t = e.config
          , i = e.elemFile = v(['<input class="' + o + '" type="file" accept="' + t.acceptMime + '" name="' + t.field + '"', t.multiple ? " multiple" : "", ">"].join(""))
          , n = t.elem.next();
        (n.hasClass(o) || n.hasClass(a)) && n.remove(),
        y.ie && y.ie < 10 && t.elem.wrap('<div class="layui-upload-wrap"></div>'),
        e.isFile() ? (e.elemFile = t.elem,
        t.field = t.elem[0].name) : t.elem.after(i),
        y.ie && y.ie < 10 && e.initIE()
    }
    ,
    x.prototype.initIE = function() {
        var i, e = this.config, t = v('<iframe id="' + F + '" class="' + F + '" name="' + F + '" frameborder="0"></iframe>'), n = v(['<form target="' + F + '" class="' + a + '" method="post" key="set-mine" enctype="multipart/form-data" action="' + e.url + '">', "</form>"].join(""));
        v("#" + F)[0] || v("body").append(t),
        e.elem.next().hasClass(a) || (this.elemFile.wrap(n),
        e.elem.next("." + a).append((i = [],
        layui.each(e.data, function(e, t) {
            t = "function" == typeof t ? t() : t,
            i.push('<input type="hidden" name="' + e + '" value="' + t + '">')
        }),
        i.join(""))))
    }
    ,
    x.prototype.msg = function(e) {
        return t.msg(e, {
            icon: 2,
            shift: 6
        })
    }
    ,
    x.prototype.isFile = function() {
        var e = this.config.elem[0];
        if (e)
            return "input" === e.tagName.toLocaleLowerCase() && "file" === e.type
    }
    ,
    x.prototype.preview = function(n) {
        window.FileReader && layui.each(this.chooseFiles, function(e, t) {
            var i = new FileReader;
            i.readAsDataURL(t),
            i.onload = function() {
                n && n(e, t, this.result)
            }
        })
    }
    ,
    x.prototype.upload = function(i, e) {
        var n, o, t, a, l = this, r = l.config, u = l.elemFile[0], c = function() {
            var t = 0
              , o = 0
              , e = i || l.files || l.chooseFiles || u.files
              , a = function() {
                r.multiple && t + o === l.fileLength && "function" == typeof r.allDone && r.allDone({
                    total: l.fileLength,
                    successful: t,
                    failed: o
                })
            };
            layui.each(e, function(i, e) {
                var n = new FormData
                  , e = (n.append(r.field, e),
                layui.each(r.data, function(e, t) {
                    t = "function" == typeof t ? t() : t,
                    n.append(e, t)
                }),
                {
                    url: r.url,
                    type: "post",
                    data: n,
                    contentType: !1,
                    processData: !1,
                    dataType: "json",
                    headers: r.headers || {},
                    success: function(e) {
                        t++,
                        f(i, e),
                        a()
                    },
                    error: function(e) {
                        o++,
                        l.msg("Request URL is abnormal: " + (e.statusText || "error")),
                        p(i),
                        a()
                    }
                });
                "function" == typeof r.progress && (e.xhr = function() {
                    var e = v.ajaxSettings.xhr();
                    return e.upload.addEventListener("progress", function(e) {
                        var t;
                        e.lengthComputable && (t = Math.floor(e.loaded / e.total * 100),
                        r.progress(t, (r.item || r.elem)[0], e, i))
                    }),
                    e
                }
                ),
                v.ajax(e)
            })
        }, s = function() {
            var n = v("#" + F);
            l.elemFile.parent().submit(),
            clearInterval(x.timer),
            x.timer = setInterval(function() {
                var e, t = n.contents().find("body");
                try {
                    e = t.text()
                } catch (i) {
                    l.msg("Cross-domain requests are not supported"),
                    clearInterval(x.timer),
                    p()
                }
                e && (clearInterval(x.timer),
                t.html(""),
                f(0, e))
            }, 30)
        }, f = function(e, t) {
            if (l.elemFile.next("." + b).remove(),
            u.value = "",
            "json" === r.force && "object" != typeof t)
                try {
                    t = JSON.parse(t)
                } catch (i) {
                    return t = {},
                    l.msg("Please return JSON data format")
                }
            "function" == typeof r.done && r.done(t, e || 0, function(e) {
                l.upload(e)
            })
        }, p = function(e) {
            r.auto && (u.value = ""),
            "function" == typeof r.error && r.error(e || 0, function(e) {
                l.upload(e)
            })
        }, d = r.exts, m = (o = [],
        layui.each(i || l.chooseFiles, function(e, t) {
            o.push(t.name)
        }),
        o), h = {
            preview: function(e) {
                l.preview(e)
            },
            upload: function(e, t) {
                var i = {};
                i[e] = t,
                l.upload(i)
            },
            pushFile: function() {
                return l.files = l.files || {},
                layui.each(l.chooseFiles, function(e, t) {
                    l.files[e] = t
                }),
                l.files
            },
            resetFile: function(e, t, i) {
                t = new File([t],i);
                l.files = l.files || {},
                l.files[e] = t
            }
        }, g = {
            file: "\u6587\u4ef6",
            images: "\u56fe\u7247",
            video: "\u89c6\u9891",
            audio: "\u97f3\u9891"
        }[r.accept] || "\u6587\u4ef6", m = 0 === m.length ? u.value.match(/[^\/\\]+\..+/g) || [] || "" : m;
        if (0 !== m.length) {
            switch (r.accept) {
            case "file":
                layui.each(m, function(e, t) {
                    if (d && !RegExp(".\\.(" + d + ")$", "i").test(escape(t)))
                        return n = !0
                });
                break;
            case "video":
                layui.each(m, function(e, t) {
                    if (!RegExp(".\\.(" + (d || "avi|mp4|wma|rmvb|rm|flash|3gp|flv") + ")$", "i").test(escape(t)))
                        return n = !0
                });
                break;
            case "audio":
                layui.each(m, function(e, t) {
                    if (!RegExp(".\\.(" + (d || "mp3|wav|mid") + ")$", "i").test(escape(t)))
                        return n = !0
                });
                break;
            default:
                layui.each(m, function(e, t) {
                    if (!RegExp(".\\.(" + (d || "jpg|png|gif|bmp|jpeg") + ")$", "i").test(escape(t)))
                        return n = !0
                })
            }
            if (n)
                return l.msg("\u9009\u62e9\u7684" + g + "\u4e2d\u5305\u542b\u4e0d\u652f\u6301\u7684\u683c\u5f0f"),
                u.value = "";
            if ("choose" !== e && !r.auto || (r.choose && r.choose(h),
            "choose" !== e)) {
                if (l.fileLength = (t = 0,
                g = i || l.files || l.chooseFiles || u.files,
                layui.each(g, function() {
                    t++
                }),
                t),
                r.number && l.fileLength > r.number)
                    return l.msg("\u540c\u65f6\u6700\u591a\u53ea\u80fd\u4e0a\u4f20: " + r.number + " \u4e2a\u6587\u4ef6<br>\u60a8\u5f53\u524d\u5df2\u7ecf\u9009\u62e9\u4e86: " + l.fileLength + " \u4e2a\u6587\u4ef6");
                if (0 < r.size && !(y.ie && y.ie < 10))
                    if (layui.each(l.chooseFiles, function(e, t) {
                        t.size > 1024 * r.size && (t = 1 <= (t = r.size / 1024) ? t.toFixed(2) + "MB" : r.size + "KB",
                        u.value = "",
                        a = t)
                    }),
                    a)
                        return l.msg("\u6587\u4ef6\u5927\u5c0f\u4e0d\u80fd\u8d85\u8fc7 " + a);
                if (!r.before || !1 !== r.before(h))
                    y.ie ? (9 < y.ie ? c : s)() : c()
            }
        }
    }
    ,
    x.prototype.reload = function(e) {
        delete (e = e || {}).elem,
        delete e.bindAction;
        (e = this.config = v.extend({}, this.config, i.config, e)).elem.next().attr({
            name: e.name,
            accept: e.acceptMime,
            multiple: e.multiple
        })
    }
    ,
    x.prototype.events = function() {
        var n = this
          , o = n.config
          , a = function(e) {
            n.chooseFiles = {},
            layui.each(e, function(e, t) {
                var i = (new Date).getTime();
                n.chooseFiles[i + "-" + e] = t
            })
        }
          , l = function(e, t) {
            var i = n.elemFile
              , e = (o.item || o.elem,
            1 < e.length ? e.length + "\u4e2a\u6587\u4ef6" : (e[0] || {}).name || i[0].value.match(/[^\/\\]+\..+/g) || [] || "");
            i.next().hasClass(b) && i.next().remove(),
            n.upload(null, "choose"),
            n.isFile() || o.choose || i.after('<span class="layui-inline ' + b + '">' + e + "</span>")
        };
        o.elem.off("upload.start").on("upload.start", function() {
            var e = v(this)
              , t = e.attr("lay-data");
            if (t)
                try {
                    t = new Function("return " + t)(),
                    n.config = v.extend({}, o, t)
                } catch (i) {
                    r.error("Upload element property lay-data configuration item has a syntax error: " + t)
                }
            n.config.item = e,
            n.elemFile[0].click()
        }),
        y.ie && y.ie < 10 || o.elem.off("upload.over").on("upload.over", function() {
            v(this).attr("lay-over", "")
        }).off("upload.leave").on("upload.leave", function() {
            v(this).removeAttr("lay-over")
        }).off("upload.drop").on("upload.drop", function(e, t) {
            var i = v(this)
              , t = t.originalEvent.dataTransfer.files || [];
            i.removeAttr("lay-over"),
            a(t),
            o.auto ? n.upload() : l(t)
        }),
        n.elemFile.off("upload.change").on("upload.change", function() {
            var e = this.files || [];
            a(e),
            o.auto ? n.upload() : l(e)
        }),
        o.bindAction.off("upload.action").on("upload.action", function() {
            n.upload()
        }),
        o.elem.data("haveEvents") || (n.elemFile.on("change", function() {
            v(this).trigger("upload.change")
        }),
        o.elem.on("click", function() {
            n.isFile() || v(this).trigger("upload.start")
        }),
        o.drag && o.elem.on("dragover", function(e) {
            e.preventDefault(),
            v(this).trigger("upload.over")
        }).on("dragleave", function(e) {
            v(this).trigger("upload.leave")
        }).on("drop", function(e) {
            e.preventDefault(),
            v(this).trigger("upload.drop", e)
        }),
        o.bindAction.on("click", function() {
            v(this).trigger("upload.action")
        }),
        o.elem.data("haveEvents", !0))
    }
    ,
    i.render = function(e) {
        e = new x(e);
        return function() {
            var t = this;
            return {
                upload: function(e) {
                    t.upload.call(t, e)
                },
                reload: function(e) {
                    t.reload.call(t, e)
                },
                config: t.config
            }
        }
        .call(e)
    }
    ,
    e(n, i)
});
layui.define("layer", function(e) {
    "use strict";
    var C = layui.$
      , h = layui.layer
      , l = layui.hint()
      , w = (layui.device(),
    "form")
      , s = ".layui-form"
      , T = "layui-this"
      , $ = "layui-hide"
      , E = "layui-disabled"
      , t = function() {
        this.config = {
            verify: {
                required: [/[\S]+/, "\u5fc5\u586b\u9879\u4e0d\u80fd\u4e3a\u7a7a"],
                phone: [/^1\d{10}$/, "\u8bf7\u8f93\u5165\u6b63\u786e\u7684\u624b\u673a\u53f7"],
                email: [/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "\u90ae\u7bb1\u683c\u5f0f\u4e0d\u6b63\u786e"],
                url: [/^(#|(http(s?)):\/\/|\/\/)[^\s]+\.[^\s]+$/, "\u94fe\u63a5\u683c\u5f0f\u4e0d\u6b63\u786e"],
                number: function(e) {
                    if (!e || isNaN(e))
                        return "\u53ea\u80fd\u586b\u5199\u6570\u5b57"
                },
                date: [/^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "\u65e5\u671f\u683c\u5f0f\u4e0d\u6b63\u786e"],
                identity: [/(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "\u8bf7\u8f93\u5165\u6b63\u786e\u7684\u8eab\u4efd\u8bc1\u53f7"]
            },
            autocomplete: null
        }
    }
      , i = (t.prototype.set = function(e) {
        return C.extend(!0, this.config, e),
        this
    }
    ,
    t.prototype.verify = function(e) {
        return C.extend(!0, this.config.verify, e),
        this
    }
    ,
    t.prototype.getFormElem = function(e) {
        return C(s + (e ? '[lay-filter="' + e + '"]' : ""))
    }
    ,
    t.prototype.on = function(e, t) {
        return layui.onevent.call(this, w, e, t)
    }
    ,
    t.prototype.val = function(e, i) {
        return this.getFormElem(e).each(function(e, t) {
            var a = C(this);
            layui.each(i, function(e, t) {
                var i, e = a.find('[name="' + e + '"]');
                e[0] && ("checkbox" === (i = e[0].type) ? e[0].checked = t : "radio" === i ? e.each(function() {
                    this.value == t && (this.checked = !0)
                }) : e.val(t))
            })
        }),
        r.render(null, e),
        this.getValue(e)
    }
    ,
    t.prototype.getValue = function(e, t) {
        t = t || this.getFormElem(e);
        var a = {}
          , n = {}
          , e = t.find("input,select,textarea");
        return layui.each(e, function(e, t) {
            var i;
            C(this);
            t.name = (t.name || "").replace(/^\s*|\s*&/, ""),
            t.name && (/^.*\[\]$/.test(t.name) && (i = t.name.match(/^(.*)\[\]$/g)[0],
            a[i] = 0 | a[i],
            i = t.name.replace(/^(.*)\[\]$/, "$1[" + a[i]++ + "]")),
            /^checkbox|radio$/.test(t.type) && !t.checked || (n[i || t.name] = t.value))
        }),
        n
    }
    ,
    t.prototype.render = function(e, t) {
        var i = this.config
          , a = C(s + (t ? '[lay-filter="' + t + '"]' : ""))
          , n = {
            input: function(e) {
                e = e || a.find("input,textarea");
                i.autocomplete && e.attr("autocomplete", i.autocomplete)
            },
            select: function(e) {
                var p, c = "\u8bf7\u9009\u62e9", m = "layui-form-select", g = "layui-select-title", k = "layui-select-none", x = "", e = e || a.find("select"), b = function(e, t) {
                    C(e.target).parent().hasClass(g) && !t || (C("." + m).removeClass(m + "ed " + m + "up"),
                    p && x && p.val(x)),
                    p = null
                }, u = function(a, e, t) {
                    var o, r, i, n, s, l, c = C(this), u = a.find("." + g), d = u.find("input"), f = a.find("dl"), h = f.children("dd"), y = f.children("dt"), v = this.selectedIndex;
                    e || (r = c.attr("lay-search"),
                    i = function() {
                        var e = a.offset().top + a.outerHeight() + 5 - q.scrollTop()
                          , t = f.outerHeight();
                        v = c[0].selectedIndex,
                        a.addClass(m + "ed"),
                        h.removeClass($),
                        y.removeClass($),
                        o = null,
                        h.eq(v).addClass(T).siblings().removeClass(T),
                        e + t > q.height() && t <= e && a.addClass(m + "up"),
                        s()
                    }
                    ,
                    n = function(e) {
                        a.removeClass(m + "ed " + m + "up"),
                        d.blur(),
                        o = null,
                        e || l(d.val(), function(e) {
                            var t = c[0].selectedIndex;
                            e && (x = C(c[0].options[t]).html(),
                            0 === t && x === d.attr("placeholder") && (x = ""),
                            d.val(x || ""))
                        })
                    }
                    ,
                    s = function() {
                        var e, t, i = f.children("dd." + T);
                        i[0] && (e = i.position().top,
                        t = f.height(),
                        i = i.height(),
                        t < e && f.scrollTop(e + f.scrollTop() - t + i - 5),
                        e < 0 && f.scrollTop(e + f.scrollTop() - 5))
                    }
                    ,
                    u.on("click", function(e) {
                        a.hasClass(m + "ed") ? n() : (b(e, !0),
                        i()),
                        f.find("." + k).remove()
                    }),
                    u.find(".layui-edge").on("click", function() {
                        d.focus()
                    }),
                    d.on("keyup", function(e) {
                        9 === e.keyCode && i()
                    }).on("keydown", function(l) {
                        var e = l.keyCode
                          , r = (9 === e && n(),
                        function(a, n) {
                            l.preventDefault();
                            var e = function() {
                                var e = f.children("dd." + T);
                                if (f.children("dd." + $)[0] && "next" === a) {
                                    var t = f.children("dd:not(." + $ + ",." + E + ")")
                                      , i = t.eq(0).index();
                                    if (0 <= i && i < e.index() && !t.hasClass(T))
                                        return t.eq(0).prev()[0] ? t.eq(0).prev() : f.children(":last")
                                }
                                return n && n[0] ? n : o && o[0] ? o : e
                            }()
                              , t = e[a]()
                              , i = e[a]("dd:not(." + $ + ")");
                            return t[0] ? (o = e[a](),
                            i[0] && !i.hasClass(E) || !o[0] ? (i.addClass(T).siblings().removeClass(T),
                            void s()) : r(a, o)) : o = null
                        }
                        );
                        38 === e && r("prev"),
                        40 === e && r("next"),
                        13 === e && (l.preventDefault(),
                        f.children("dd." + T).trigger("click"))
                    }),
                    l = function(a, e, n) {
                        var l = 0
                          , t = (layui.each(h, function() {
                            var e = C(this)
                              , t = e.text()
                              , i = ("exact" !== r && (t = t.toLowerCase(),
                            a = a.toLowerCase()),
                            -1 === t.indexOf(a));
                            ("" === a || "blur" === n ? a !== t : i) && l++,
                            "keyup" === n && e[i ? "addClass" : "removeClass"]($)
                        }),
                        "keyup" === n && layui.each(y, function() {
                            var e = C(this)
                              , t = e.nextUntil("dt").filter("dd");
                            e[t.length == t.filter("." + $).length ? "addClass" : "removeClass"]($)
                        }),
                        l === h.length);
                        return e(t),
                        t
                    }
                    ,
                    t && d.on("keyup", function(e) {
                        var t = this.value
                          , e = e.keyCode;
                        if (9 === e || 13 === e || 37 === e || 38 === e || 39 === e || 40 === e)
                            return !1;
                        l(t, function(e) {
                            e ? f.find("." + k)[0] || f.append('<p class="' + k + '">\u65e0\u5339\u914d\u9879</p>') : f.find("." + k).remove()
                        }, "keyup"),
                        "" === t && f.find("." + k).remove(),
                        s()
                    }).on("blur", function(e) {
                        var t = c[0].selectedIndex;
                        p = d,
                        x = C(c[0].options[t]).html(),
                        0 === t && x === d.attr("placeholder") && (x = ""),
                        setTimeout(function() {
                            l(d.val(), function(e) {
                                x || d.val("")
                            }, "blur")
                        }, 200)
                    }),
                    h.on("click", function() {
                        var e = C(this)
                          , t = e.attr("lay-value")
                          , i = c.attr("lay-filter");
                        return e.hasClass(E) || (e.hasClass("layui-select-tips") ? d.val("") : (d.val(e.text()),
                        e.addClass(T)),
                        e.siblings().removeClass(T),
                        c.val(t).removeClass("layui-form-danger"),
                        layui.event.call(this, w, "select(" + i + ")", {
                            elem: c[0],
                            value: t,
                            othis: a
                        }),
                        n(!0)),
                        !1
                    }),
                    a.find("dl>dt").on("click", function(e) {
                        return !1
                    }),
                    C(document).off("click", b).on("click", b))
                };
                e.each(function(e, t) {
                    var i = C(this)
                      , a = i.next("." + m)
                      , n = this.disabled
                      , l = t.value
                      , r = C(t.options[t.selectedIndex])
                      , t = t.options[0];
                    if ("string" == typeof i.attr("lay-ignore"))
                        return i.show();
                    var o, s = "string" == typeof i.attr("lay-search"), t = t && !t.value && t.innerHTML || c, r = C(['<div class="' + (s ? "" : "layui-unselect ") + m, (n ? " layui-select-disabled" : "") + '">', '<div class="' + g + '">', '<input type="text" placeholder="' + C.trim(t) + '" value="' + C.trim(l ? r.html() : "") + '"' + (!n && s ? "" : " readonly") + ' class="layui-input' + (s ? "" : " layui-unselect") + (n ? " " + E : "") + '">', '<i class="layui-edge"></i></div>', '<dl class="layui-anim layui-anim-upbit' + (i.find("optgroup")[0] ? " layui-select-group" : "") + '">', (t = i.find("*"),
                    o = [],
                    layui.each(t, function(e, t) {
                        0 !== e || t.value ? "optgroup" === t.tagName.toLowerCase() ? o.push("<dt>" + t.label + "</dt>") : o.push('<dd lay-value="' + t.value + '" class="' + (l === t.value ? T : "") + (t.disabled ? " " + E : "") + '">' + C.trim(t.innerHTML) + "</dd>") : o.push('<dd lay-value="" class="layui-select-tips">' + C.trim(t.innerHTML || c) + "</dd>")
                    }),
                    0 === o.length && o.push('<dd lay-value="" class="' + E + '">\u6ca1\u6709\u9009\u9879</dd>'),
                    o.join("") + "</dl>"), "</div>"].join(""));
                    a[0] && a.remove(),
                    i.after(r),
                    u.call(this, r, n, s)
                })
            },
            checkbox: function(e) {
                var s = {
                    checkbox: ["layui-form-checkbox", "layui-form-checked", "checkbox"],
                    _switch: ["layui-form-switch", "layui-form-onswitch", "switch"]
                }
                  , e = e || a.find("input[type=checkbox]");
                e.each(function(e, t) {
                    var i = C(this)
                      , a = i.attr("lay-skin")
                      , n = (i.attr("lay-text") || "").split("|")
                      , l = this.disabled
                      , r = s[a = "switch" === a ? "_" + a : a] || s.checkbox;
                    if ("string" == typeof i.attr("lay-ignore"))
                        return i.show();
                    var o = i.next("." + r[0])
                      , t = C(['<div class="layui-unselect ' + r[0], t.checked ? " " + r[1] : "", l ? " layui-checkbox-disabled " + E : "", '"', a ? ' lay-skin="' + a + '"' : "", ">", (l = {
                        checkbox: [t.title.replace(/\s/g, "") ? "<span>" + t.title + "</span>" : "", '<i class="layui-icon layui-icon-ok"></i>'].join(""),
                        _switch: "<em>" + ((t.checked ? n[0] : n[1]) || "") + "</em><i></i>"
                    })[a] || l.checkbox, "</div>"].join(""));
                    o[0] && o.remove(),
                    i.after(t),
                    function(i, a) {
                        var n = C(this);
                        i.on("click", function() {
                            var e = n.attr("lay-filter")
                              , t = (n.attr("lay-text") || "").split("|");
                            n[0].disabled || (n[0].checked ? (n[0].checked = !1,
                            i.removeClass(a[1]).find("em").text(t[1])) : (n[0].checked = !0,
                            i.addClass(a[1]).find("em").text(t[0])),
                            layui.event.call(n[0], w, a[2] + "(" + e + ")", {
                                elem: n[0],
                                value: n[0].value,
                                othis: i
                            }))
                        })
                    }
                    .call(this, t, r)
                })
            },
            radio: function(e) {
                var r = "layui-form-radio"
                  , o = ["&#xe643;", "&#xe63f;"]
                  , e = e || a.find("input[type=radio]");
                e.each(function(e, t) {
                    var i = C(this)
                      , a = i.next("." + r)
                      , n = this.disabled;
                    if ("string" == typeof i.attr("lay-ignore"))
                        return i.show();
                    a[0] && a.remove();
                    n = C(['<div class="layui-unselect ' + r, t.checked ? " " + r + "ed" : "", (n ? " layui-radio-disabled " + E : "") + '">', '<i class="layui-anim layui-icon">' + o[t.checked ? 0 : 1] + "</i>", "<div>" + (a = t.title || "",
                    a = "string" == typeof i.next().attr("lay-radio") ? i.next().html() : a) + "</div>", "</div>"].join(""));
                    i.after(n),
                    function(a) {
                        var n = C(this)
                          , l = "layui-anim-scaleSpring";
                        a.on("click", function() {
                            var e = n[0].name
                              , t = n.parents(s)
                              , i = n.attr("lay-filter")
                              , e = t.find("input[name=" + e.replace(/(\.|#|\[|\])/g, "\\$1") + "]");
                            n[0].disabled || (layui.each(e, function() {
                                var e = C(this).next("." + r);
                                this.checked = !1,
                                e.removeClass(r + "ed"),
                                e.find(".layui-icon").removeClass(l).html(o[1])
                            }),
                            n[0].checked = !0,
                            a.addClass(r + "ed"),
                            a.find(".layui-icon").addClass(l).html(o[0]),
                            layui.event.call(n[0], w, "radio(" + i + ")", {
                                elem: n[0],
                                value: n[0].value,
                                othis: a
                            }))
                        })
                    }
                    .call(this, n)
                })
            }
        };
        return "object" === layui.type(e) ? e.each(function(e, t) {
            var i = C(t);
            i.closest(s).length && ("SELECT" === t.tagName ? n.select(i) : "INPUT" === t.tagName && ("checkbox" === (t = t.type) || "radio" === t ? n[t](i) : n.input(i)))
        }) : e ? n[e] ? n[e]() : l.error('\u4e0d\u652f\u6301\u7684 "' + e + '" \u8868\u5355\u6e32\u67d3') : layui.each(n, function(e, t) {
            t()
        }),
        this
    }
    ,
    t.prototype.validate = function(e) {
        var u = null
          , d = r.config.verify
          , f = "layui-form-danger";
        return !(e = C(e))[0] || (e.attr("lay-verify") !== undefined || !1 !== this.validate(e.find("*[lay-verify]"))) && (layui.each(e, function(e, r) {
            var o = C(this)
              , t = (o.attr("lay-verify") || "").split("|")
              , s = o.attr("lay-verType")
              , c = o.val();
            if (o.removeClass(f),
            layui.each(t, function(e, t) {
                var i = ""
                  , a = d[t];
                if (a) {
                    var n = "function" == typeof a ? i = a(c, r) : !a[0].test(c)
                      , l = "select" === r.tagName.toLowerCase() || /^checkbox|radio$/.test(r.type)
                      , i = i || a[1];
                    if ("required" === t && (i = o.attr("lay-reqText") || i),
                    n)
                        return "tips" === s ? h.tips(i, "string" != typeof o.attr("lay-ignore") && l ? o.next() : o, {
                            tips: 1
                        }) : "alert" === s ? h.alert(i, {
                            title: "\u63d0\u793a",
                            shadeClose: !0
                        }) : /\bstring|number\b/.test(typeof i) && h.msg(i, {
                            icon: 5,
                            shift: 6
                        }),
                        setTimeout(function() {
                            (l ? o.next().find("input") : r).focus()
                        }, 7),
                        o.addClass(f),
                        u = !0
                }
            }),
            u)
                return u
        }),
        !u)
    }
    ,
    t.prototype.submit = function(e, t) {
        var i = C(this)
          , e = "string" == typeof e ? e : i.attr("lay-filter")
          , a = this.getFormElem ? this.getFormElem(e) : i.parents(s).eq(0)
          , n = a.find("*[lay-verify]");
        if (!r.validate(n))
            return !1;
        n = r.getValue(null, a),
        a = {
            elem: this.getFormElem ? window.event && window.event.target : this,
            form: (this.getFormElem ? a : i.parents("form"))[0],
            field: n
        };
        return "function" == typeof t && t(a),
        layui.event.call(this, w, "submit(" + e + ")", a)
    }
    )
      , r = new t
      , t = C(document)
      , q = C(window);
    C(function() {
        r.render()
    }),
    t.on("reset", s, function() {
        var e = C(this).attr("lay-filter");
        setTimeout(function() {
            r.render(null, e)
        }, 50)
    }),
    t.on("submit", s, i).on("click", "*[lay-submit]", i),
    e(w, r)
});
layui.define(["laytpl", "laypage", "form", "util"], function(e) {
    "use strict";
    var m = layui.$
      , v = layui.laytpl
      , r = layui.laypage
      , g = layui.layer
      , y = layui.form
      , b = layui.util
      , f = layui.hint()
      , h = layui.device()
      , x = {
        config: {
            checkName: "LAY_CHECKED",
            indexName: "LAY_TABLE_INDEX",
            disabledName: "LAY_DISABLED"
        },
        cache: {},
        index: layui.table ? layui.table.index + 1e4 : 0,
        set: function(e) {
            var t = this;
            return t.config = m.extend({}, t.config, e),
            t
        },
        on: function(e, t) {
            return layui.onevent.call(this, C, e, t)
        }
    }
      , p = function() {
        var a = this
          , e = a.config
          , i = e.id || e.index;
        return i && (p.that[i] = a,
        p.config[i] = e),
        {
            config: e,
            reload: function(e, t) {
                a.reload.call(a, e, t)
            },
            reloadData: function(e, t) {
                x.reloadData(i, e, t)
            },
            setColsWidth: function() {
                a.setColsWidth.call(a)
            },
            resize: function() {
                a.resize.call(a)
            }
        }
    }
      , l = function(e) {
        var t = p.config[e];
        return t || f.error(e ? "The table instance with ID '" + e + "' not found" : "ID argument required"),
        t || null
    }
      , k = function(e) {
        var t = this.config || {}
          , a = (e = e || {}).item3
          , i = e.content
          , t = (("escape"in a ? a : t).escape && (i = b.escape(i)),
        e.text && a.exportTemplet || a.templet || a.toolbar);
        return t && (i = "function" == typeof t ? t.call(a, e.tplData, e.obj) : v(m(t).html() || String(i)).render(m.extend({
            LAY_COL: a
        }, e.tplData))),
        e.text ? m("<div>" + i + "</div>").text() : i
    }
      , C = "table"
      , w = "layui-hide"
      , c = "layui-hide-v"
      , d = "layui-none"
      , s = "layui-table-view"
      , u = ".layui-table-header"
      , T = ".layui-table-body"
      , L = ".layui-table-pageview"
      , N = ".layui-table-sort"
      , D = "layui-table-edit"
      , A = "layui-table-hover"
      , E = "layui-table-col-special"
      , _ = "LAY_TABLE_MOVE_DICT"
      , t = function(e) {
        return ['<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ', '{{# if(d.data.skin){ }}lay-skin="{{=d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{=d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>', "<thead>", "{{# layui.each(d.data.cols, function(i1, item1){ }}", "<tr>", "{{# layui.each(item1, function(i2, item2){ }}", '{{# if(item2.fixed && item2.fixed !== "right"){ left = true; } }}', '{{# if(item2.fixed === "right"){ right = true; } }}', (e = e || {}).fixed && "right" !== e.fixed ? '{{# if(item2.fixed && item2.fixed !== "right"){ }}' : "right" === e.fixed ? '{{# if(item2.fixed === "right"){ }}' : "", "{{# var isSort = !(item2.colGroup) && item2.sort; }}", '<th data-field="{{= item2.field||i2 }}" data-key="{{=d.index}}-{{=i1}}-{{=i2}}" {{# if( item2.parentKey){ }}data-parentkey="{{= item2.parentKey }}"{{# } }} {{# if(item2.minWidth){ }}data-minwidth="{{=item2.minWidth}}"{{# } }} {{#if(item2.colspan){}} colspan="{{=item2.colspan}}"{{#} if(item2.rowspan){}} rowspan="{{=item2.rowspan}}"{{#}}} {{# if(item2.unresize || item2.colGroup){ }}data-unresize="true"{{# } }} class="{{# if(item2.hide){ }}layui-hide{{# } }}{{# if(isSort){ }} layui-unselect{{# } }}{{# if(!item2.field){ }} layui-table-col-special{{# } }}">', '<div class="layui-table-cell laytable-cell-', "{{# if(item2.colGroup){ }}", "group", "{{# } else { }}", "{{=d.index}}-{{=i1}}-{{=i2}}", '{{# if(item2.type !== "normal"){ }}', " laytable-cell-{{= item2.type }}", "{{# } }}", "{{# } }}", '" {{#if(item2.align){}}align="{{=item2.align}}"{{#}}}>', '{{# if(item2.type === "checkbox"){ }}', '<input type="checkbox" name="layTableCheckbox" lay-skin="primary" lay-filter="layTableAllChoose" {{# if(item2[d.data.checkName]){ }}checked{{# }; }}>', "{{# } else { }}", '<span>{{-item2.title||""}}</span>', "{{# if(isSort){ }}", '<span class="layui-table-sort layui-inline"><i class="layui-edge layui-table-sort-asc" title="\u5347\u5e8f"></i><i class="layui-edge layui-table-sort-desc" title="\u964d\u5e8f"></i></span>', "{{# } }}", "{{# } }}", "</div>", "</th>", e.fixed ? "{{# }; }}" : "", "{{# }); }}", "</tr>", "{{# }); }}", "</thead>", "</table>"].join("")
    }
      , a = ['<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ', '{{# if(d.data.skin){ }}lay-skin="{{=d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{=d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>', "<tbody></tbody>", "</table>"].join("")
      , j = [, "{{# if(d.data.toolbar){ }}", '<div class="layui-table-tool">', '<div class="layui-table-tool-temp"></div>', '<div class="layui-table-tool-self"></div>', "</div>", "{{# } }}", '<div class="layui-table-box">', "{{# if(d.data.loading){ }}", '<div class="layui-table-init" style="background-color: #fff;">', '<i class="layui-icon layui-icon-loading layui-anim layui-anim-rotate layui-anim-loop"></i>', "</div>", "{{# } }}", "{{# var left, right; }}", '<div class="layui-table-header">', t(), "</div>", '<div class="layui-table-body layui-table-main">', a, "</div>", "{{# if(left){ }}", '<div class="layui-table-fixed layui-table-fixed-l">', '<div class="layui-table-header">', t({
        fixed: !0
    }), "</div>", '<div class="layui-table-body">', a, "</div>", "</div>", "{{# }; }}", "{{# if(right){ }}", '<div class="layui-table-fixed layui-table-fixed-r layui-hide">', '<div class="layui-table-header">', t({
        fixed: "right"
    }), '<div class="layui-table-mend"></div>', "</div>", '<div class="layui-table-body">', a, "</div>", "</div>", "{{# }; }}", "</div>", "{{# if(d.data.totalRow){ }}", '<div class="layui-table-total">', '<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ', '{{# if(d.data.skin){ }}lay-skin="{{=d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{=d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>', '<tbody><tr><td><div class="layui-table-cell" style="visibility: hidden;">Total</div></td></tr></tbody>', "</table>", "</div>", "{{# } }}", '<div class="layui-table-column layui-table-page layui-hide">', '<div class="layui-inline layui-table-pageview" id="layui-table-page{{=d.index}}"></div>', "</div>", "<style>", "{{# layui.each(d.data.cols, function(i1, item1){", "layui.each(item1, function(i2, item2){ }}", ".laytable-cell-{{=d.index}}-{{=i1}}-{{=i2}}{ ", "{{# if(item2.width){ }}", "width: {{=item2.width}}px;", "{{# } }}", " }", "{{# });", "}); }}", "{{# if(d.data.lineStyle){", 'var cellClassName = ".layui-table-view-"+ d.index +" .layui-table-body .layui-table .layui-table-cell";', "}}", "{{= cellClassName }}{", "display: -webkit-box; -webkit-box-align: center; white-space: normal; {{- d.data.lineStyle }} ", "}", "{{= cellClassName }}:hover{overflow: auto;}", "{{# } }}", "{{# if(d.data.css){ }}", "{{- d.data.css }}", "{{# } }}", "</style>"].join("")
      , R = m(window)
      , S = m(document)
      , i = function(e) {
        this.index = ++x.index,
        this.config = m.extend({}, this.config, x.config, e),
        this.render()
    }
      , F = (i.prototype.config = {
        limit: 10,
        loading: !0,
        escape: !0,
        cellMinWidth: 60,
        editTrigger: "click",
        defaultToolbar: ["filter", "exports", "print"],
        autoSort: !0,
        text: {
            none: "\u65e0\u6570\u636e"
        }
    },
    i.prototype.render = function(e) {
        var t = this
          , a = t.config;
        if (a.elem = m(a.elem),
        a.where = a.where || {},
        a.id = a.id || a.elem.attr("id") || t.index,
        a.request = m.extend({
            pageName: "page",
            limitName: "limit"
        }, a.request),
        a.response = m.extend({
            statusName: "code",
            statusCode: 0,
            msgName: "msg",
            dataName: "data",
            totalRowName: "totalRow",
            countName: "count"
        }, a.response),
        "object" == typeof a.page && (a.limit = a.page.limit || a.limit,
        a.limits = a.page.limits || a.limits,
        t.page = a.page.curr = a.page.curr || 1,
        delete a.page.elem,
        delete a.page.jump),
        !a.elem[0])
            return t;
        if ("reloadData" === e)
            return t.pullData(t.page, {
                type: "reloadData"
            });
        a.height && /^full-\d+$/.test(a.height) && (t.fullHeightGap = a.height.split("-")[1],
        a.height = R.height() - t.fullHeightGap),
        t.setInit();
        var i, l, e = a.elem, n = e.next("." + s), o = t.elem = m("<div></div>");
        o.addClass((i = [s, s + "-" + t.index, "layui-form", "layui-border-box"],
        a.className && i.push(a.className),
        i.join(" "))).attr({
            "lay-filter": "LAY-TABLE-FORM-DF-" + t.index,
            "lay-id": a.id,
            style: (i = [],
            a.width && i.push("width:" + a.width + "px;"),
            a.height && i.push("height:" + a.height + "px;"),
            i.join(""))
        }).html(v(j).render({
            data: a,
            index: t.index
        })),
        a.index = t.index,
        t.key = a.id || a.index,
        n[0] && n.remove(),
        e.after(o),
        t.layTool = o.find(".layui-table-tool"),
        t.layBox = o.find(".layui-table-box"),
        t.layHeader = o.find(u),
        t.layMain = o.find(".layui-table-main"),
        t.layBody = o.find(T),
        t.layFixed = o.find(".layui-table-fixed"),
        t.layFixLeft = o.find(".layui-table-fixed-l"),
        t.layFixRight = o.find(".layui-table-fixed-r"),
        t.layTotal = o.find(".layui-table-total"),
        t.layPage = o.find(".layui-table-page"),
        t.renderToolbar(),
        t.renderPagebar(),
        t.fullSize(),
        1 < a.cols.length && (i = t.layFixed.find(u).find("th"),
        l = t.layHeader.first(),
        layui.each(i, function(e, t) {
            (t = m(t)).height(l.find('th[data-key="' + t.attr("data-key") + '"]').height() + "px")
        })),
        t.pullData(t.page),
        t.events()
    }
    ,
    i.prototype.initOpts = function(e) {
        this.config;
        e.checkbox && (e.type = "checkbox"),
        e.space && (e.type = "space"),
        e.type || (e.type = "normal"),
        "normal" !== e.type && (e.unresize = !0,
        e.width = e.width || {
            checkbox: 50,
            radio: 50,
            space: 30,
            numbers: 60
        }[e.type])
    }
    ,
    i.prototype.setInit = function(e) {
        var l, a, r = this, c = r.config;
        if (c.clientWidth = c.width || (l = function(e) {
            var t, a = (e = e || c.elem.parent()).width();
            try {
                t = "none" === e.css("display")
            } catch (i) {}
            return !e[0] || a && !t ? a : l(e.parent())
        }
        )(),
        "width" === e)
            return c.clientWidth;
        c.css && -1 === c.css.indexOf(s) && (a = c.css.split("}"),
        layui.each(a, function(e, t) {
            t && (a[e] = "." + s + "-" + r.index + " " + t)
        }),
        c.css = a.join("}"));
        var d = function(a, e, i, l) {
            var n, o;
            l ? (l.key = a + "-" + i,
            l.hide = l.hide || !1,
            l.colspan = l.colspan || 1,
            l.rowspan = l.rowspan || 1,
            r.initOpts(l),
            (n = a + (parseInt(l.rowspan) || 1)) < c.cols.length ? (l.colGroup = !0,
            o = 0,
            layui.each(c.cols[n], function(e, t) {
                t.HAS_PARENT || 1 <= o && o == (l.colspan || 1) || (t.HAS_PARENT = !0,
                t.parentKey = a + "-" + i,
                o += parseInt(1 < t.colspan ? t.colspan : 1),
                d(n, c.cols[n], e, t))
            })) : l.colGroup = !1) : e.splice(i, 1)
        };
        layui.each(c.cols, function(a, i) {
            if (a)
                return !0;
            layui.each(i, function(e, t) {
                d(a, i, e, t)
            })
        })
    }
    ,
    i.prototype.renderToolbar = function() {
        var e = this.config
          , t = ['<div class="layui-inline" lay-event="add"><i class="layui-icon layui-icon-add-1"></i></div>', '<div class="layui-inline" lay-event="update"><i class="layui-icon layui-icon-edit"></i></div>', '<div class="layui-inline" lay-event="delete"><i class="layui-icon layui-icon-delete"></i></div>'].join("")
          , a = this.layTool.find(".layui-table-tool-temp")
          , i = ("default" === e.toolbar ? a.html(t) : "string" == typeof e.toolbar && (t = m(e.toolbar).html() || "") && a.html(v(t).render(e)),
        {
            filter: {
                title: "\u7b5b\u9009\u5217",
                layEvent: "LAYTABLE_COLS",
                icon: "layui-icon-cols"
            },
            exports: {
                title: "\u5bfc\u51fa",
                layEvent: "LAYTABLE_EXPORT",
                icon: "layui-icon-export"
            },
            print: {
                title: "\u6253\u5370",
                layEvent: "LAYTABLE_PRINT",
                icon: "layui-icon-print"
            }
        })
          , l = [];
        "object" == typeof e.defaultToolbar && layui.each(e.defaultToolbar, function(e, t) {
            t = "string" == typeof t ? i[t] : t;
            t && l.push('<div class="layui-inline" title="' + t.title + '" lay-event="' + t.layEvent + '"><i class="layui-icon ' + t.icon + '"></i></div>')
        }),
        this.layTool.find(".layui-table-tool-self").html(l.join(""))
    }
    ,
    i.prototype.renderPagebar = function() {
        var e, t = this.config, a = this.layPagebar = m('<div class="layui-inline layui-table-pagebar"></div>');
        t.pagebar && ((e = m(t.pagebar).html() || "") && a.append(v(e).render(t)),
        this.layPage.append(a))
    }
    ,
    i.prototype.setParentCol = function(e, t) {
        var a = this.config
          , i = this.layHeader.find('th[data-key="' + a.index + "-" + t + '"]')
          , l = parseInt(i.attr("colspan")) || 0;
        i[0] && (t = t.split("-"),
        t = a.cols[t[0]][t[1]],
        e ? l-- : l++,
        i.attr("colspan", l),
        i[l < 1 ? "addClass" : "removeClass"](w),
        t.colspan = l,
        t.hide = l < 1,
        (a = i.data("parentkey")) && this.setParentCol(e, a))
    }
    ,
    i.prototype.setColsPatch = function() {
        var a = this
          , e = a.config;
        layui.each(e.cols, function(e, t) {
            layui.each(t, function(e, t) {
                t.hide && a.setParentCol(t.hide, t.parentKey)
            })
        })
    }
    ,
    i.prototype.setColsWidth = function() {
        var t, a, i = this, o = i.config, l = 0, r = 0, c = 0, d = 0, s = i.setInit("width"), e = (i.eachCols(function(e, t) {
            t.hide || l++
        }),
        s = s - ("line" === o.skin || "nob" === o.skin ? 2 : l + 1) - i.getScrollWidth(i.layMain[0]) - 1,
        function(n) {
            layui.each(o.cols, function(e, l) {
                layui.each(l, function(e, t) {
                    var a = 0
                      , i = t.minWidth || o.cellMinWidth;
                    t ? t.colGroup || t.hide || (n ? c && c < i && (r--,
                    a = i) : (a = t.width || 0,
                    /\d+%$/.test(a) ? (a = Math.floor(parseFloat(a) / 100 * s)) < i && (a = i) : a || (t.width = a = 0,
                    r++)),
                    t.hide && (a = 0),
                    d += a) : l.splice(e, 1)
                })
            }),
            d < s && r && (c = (s - d) / r)
        }
        ), n = (e(),
        e(!0),
        i.autoColNums = r,
        i.eachCols(function(e, t) {
            var a = t.minWidth || o.cellMinWidth;
            t.colGroup || t.hide || (0 === t.width ? i.getCssRule(o.index + "-" + t.key, function(e) {
                e.style.width = Math.floor(a <= c ? c : a) + "px"
            }) : /\d+%$/.test(t.width) && i.getCssRule(o.index + "-" + t.key, function(e) {
                e.style.width = Math.floor(parseFloat(t.width) / 100 * s) + "px"
            }))
        }),
        i.layMain.width() - i.getScrollWidth(i.layMain[0]) - i.layMain.children("table").outerWidth());
        i.autoColNums && -l <= n && n <= l && (e = (a = (t = function(e) {
            return !(e = e || i.layHeader.eq(0).find("thead th:last-child")).data("field") && e.prev()[0] ? t(e.prev()) : e
        }
        )()).data("key"),
        i.getCssRule(e, function(e) {
            var t = e.style.width || a.outerWidth();
            e.style.width = parseFloat(t) + n + "px",
            0 < i.layMain.height() - i.layMain.prop("clientHeight") && (e.style.width = parseFloat(e.style.width) - 1 + "px")
        })),
        i.loading(!0)
    }
    ,
    i.prototype.resize = function() {
        this.fullSize(),
        this.setColsWidth(),
        this.scrollPatch()
    }
    ,
    i.prototype.reload = function(e, t, a) {
        var i = this;
        e = e || {},
        delete i.haveInit,
        layui.each(e, function(e, t) {
            "array" === layui.type(t) && delete i.config[e]
        }),
        i.config = m.extend(t, {}, i.config, e),
        i.render(a)
    }
    ,
    i.prototype.errorView = function(e) {
        var t = this
          , a = t.layMain.find("." + d)
          , e = m('<div class="' + d + '">' + (e || "Error") + "</div>");
        a[0] && (t.layNone.remove(),
        a.remove()),
        t.layFixed.addClass(w),
        t.layMain.find("tbody").html(""),
        t.layMain.append(t.layNone = e),
        t.layTotal.addClass(c),
        t.layPage.find(L).addClass(c),
        x.cache[t.key] = [],
        t.syncCheckAll()
    }
    ,
    i.prototype.page = 1,
    i.prototype.pullData = function(t, a) {
        var e, i = this, l = i.config, n = l.request, o = l.response, r = function() {
            "object" == typeof l.initSort && i.sort(l.initSort.field, l.initSort.type)
        };
        a = a || {},
        "function" == typeof l.before && l.before(l),
        i.startTime = (new Date).getTime(),
        l.url ? ((e = {})[n.pageName] = t,
        e[n.limitName] = l.limit,
        n = m.extend(e, l.where),
        l.contentType && 0 == l.contentType.indexOf("application/json") && (n = JSON.stringify(n)),
        i.loading(),
        m.ajax({
            type: l.method || "get",
            url: l.url,
            contentType: l.contentType,
            data: n,
            dataType: l.dataType || "json",
            jsonpCallback: l.jsonpCallback,
            headers: l.headers || {},
            success: function(e) {
                (e = "function" == typeof l.parseData ? l.parseData(e) || e : e)[o.statusName] != o.statusCode ? (i.renderForm(),
                i.errorView(e[o.msgName] || '\u8fd4\u56de\u7684\u6570\u636e\u4e0d\u7b26\u5408\u89c4\u8303\uff0c\u6b63\u786e\u7684\u6210\u529f\u72b6\u6001\u7801\u5e94\u4e3a\uff1a"' + o.statusName + '": ' + o.statusCode)) : (i.renderData({
                    res: e,
                    curr: t,
                    count: e[o.countName],
                    type: a.type
                }),
                r(),
                l.time = (new Date).getTime() - i.startTime + " ms"),
                i.setColsWidth(),
                "function" == typeof l.done && l.done(e, t, e[o.countName])
            },
            error: function(e, t) {
                i.errorView("\u8bf7\u6c42\u5f02\u5e38\uff0c\u9519\u8bef\u63d0\u793a\uff1a" + t),
                i.renderForm(),
                i.setColsWidth(),
                "function" == typeof l.error && l.error(e, t)
            }
        })) : "array" === layui.type(l.data) && (e = t * l.limit - l.limit,
        (n = {})[o.dataName] = l.data.concat().splice(e, l.limit),
        n[o.countName] = l.data.length,
        "object" == typeof l.totalRow && (n[o.totalRowName] = m.extend({}, l.totalRow)),
        i.renderData({
            res: n,
            curr: t,
            count: n[o.countName],
            type: a.type
        }),
        r(),
        i.setColsWidth(),
        "function" == typeof l.done && l.done(n, t, n[o.countName]))
    }
    ,
    i.prototype.eachCols = function(e) {
        return x.eachCols(null, e, this.config.cols),
        this
    }
    ,
    i.prototype.col = function(e) {
        try {
            return e = e.split("-"),
            this.config.cols[e[1]][e[2]]
        } catch (t) {
            return f.error(t),
            {}
        }
    }
    ,
    i.prototype.renderData = function(e) {
        var u = this
          , y = u.config
          , t = e.res
          , l = e.curr
          , a = e.count
          , n = e.sort
          , i = t[y.response.dataName] || []
          , t = t[y.response.totalRowName]
          , h = []
          , f = []
          , p = []
          , o = function() {
            var s;
            if (y.HAS_SET_COLS_PATCH || u.setColsPatch(),
            y.HAS_SET_COLS_PATCH = !0,
            !n && u.sortKey)
                return u.sort(u.sortKey.field, u.sortKey.sort, !0);
            layui.each(i, function(o, r) {
                var a = []
                  , i = []
                  , c = []
                  , d = o + y.limit * (l - 1) + 1;
                "array" === layui.type(r) && 0 === r.length || (n || (r[x.config.indexName] = o),
                u.eachCols(function(e, l) {
                    var e = l.field || e
                      , t = y.index + "-" + l.key
                      , n = r[e];
                    n !== undefined && null !== n || (n = ""),
                    l.colGroup || (t = ['<td data-field="' + e + '" data-key="' + t + '" ' + (e = [],
                    l.templet && e.push('data-content="' + b.escape(n) + '"'),
                    l.toolbar && e.push('data-off="true"'),
                    l.event && e.push('lay-event="' + l.event + '"'),
                    l.minWidth && e.push('data-minwidth="' + l.minWidth + '"'),
                    e.join(" ")) + ' class="' + (e = [],
                    l.hide && e.push(w),
                    l.field || e.push(E),
                    e.join(" ")) + '">', '<div class="layui-table-cell laytable-cell-' + ("normal" === l.type ? t : t + " laytable-cell-" + l.type) + '"' + (l.align ? ' align="' + l.align + '"' : "") + (e = [],
                    l.style && e.push('style="' + l.style + '"'),
                    e.join(" ")) + ">" + function() {
                        var e, t = m.extend(!0, {
                            LAY_INDEX: d,
                            LAY_COL: l
                        }, r), a = x.config.checkName, i = x.config.disabledName;
                        switch (l.type) {
                        case "checkbox":
                            return '<input type="checkbox" name="layTableCheckbox" lay-skin="primary" ' + (e = [],
                            l[a] && (r[a] = l[a],
                            l[a] && (e[0] = "checked")),
                            t[a] && (e[0] = "checked"),
                            t[i] && e.push("disabled"),
                            e.join(" ")) + ">";
                        case "radio":
                            return t[a] && (s = o),
                            '<input type="radio" name="layTableRadio_' + y.index + '" ' + (e = [],
                            t[a] && (e[0] = "checked"),
                            t[i] && e.push("disabled"),
                            e.join(" ")) + ' lay-type="layTableRadio">';
                        case "numbers":
                            return d
                        }
                        return l.toolbar ? v(m(l.toolbar).html() || "").render(t) : k.call(u, {
                            item3: l,
                            content: n,
                            tplData: t
                        })
                    }(), "</div></td>"].join(""),
                    a.push(t),
                    l.fixed && "right" !== l.fixed && i.push(t),
                    "right" === l.fixed && c.push(t))
                }),
                h.push('<tr data-index="' + o + '">' + a.join("") + "</tr>"),
                f.push('<tr data-index="' + o + '">' + i.join("") + "</tr>"),
                p.push('<tr data-index="' + o + '">' + c.join("") + "</tr>"))
            }),
            "fixed" === y.scrollPos && "reloadData" === e.type || u.layBody.scrollTop(0),
            "reset" === y.scrollPos && u.layBody.scrollLeft(0),
            u.layMain.find("." + d).remove(),
            u.layMain.find("tbody").html(h.join("")),
            u.layFixLeft.find("tbody").html(f.join("")),
            u.layFixRight.find("tbody").html(p.join("")),
            u.renderForm(),
            "number" == typeof s && u.setThisRowChecked(s),
            u.syncCheckAll(),
            u.fullSize(),
            u.haveInit ? u.scrollPatch() : setTimeout(function() {
                u.scrollPatch()
            }, 50),
            u.haveInit = !0,
            g.close(u.tipsIndex)
        };
        return x.cache[u.key] = i,
        u.layTotal[0 == i.length ? "addClass" : "removeClass"](c),
        u.layPage[y.page || y.pagebar ? "removeClass" : "addClass"](w),
        u.layPage.find(L)[!y.page || 0 == a || 0 === i.length && 1 == l ? "addClass" : "removeClass"](c),
        0 === i.length ? (u.renderForm(),
        u.errorView(y.text.none)) : (u.layFixLeft.removeClass(w),
        n ? o() : (o(),
        u.renderTotal(i, t),
        u.layTotal && u.layTotal.removeClass(w),
        void (y.page && (y.page = m.extend({
            elem: "layui-table-page" + y.index,
            count: a,
            limit: y.limit,
            limits: y.limits || [10, 20, 30, 40, 50, 60, 70, 80, 90],
            groups: 3,
            layout: ["prev", "page", "next", "skip", "count", "limit"],
            prev: '<i class="layui-icon">&#xe603;</i>',
            next: '<i class="layui-icon">&#xe602;</i>',
            jump: function(e, t) {
                t || (u.page = e.curr,
                y.limit = e.limit,
                u.pullData(e.curr))
            }
        }, y.page),
        y.page.count = a,
        r.render(y.page)))))
    }
    ,
    i.prototype.renderTotal = function(e, o) {
        var r, c = this, d = c.config, s = {};
        d.totalRow && (layui.each(e, function(e, i) {
            "array" === layui.type(i) && 0 === i.length || c.eachCols(function(e, t) {
                var e = t.field || e
                  , a = i[e];
                t.totalRow && (s[e] = (s[e] || 0) + (parseFloat(a) || 0))
            })
        }),
        c.dataTotal = {},
        r = [],
        c.eachCols(function(e, t) {
            var a, e = t.field || e, i = o && o[t.field], l = (a = t.totalRowText || "",
            n = "totalRowDecimals"in t ? t.totalRowDecimals : 2,
            n = parseFloat(s[e]).toFixed(n),
            (l = {
                LAY_COL: t
            })[e] = n,
            n = t.totalRow && k.call(c, {
                item3: t,
                content: n,
                tplData: l
            }) || a,
            i || n), n = ['<td data-field="' + e + '" data-key="' + d.index + "-" + t.key + '" ' + (a = [],
            t.align && a.push('align="' + t.align + '"'),
            t.minWidth && a.push('data-minwidth="' + t.minWidth + '"'),
            a.join(" ")) + ' class="' + (n = [],
            t.hide && n.push(w),
            t.field || n.push(E),
            n.join(" ")) + '">', '<div class="layui-table-cell laytable-cell-' + (a = d.index + "-" + t.key,
            "normal" === t.type ? a : a + " laytable-cell-" + t.type) + '"' + (n = [],
            t.style && n.push('style="' + t.style + '"'),
            n.join(" ")) + ">" + ("string" == typeof (a = t.totalRow || d.totalRow) ? v(a).render(m.extend({
                TOTAL_NUMS: i || s[e],
                LAY_COL: t
            }, t)) : l), "</div></td>"].join("");
            t.field && (c.dataTotal[e] = l),
            r.push(n)
        }),
        c.layTotal.find("tbody").html("<tr>" + r.join("") + "</tr>"))
    }
    ,
    i.prototype.getColElem = function(e, t) {
        var a = this.config;
        return e.eq(0).find(".laytable-cell-" + a.index + "-" + t + ":eq(0)")
    }
    ,
    i.prototype.renderForm = function(e) {
        this.config;
        var t = this.elem.attr("lay-filter");
        y.render(e, t)
    }
    ,
    i.prototype.setThisRowChecked = function(e) {
        this.config;
        var t = "layui-table-click";
        this.layBody.find('tr[data-index="' + e + '"]').addClass(t).siblings("tr").removeClass(t)
    }
    ,
    i.prototype.sort = function(l, e, t, a) {
        var i, n = this, o = {}, r = n.config, c = r.elem.attr("lay-filter"), d = x.cache[n.key];
        "string" == typeof l && (s = l,
        n.layHeader.find("th").each(function(e, t) {
            var a = m(this)
              , i = a.data("field");
            if (i === l)
                return l = a,
                s = i,
                !1
        }));
        try {
            var s = s || l.data("field")
              , u = l.data("key");
            if (n.sortKey && !t && s === n.sortKey.field && e === n.sortKey.sort)
                return;
            var y = n.layHeader.find("th .laytable-cell-" + u).find(N);
            n.layHeader.find("th").find(N).removeAttr("lay-sort"),
            y.attr("lay-sort", e || null),
            n.layFixed.find("th")
        } catch (h) {
            f.error("Table modules: sort field '" + s + "' not matched")
        }
        n.sortKey = {
            field: s,
            sort: e
        },
        r.autoSort && ("asc" === e ? i = layui.sort(d, s) : "desc" === e ? i = layui.sort(d, s, !0) : (i = layui.sort(d, x.config.indexName),
        delete n.sortKey,
        delete r.initSort)),
        o[r.response.dataName] = i || d,
        n.renderData({
            res: o,
            curr: n.page,
            count: n.count,
            sort: !0
        }),
        a && (r.initSort = {
            field: s,
            type: e
        },
        layui.event.call(l, C, "sort(" + c + ")", r.initSort))
    }
    ,
    i.prototype.loading = function(e) {
        var t = this;
        t.config.loading && (e ? (t.layInit && t.layInit.remove(),
        delete t.layInit,
        t.layBox.find(".layui-table-init").remove()) : (t.layInit = m(['<div class="layui-table-init">', '<i class="layui-icon layui-icon-loading layui-anim layui-anim-rotate layui-anim-loop"></i>', "</div>"].join("")),
        t.layBox.append(t.layInit)))
    }
    ,
    i.prototype.setCheckData = function(e, t) {
        var a = this.config
          , i = x.cache[this.key];
        i[e] && "array" !== layui.type(i[e]) && (i[e][a.checkName] = t)
    }
    ,
    i.prototype.syncCheckAll = function() {
        var e = this
          , i = e.config
          , t = e.layHeader.find('input[name="layTableCheckbox"]')
          , a = function(a) {
            return e.eachCols(function(e, t) {
                "checkbox" === t.type && (t[i.checkName] = a)
            }),
            a
        };
        t[0] && (x.checkStatus(e.key).isAll ? (t[0].checked || (t.prop("checked", !0),
        e.renderForm("checkbox")),
        a(!0)) : (t[0].checked && (t.prop("checked", !1),
        e.renderForm("checkbox")),
        a(!1)))
    }
    ,
    i.prototype.getCssRule = function(a, i) {
        var e = this.elem.find("style")[0]
          , e = e.sheet || e.styleSheet || {}
          , e = e.cssRules || e.rules;
        layui.each(e, function(e, t) {
            if (t.selectorText === ".laytable-cell-" + a)
                return i(t),
                !0
        })
    }
    ,
    i.prototype.fullSize = function() {
        var e = this
          , t = e.config
          , a = t.height;
        e.fullHeightGap && (a = R.height() - e.fullHeightGap,
        e.elem.css("height", a = a < 135 ? 135 : a)),
        a && (a = parseFloat(a) - (e.layHeader.outerHeight() || 38),
        t.toolbar && (a -= e.layTool.outerHeight() || 50),
        t.totalRow && (a -= e.layTotal.outerHeight() || 40),
        (t.page || t.pagebar) && (a -= e.layPage.outerHeight() || 43),
        e.layMain.outerHeight(a))
    }
    ,
    i.prototype.getScrollWidth = function(e) {
        var t = 0;
        return e ? t = e.offsetWidth - e.clientWidth : ((e = document.createElement("div")).style.width = "100px",
        e.style.height = "100px",
        e.style.overflowY = "scroll",
        document.body.appendChild(e),
        t = e.offsetWidth - e.clientWidth,
        document.body.removeChild(e)),
        t
    }
    ,
    i.prototype.scrollPatch = function() {
        var e = this
          , t = e.layMain.children("table")
          , a = e.layMain.width() - e.layMain.prop("clientWidth")
          , i = e.layMain.height() - e.layMain.prop("clientHeight")
          , l = (e.getScrollWidth(e.layMain[0]),
        t.outerWidth() - e.layMain.width())
          , n = function(e) {
            var t;
            a && i ? (e = e.eq(0)).find(".layui-table-patch")[0] || ((t = m('<th class="layui-table-patch"><div class="layui-table-cell"></div></th>')).find("div").css({
                width: a
            }),
            e.find("tr").append(t)) : e.find(".layui-table-patch").remove()
        };
        n(e.layHeader),
        n(e.layTotal);
        n = e.layMain.height() - i;
        e.layFixed.find(T).css("height", t.height() >= n ? n : "auto"),
        e.layFixRight[0 < l ? "removeClass" : "addClass"](w),
        e.layFixRight.css("right", a - 1)
    }
    ,
    i.prototype.events = function() {
        var s = this
          , c = s.config
          , d = c.elem.attr("lay-filter")
          , e = s.layHeader.find("th")
          , u = ".layui-table-cell"
          , i = m("body")
          , l = {}
          , n = (s.layTool.on("click", "*[lay-event]", function(e) {
            var a, i = m(this), t = i.attr("lay-event"), l = function(e) {
                var t = m(e.list)
                  , a = m('<ul class="layui-table-tool-panel"></ul>');
                a.html(t),
                c.height && a.css("max-height", c.height - (s.layTool.outerHeight() || 50)),
                i.find(".layui-table-tool-panel")[0] || i.append(a),
                s.renderForm(),
                a.on("click", function(e) {
                    layui.stope(e)
                }),
                e.done && e.done(a, t)
            };
            switch (layui.stope(e),
            S.trigger("table.tool.panel.remove"),
            g.close(s.tipsIndex),
            t) {
            case "LAYTABLE_COLS":
                l({
                    list: (a = [],
                    s.eachCols(function(e, t) {
                        t.field && "normal" == t.type && a.push('<li><input type="checkbox" name="' + t.field + '" data-key="' + t.key + '" data-parentkey="' + (t.parentKey || "") + '" lay-skin="primary" ' + (t.hide ? "" : "checked") + ' title="' + b.escape(t.title || t.field) + '" lay-filter="LAY_TABLE_TOOL_COLS"></li>')
                    }),
                    a.join("")),
                    done: function() {
                        y.on("checkbox(LAY_TABLE_TOOL_COLS)", function(e) {
                            var e = m(e.elem)
                              , i = this.checked
                              , l = e.data("key")
                              , n = e.data("parentkey");
                            layui.each(c.cols, function(a, e) {
                                layui.each(e, function(e, t) {
                                    a + "-" + e === l && (e = t.hide,
                                    t.hide = !i,
                                    s.elem.find('*[data-key="' + c.index + "-" + l + '"]')[i ? "removeClass" : "addClass"](w),
                                    e != t.hide && s.setParentCol(!i, n),
                                    s.resize())
                                })
                            })
                        })
                    }
                });
                break;
            case "LAYTABLE_EXPORT":
                h.ie ? g.tips("\u5bfc\u51fa\u529f\u80fd\u4e0d\u652f\u6301 IE\uff0c\u8bf7\u7528 Chrome \u7b49\u9ad8\u7ea7\u6d4f\u89c8\u5668\u5bfc\u51fa", this, {
                    tips: 3
                }) : l({
                    list: ['<li data-type="csv">\u5bfc\u51fa csv \u683c\u5f0f\u6587\u4ef6</li>', '<li data-type="xls">\u5bfc\u51fa xls \u683c\u5f0f\u6587\u4ef6</li>'].join(""),
                    done: function(e, t) {
                        t.on("click", function() {
                            var e = m(this).data("type");
                            x.exportFile.call(s, c.id, null, e)
                        })
                    }
                });
                break;
            case "LAYTABLE_PRINT":
                var n = window.open("about:blank", "_blank")
                  , o = ["<style>", "body{font-size: 12px; color: #5F5F5F;}", "table{width: 100%; border-collapse: collapse; border-spacing: 0;}", "th,td{line-height: 20px; padding: 9px 15px; border: 1px solid #ccc; text-align: left; font-size: 12px; color: #5F5F5F;}", "a{color: #5F5F5F; text-decoration:none;}", "*.layui-hide{display: none}", "</style>"].join("")
                  , r = m(s.layHeader.html());
                r.append(s.layMain.find("table").html()),
                r.append(s.layTotal.find("table").html()),
                r.find("th.layui-table-patch").remove(),
                r.find("thead>tr>th." + E).filter(function(e, t) {
                    return !m(t).children(".laytable-cell-group").length
                }).remove(),
                r.find("tbody>tr>td." + E).remove(),
                n.document.write(o + r.prop("outerHTML")),
                n.document.close(),
                n.print(),
                n.close()
            }
            layui.event.call(this, C, "toolbar(" + d + ")", m.extend({
                event: t,
                config: c
            }, {}))
        }),
        s.layPagebar.on("click", "*[lay-event]", function(e) {
            var t = m(this).attr("lay-event");
            layui.event.call(this, C, "pagebar(" + d + ")", m.extend({
                event: t,
                config: c
            }, {}))
        }),
        e.on("mousemove", function(e) {
            var t = m(this)
              , a = t.offset().left
              , e = e.clientX - a;
            t.data("unresize") || p.eventMoveElem || (l.allowResize = t.width() - e <= 10,
            i.css("cursor", l.allowResize ? "col-resize" : ""))
        }).on("mouseleave", function() {
            m(this);
            p.eventMoveElem || i.css("cursor", "")
        }).on("mousedown", function(e) {
            var t, a = m(this);
            l.allowResize && (t = a.data("key"),
            e.preventDefault(),
            l.offset = [e.clientX, e.clientY],
            s.getCssRule(t, function(e) {
                var t = e.style.width || a.outerWidth();
                l.rule = e,
                l.ruleWidth = parseFloat(t),
                l.minWidth = a.data("minwidth") || c.cellMinWidth
            }),
            a.data(_, l),
            p.eventMoveElem = a)
        }),
        p.docEvent || S.on("mousemove", function(e) {
            var t;
            p.eventMoveElem && (t = p.eventMoveElem.data(_) || {},
            p.eventMoveElem.data("resizing", 1),
            e.preventDefault(),
            t.rule && ((e = t.ruleWidth + e.clientX - t.offset[0]) < t.minWidth && (e = t.minWidth),
            t.rule.style.width = e + "px",
            g.close(s.tipsIndex)))
        }).on("mouseup", function(e) {
            p.eventMoveElem && (l = {},
            i.css("cursor", ""),
            s.scrollPatch(),
            p.eventMoveElem.removeData(_),
            delete p.eventMoveElem)
        }),
        p.docEvent = !0,
        e.on("click", function(e) {
            var t = m(this)
              , a = t.find(N)
              , i = a.attr("lay-sort");
            if (!a[0] || 1 === t.data("resizing"))
                return t.removeData("resizing");
            s.sort(t, "asc" === i ? "desc" : "desc" === i ? null : "asc", null, !0)
        }).find(N + " .layui-edge ").on("click", function(e) {
            var t = m(this)
              , a = t.index()
              , t = t.parents("th").eq(0).data("field");
            layui.stope(e),
            0 === a ? s.sort(t, "asc", null, !0) : s.sort(t, "desc", null, !0)
        }),
        s.commonMember = function(e) {
            var t = m(this).parents("tr").eq(0).data("index")
              , c = s.layBody.find('tr[data-index="' + t + '"]')
              , d = (d = x.cache[s.key] || [])[t] || {};
            return m.extend({
                tr: c,
                data: x.clearCacheKey(d),
                del: function() {
                    x.cache[s.key][t] = [],
                    c.remove(),
                    s.scrollPatch()
                },
                update: function(e, r) {
                    e = e || {},
                    layui.each(e, function(i, l) {
                        var n = c.children('td[data-field="' + i + '"]')
                          , o = n.children(u);
                        i in d && (d[i] = l),
                        s.eachCols(function(e, t) {
                            var a;
                            t.field == i ? (o.html(k.call(s, {
                                item3: t,
                                content: l,
                                tplData: d
                            })),
                            n.data("content", l)) : r && (t.templet || t.toolbar) && (e = c.children('td[data-field="' + (t.field || e) + '"]'),
                            a = d[t.field],
                            e.children(u).html(k.call(s, {
                                item3: t,
                                content: a,
                                tplData: d
                            })),
                            e.data("content", a))
                        })
                    }),
                    s.renderForm()
                }
            }, e)
        }
        )
          , t = (s.elem.on("click", 'input[name="layTableCheckbox"]+', function() {
            var e = m(this).prev()
              , t = s.layBody.find('input[name="layTableCheckbox"]')
              , a = e.parents("tr").eq(0).data("index")
              , i = e[0].checked
              , l = "layTableAllChoose" === e.attr("lay-filter");
            e[0].disabled || (l ? (t.each(function(e, t) {
                t.checked = i,
                s.setCheckData(e, i)
            }),
            s.syncCheckAll(),
            s.renderForm("checkbox")) : (s.setCheckData(a, i),
            s.syncCheckAll()),
            layui.event.call(e[0], C, "checkbox(" + d + ")", n.call(e[0], {
                checked: i,
                type: l ? "all" : "one"
            })))
        }),
        s.elem.on("click", 'input[lay-type="layTableRadio"]+', function() {
            var e = m(this).prev()
              , t = e[0].checked
              , a = x.cache[s.key]
              , i = e.parents("tr").eq(0).data("index");
            layui.each(a, function(e, t) {
                i === e ? t[c.checkName] = !0 : delete t[c.checkName]
            }),
            s.setThisRowChecked(i),
            layui.event.call(this, C, "radio(" + d + ")", n.call(this, {
                checked: t
            }))
        }),
        s.layBody.on("mouseenter", "tr", function() {
            var e = m(this)
              , t = e.index();
            e.data("off") || s.layBody.find("tr:eq(" + t + ")").addClass(A)
        }).on("mouseleave", "tr", function() {
            var e = m(this)
              , t = e.index();
            e.data("off") || s.layBody.find("tr:eq(" + t + ")").removeClass(A)
        }).on("click", "tr", function() {
            t.call(this, "row")
        }).on("dblclick", "tr", function() {
            t.call(this, "rowDouble")
        }),
        function(e) {
            var t = m(this);
            t.data("off") || layui.event.call(this, C, e + "(" + d + ")", n.call(t.children("td")[0]))
        }
        )
          , o = (s.layBody.on("change", "." + D, function() {
            var e = m(this)
              , t = this.value
              , a = e.parent().data("field")
              , e = e.parents("tr").eq(0).data("index");
            x.cache[s.key][e][a] = t,
            layui.event.call(this, C, "edit(" + d + ")", n.call(this, {
                value: t,
                field: a
            }))
        }).on("blur", "." + D, function() {
            var e, t = m(this), a = t.parent(), i = a.data("key"), l = t.closest("tr").data("index"), l = x.cache[s.key][l];
            t.siblings(u).html((e = t[0].value,
            k.call(s, {
                item3: s.col(i),
                content: e,
                tplData: l
            }))),
            a.data("content", t[0].value),
            t.remove()
        }),
        s.layBody.on(c.editTrigger, "td", function(e) {
            var t, a, i, l, n = m(this);
            n.data("off") || (t = n.data("field"),
            l = n.data("key"),
            l = s.col(l),
            a = n.closest("tr").data("index"),
            a = x.cache[s.key][a],
            i = n.children(u),
            (l = "function" == typeof l.edit ? l.edit(a) : l.edit) && ((l = m("textarea" === l ? '<textarea class="layui-input ' + D + '"></textarea>' : '<input class="layui-input ' + D + '">'))[0].value = n.data("content") || a[t] || i.text(),
            n.find("." + D)[0] || n.append(l),
            l.focus(),
            layui.stope(e)))
        }).on("mouseenter", "td", function() {
            a.call(this)
        }).on("mouseleave", "td", function() {
            a.call(this, "hide")
        }),
        "layui-table-grid-down")
          , a = function(e) {
            var t = m(this)
              , a = t.children(u);
            t.data("off") || (e ? t.find(".layui-table-grid-down").remove() : !(a.prop("scrollWidth") > a.outerWidth() || 0 < a.find("br").length) || c.lineStyle || a.find("." + o)[0] || t.append('<div class="' + o + '"><i class="layui-icon layui-icon-down"></i></div>'))
        }
          , r = (s.layBody.on("click", "." + o, function(e) {
            var t = m(this).parent().children(u);
            s.tipsIndex = g.tips(['<div class="layui-table-tips-main" style="margin-top: -' + (t.height() + 23) + "px;" + ("sm" === c.size ? "padding: 4px 15px; font-size: 12px;" : "lg" === c.size ? "padding: 14px 15px;" : "") + '">', t.html(), "</div>", '<i class="layui-icon layui-table-tips-c layui-icon-close"></i>'].join(""), t[0], {
                tips: [3, ""],
                time: -1,
                anim: -1,
                maxWidth: h.ios || h.android ? 300 : s.elem.width() / 2,
                isOutAnim: !1,
                skin: "layui-table-tips",
                success: function(e, t) {
                    e.find(".layui-table-tips-c").on("click", function() {
                        g.close(t)
                    })
                }
            }),
            layui.stope(e)
        }),
        function(e) {
            var t = m(this)
              , a = t.parents("tr").eq(0).data("index");
            layui.event.call(this, C, (e || "tool") + "(" + d + ")", n.call(this, {
                event: t.attr("lay-event")
            })),
            s.setThisRowChecked(a)
        }
        );
        s.layBody.on("click", "*[lay-event]", function() {
            return r.call(this),
            !1
        }).on("dblclick", "*[lay-event]", function() {
            return r.call(this, "toolDouble"),
            !1
        }),
        s.layMain.on("scroll", function() {
            var e = m(this)
              , t = e.scrollLeft()
              , e = e.scrollTop();
            s.layHeader.scrollLeft(t),
            s.layTotal.scrollLeft(t),
            s.layFixed.find(T).scrollTop(e),
            g.close(s.tipsIndex)
        }),
        R.on("resize", function() {
            s.resize()
        })
    }
    ,
    S.on("click", function() {
        S.trigger("table.remove.tool.panel")
    }),
    S.on("table.remove.tool.panel", function() {
        m(".layui-table-tool-panel").remove()
    }),
    x.init = function(a, i) {
        i = i || {};
        var e = m(a ? 'table[lay-filter="' + a + '"]' : ".layui-table[lay-data]")
          , r = "Table element property lay-data configuration item has a syntax error: ";
        return e.each(function() {
            var e = m(this)
              , t = e.attr("lay-data");
            try {
                t = new Function("return " + t)()
            } catch (l) {
                f.error(r + t, "error")
            }
            var n = []
              , o = m.extend({
                elem: this,
                cols: [],
                data: [],
                skin: e.attr("lay-skin"),
                size: e.attr("lay-size"),
                even: "string" == typeof e.attr("lay-even")
            }, x.config, i, t);
            a && e.hide(),
            e.find("thead>tr").each(function(i) {
                o.cols[i] = [],
                m(this).children().each(function(e) {
                    var t = m(this)
                      , a = t.attr("lay-data");
                    try {
                        a = new Function("return " + a)()
                    } catch (l) {
                        return f.error(r + a)
                    }
                    t = m.extend({
                        title: t.text(),
                        colspan: t.attr("colspan") || 1,
                        rowspan: t.attr("rowspan") || 1
                    }, a);
                    t.colspan < 2 && n.push(t),
                    o.cols[i].push(t)
                })
            }),
            e.find("tbody>tr").each(function(e) {
                var a = m(this)
                  , l = {};
                a.children("td").each(function(e, t) {
                    var a = m(this)
                      , i = a.data("field");
                    if (i)
                        return l[i] = a.html()
                }),
                layui.each(n, function(e, t) {
                    e = a.children("td").eq(e);
                    l[t.field] = e.html()
                }),
                o.data[e] = l
            }),
            x.render(o)
        }),
        this
    }
    ,
    p.that = {},
    p.config = {},
    function(a, i, e, l) {
        var n, o;
        l.colGroup && (n = 0,
        a++,
        l.CHILD_COLS = [],
        o = e + (parseInt(l.rowspan) || 1),
        layui.each(i[o], function(e, t) {
            t.parentKey ? t.parentKey === l.key && (t.PARENT_COL_INDEX = a,
            l.CHILD_COLS.push(t),
            F(a, i, o, t)) : t.PARENT_COL_INDEX || 1 <= n && n == (l.colspan || 1) || (t.PARENT_COL_INDEX = a,
            l.CHILD_COLS.push(t),
            n += t.hide ? 0 : parseInt(1 < t.colspan ? t.colspan : 1),
            F(a, i, o, t))
        }))
    }
    );
    x.eachCols = function(e, a, i) {
        var e = p.config[e] || {}
          , l = []
          , n = (i = m.extend(!0, [], i || e.cols),
        layui.each(i, function(a, e) {
            if (a)
                return !0;
            layui.each(e, function(e, t) {
                F(0, i, a, t),
                t.PARENT_COL_INDEX || l.push(t)
            })
        }),
        function(e) {
            layui.each(e || l, function(e, t) {
                if (t.CHILD_COLS)
                    return n(t.CHILD_COLS);
                "function" == typeof a && a(e, t)
            })
        }
        );
        n()
    }
    ,
    x.checkStatus = function(e) {
        var a = 0
          , i = 0
          , l = []
          , e = x.cache[e] || [];
        return layui.each(e, function(e, t) {
            "array" === layui.type(t) ? i++ : t[x.config.checkName] && (a++,
            t[x.config.disabledName] || l.push(x.clearCacheKey(t)))
        }),
        {
            data: l,
            isAll: !!e.length && a === e.length - i
        }
    }
    ,
    x.getData = function(e) {
        var a = []
          , e = x.cache[e] || [];
        return layui.each(e, function(e, t) {
            "array" !== layui.type(t) && a.push(x.clearCacheKey(t))
        }),
        a
    }
    ,
    x.exportFile = function(e, t, a) {
        t = t || x.clearCacheKey(x.cache[e]);
        var r, i, l, c, n = (a = "object" == typeof a ? a : (n = {},
        a && (n.type = a),
        n)).type || "csv", d = p.that[e], o = p.config[e] || {}, s = {
            csv: "text/csv",
            xls: "application/vnd.ms-excel"
        }[n], u = document.createElement("a");
        if (h.ie)
            return f.error("IE_NOT_SUPPORT_EXPORTS");
        u.href = "data:" + s + ";charset=utf-8,\ufeff" + encodeURIComponent((r = [],
        i = [],
        l = [],
        c = {},
        layui.each(t, function(l, n) {
            var o = [];
            "object" == typeof e ? (layui.each(e, function(e, t) {
                0 == l && r.push(t || "")
            }),
            layui.each(x.clearCacheKey(n), function(e, t) {
                o.push('"' + (t || "") + '"')
            })) : x.eachCols(e, function(e, t) {
                var a, i;
                t.field && "normal" == t.type && (t.hide ? 0 == l && (c[t.field] = !0) : (a = n[t.field],
                i = d.layBody.find('tr[data-index="' + l + '"]>td'),
                a !== undefined && null !== a || (a = ""),
                0 == l && r.push(t.title || ""),
                o.push('"' + k.call(d, {
                    item3: t,
                    content: a,
                    tplData: n,
                    text: "text",
                    obj: d.commonMember.call(i.eq(0), {
                        td: function(e) {
                            return i.filter('[data-field="' + e + '"]')
                        }
                    })
                }) + '"')))
            }),
            i.push(o.join(","))
        }),
        d && layui.each(d.dataTotal, function(e, t) {
            c[e] || l.push(t)
        }),
        r.join(",") + "\r\n" + i.join("\r\n") + "\r\n" + l.join(","))),
        u.download = (a.title || o.title || "table_" + (o.index || "")) + "." + n,
        document.body.appendChild(u),
        u.click(),
        document.body.removeChild(u)
    }
    ,
    x.resize = function(e) {
        e ? l(e) && p.that[e].resize() : layui.each(p.that, function() {
            this.resize()
        })
    }
    ,
    x.reload = function(e, t, a, i) {
        if (l(e))
            return e = p.that[e],
            e.reload(t, a, i),
            p.call(e)
    }
    ,
    x.reloadData = function() {
        var a = m.extend([], arguments)
          , i = (a[3] = "reloadData",
        new RegExp("^(" + ["data", "url", "method", "contentType", "dataType", "jsonpCallback", "headers", "where", "page", "limit", "request", "response", "parseData", "scrollPos"].join("|") + ")$"));
        return layui.each(a[1], function(e, t) {
            i.test(e) || delete a[1][e]
        }),
        x.reload.apply(null, a)
    }
    ,
    x.render = function(e) {
        e = new i(e);
        return p.call(e)
    }
    ,
    x.clearCacheKey = function(e) {
        return delete (e = m.extend({}, e))[x.config.checkName],
        delete e[x.config.indexName],
        delete e[x.config.disabledName],
        e
    }
    ,
    m(function() {
        x.init()
    }),
    e(C, x)
});
layui.define("form", function(e) {
    "use strict";
    var u = layui.$
      , i = layui.form
      , p = layui.layer
      , n = "tree"
      , a = {
        config: {},
        index: layui[n] ? layui[n].index + 1e4 : 0,
        set: function(e) {
            var i = this;
            return i.config = u.extend({}, i.config, e),
            i
        },
        on: function(e, i) {
            return layui.onevent.call(this, n, e, i)
        }
    }
      , t = function() {
        var i = this
          , e = i.config
          , n = e.id || i.index;
        return t.that[n] = i,
        {
            config: t.config[n] = e,
            reload: function(e) {
                i.reload.call(i, e)
            },
            getChecked: function() {
                return i.getChecked.call(i)
            },
            setChecked: function(e) {
                return i.setChecked.call(i, e)
            }
        }
    }
      , y = "layui-hide"
      , d = "layui-disabled"
      , f = "layui-tree-set"
      , C = "layui-tree-iconClick"
      , k = "layui-icon-addition"
      , v = "layui-icon-subtraction"
      , m = "layui-tree-entry"
      , x = "layui-tree-main"
      , b = "layui-tree-txt"
      , g = "layui-tree-pack"
      , w = "layui-tree-spread"
      , N = "layui-tree-setLineShort"
      , T = "layui-tree-showLine"
      , L = "layui-tree-lineExtend"
      , l = function(e) {
        var i = this;
        i.index = ++a.index,
        i.config = u.extend({}, i.config, a.config, e),
        i.render()
    };
    l.prototype.config = {
        data: [],
        showCheckbox: !1,
        showLine: !0,
        accordion: !1,
        onlyIconControl: !1,
        isJump: !1,
        edit: !1,
        text: {
            defaultNodeName: "\u672a\u547d\u540d",
            none: "\u65e0\u6570\u636e"
        }
    },
    l.prototype.reload = function(e) {
        var n = this;
        layui.each(e, function(e, i) {
            "array" === layui.type(i) && delete n.config[e]
        }),
        n.config = u.extend(!0, {}, n.config, e),
        n.render()
    }
    ,
    l.prototype.render = function() {
        var e = this
          , i = e.config
          , n = (e.checkids = [],
        u('<div class="layui-tree' + (i.showCheckbox ? " layui-form" : "") + (i.showLine ? " layui-tree-line" : "") + '" lay-filter="LAY-tree-' + e.index + '"></div>'))
          , a = (e.tree(n),
        i.elem = u(i.elem));
        if (a[0]) {
            if (e.key = i.id || e.index,
            e.elem = n,
            e.elemNone = u('<div class="layui-tree-emptyText">' + i.text.none + "</div>"),
            a.html(e.elem),
            0 == e.elem.find(".layui-tree-set").length)
                return e.elem.append(e.elemNone);
            i.showCheckbox && e.renderForm("checkbox"),
            e.elem.find(".layui-tree-set").each(function() {
                var e = u(this);
                e.parent(".layui-tree-pack")[0] || e.addClass("layui-tree-setHide"),
                !e.next()[0] && e.parents(".layui-tree-pack").eq(1).hasClass("layui-tree-lineExtend") && e.addClass(N),
                e.next()[0] || e.parents(".layui-tree-set").eq(0).next()[0] || e.addClass(N)
            }),
            e.events()
        }
    }
    ,
    l.prototype.renderForm = function(e) {
        i.render(e, "LAY-tree-" + this.index)
    }
    ,
    l.prototype.tree = function(l, e) {
        var r = this
          , c = r.config
          , e = e || c.data;
        layui.each(e, function(e, i) {
            var n = i.children && 0 < i.children.length
              , a = u('<div class="layui-tree-pack" ' + (i.spread ? 'style="display: block;"' : "") + "></div>")
              , t = u(['<div data-id="' + i.id + '" class="layui-tree-set' + (i.spread ? " layui-tree-spread" : "") + (i.checked ? " layui-tree-checkedFirst" : "") + '">', '<div class="layui-tree-entry">', '<div class="layui-tree-main">', c.showLine ? n ? '<span class="layui-tree-iconClick layui-tree-icon"><i class="layui-icon ' + (i.spread ? "layui-icon-subtraction" : "layui-icon-addition") + '"></i></span>' : '<span class="layui-tree-iconClick"><i class="layui-icon layui-icon-file"></i></span>' : '<span class="layui-tree-iconClick"><i class="layui-tree-iconArrow ' + (n ? "" : y) + '"></i></span>', c.showCheckbox ? '<input type="checkbox" name="' + (i.field || "layuiTreeCheck_" + i.id) + '" same="layuiTreeCheck" lay-skin="primary" ' + (i.disabled ? "disabled" : "") + ' value="' + i.id + '">' : "", c.isJump && i.href ? '<a href="' + i.href + '" target="_blank" class="' + b + '">' + (i.title || i.label || c.text.defaultNodeName) + "</a>" : '<span class="' + b + (i.disabled ? " " + d : "") + '">' + (i.title || i.label || c.text.defaultNodeName) + "</span>", "</div>", function() {
                if (!c.edit)
                    return "";
                var n = {
                    add: '<i class="layui-icon layui-icon-add-1"  data-type="add"></i>',
                    update: '<i class="layui-icon layui-icon-edit" data-type="update"></i>',
                    del: '<i class="layui-icon layui-icon-delete" data-type="del"></i>'
                }
                  , a = ['<div class="layui-btn-group layui-tree-btnGroup">'];
                return !0 === c.edit && (c.edit = ["update", "del"]),
                "object" == typeof c.edit ? (layui.each(c.edit, function(e, i) {
                    a.push(n[i] || "")
                }),
                a.join("") + "</div>") : void 0
            }(), "</div></div>"].join(""));
            n && (t.append(a),
            r.tree(a, i.children)),
            l.append(t),
            t.prev("." + f)[0] && t.prev().children(".layui-tree-pack").addClass("layui-tree-showLine"),
            n || t.parent(".layui-tree-pack").addClass("layui-tree-lineExtend"),
            r.spread(t, i),
            c.showCheckbox && (i.checked && r.checkids.push(i.id),
            r.checkClick(t, i)),
            c.edit && r.operate(t, i)
        })
    }
    ,
    l.prototype.spread = function(a, e) {
        var t = this.config
          , i = a.children("." + m)
          , n = i.children("." + x)
          , l = i.find("." + C)
          , i = i.find("." + b)
          , r = t.onlyIconControl ? l : n
          , c = "";
        r.on("click", function(e) {
            var i = a.children("." + g)
              , n = (r.children(".layui-icon")[0] ? r : r.find(".layui-tree-icon")).children(".layui-icon");
            i[0] ? a.hasClass(w) ? (a.removeClass(w),
            i.slideUp(200),
            n.removeClass(v).addClass(k)) : (a.addClass(w),
            i.slideDown(200),
            n.addClass(v).removeClass(k),
            t.accordion && ((i = a.siblings("." + f)).removeClass(w),
            i.children("." + g).slideUp(200),
            i.find(".layui-tree-icon").children(".layui-icon").removeClass(v).addClass(k))) : c = "normal"
        }),
        i.on("click", function() {
            u(this).hasClass(d) || (c = a.hasClass(w) ? t.onlyIconControl ? "open" : "close" : t.onlyIconControl ? "close" : "open",
            t.click && t.click({
                elem: a,
                state: c,
                data: e
            }))
        })
    }
    ,
    l.prototype.setCheckbox = function(e, i, n) {
        this.config;
        var t, l = n.prop("checked");
        n.prop("disabled") || ("object" != typeof i.children && !e.find("." + g)[0] || e.find("." + g).find('input[same="layuiTreeCheck"]').each(function() {
            this.disabled || (this.checked = l)
        }),
        (t = function(e) {
            var i, n, a;
            e.parents("." + f)[0] && (n = (e = e.parent("." + g)).parent(),
            a = e.prev().find('input[same="layuiTreeCheck"]'),
            l ? a.prop("checked", l) : (e.find('input[same="layuiTreeCheck"]').each(function() {
                this.checked && (i = !0)
            }),
            i || a.prop("checked", !1)),
            t(n))
        }
        )(e),
        this.renderForm("checkbox"))
    }
    ,
    l.prototype.checkClick = function(n, a) {
        var t = this
          , l = t.config;
        n.children("." + m).children("." + x).on("click", 'input[same="layuiTreeCheck"]+', function(e) {
            layui.stope(e);
            var e = u(this).prev()
              , i = e.prop("checked");
            e.prop("disabled") || (t.setCheckbox(n, a, e),
            l.oncheck && l.oncheck({
                elem: n,
                checked: i,
                data: a
            }))
        })
    }
    ,
    l.prototype.operate = function(c, d) {
        var s = this
          , o = s.config
          , e = c.children("." + m)
          , h = e.children("." + x);
        e.children(".layui-tree-btnGroup").on("click", ".layui-icon", function(e) {
            layui.stope(e);
            var i, e = u(this).data("type"), a = c.children("." + g), t = {
                data: d,
                type: e,
                elem: c
            };
            if ("add" == e) {
                a[0] || (o.showLine ? (h.find("." + C).addClass("layui-tree-icon"),
                h.find("." + C).children(".layui-icon").addClass(k).removeClass("layui-icon-file")) : h.find(".layui-tree-iconArrow").removeClass(y),
                c.append('<div class="layui-tree-pack"></div>'));
                var n, l = o.operate && o.operate(t), r = {};
                if (r.title = o.text.defaultNodeName,
                r.id = l,
                s.tree(c.children("." + g), [r]),
                o.showLine && (a[0] ? (a.hasClass(L) || a.addClass(L),
                c.find("." + g).each(function() {
                    u(this).children("." + f).last().addClass(N)
                }),
                (a.children("." + f).last().prev().hasClass(N) ? a.children("." + f).last().prev() : a.children("." + f).last()).removeClass(N),
                !c.parent("." + g)[0] && c.next()[0] && a.children("." + f).last().removeClass(N)) : (l = c.siblings("." + f),
                n = 1,
                r = c.parent("." + g),
                layui.each(l, function(e, i) {
                    u(i).children("." + g)[0] || (n = 0)
                }),
                1 == n ? (l.children("." + g).addClass(T),
                l.children("." + g).children("." + f).removeClass(N),
                c.children("." + g).addClass(T),
                r.removeClass(L),
                r.children("." + f).last().children("." + g).children("." + f).last().addClass(N)) : c.children("." + g).children("." + f).addClass(N))),
                !o.showCheckbox)
                    return;
                h.find('input[same="layuiTreeCheck"]')[0].checked && (c.children("." + g).children("." + f).last().find('input[same="layuiTreeCheck"]')[0].checked = !0),
                s.renderForm("checkbox")
            } else
                "update" == e ? (l = h.children("." + b).html(),
                h.children("." + b).html(""),
                h.append('<input type="text" class="layui-tree-editInput">'),
                h.children(".layui-tree-editInput").val(l).focus(),
                i = function(e) {
                    var i = (i = e.val().trim()) || o.text.defaultNodeName;
                    e.remove(),
                    h.children("." + b).html(i),
                    t.data.title = i,
                    o.operate && o.operate(t)
                }
                ,
                h.children(".layui-tree-editInput").blur(function() {
                    i(u(this))
                }),
                h.children(".layui-tree-editInput").on("keydown", function(e) {
                    13 === e.keyCode && (e.preventDefault(),
                    i(u(this)))
                })) : p.confirm('\u786e\u8ba4\u5220\u9664\u8be5\u8282\u70b9 "<span style="color: #999;">' + (d.title || "") + '</span>" \u5417\uff1f', function(e) {
                    if (o.operate && o.operate(t),
                    t.status = "remove",
                    p.close(e),
                    !c.prev("." + f)[0] && !c.next("." + f)[0] && !c.parent("." + g)[0])
                        return c.remove(),
                        void s.elem.append(s.elemNone);
                    var l, n, i;
                    c.siblings("." + f).children("." + m)[0] ? (o.showCheckbox && (l = function(e) {
                        var i, n, a, t;
                        e.parents("." + f)[0] && (i = e.siblings("." + f).children("." + m),
                        n = (e = e.parent("." + g).prev()).find('input[same="layuiTreeCheck"]')[0],
                        a = 1,
                        (t = 0) == n.checked && (i.each(function(e, i) {
                            i = u(i).find('input[same="layuiTreeCheck"]')[0];
                            0 != i.checked || i.disabled || (a = 0),
                            i.disabled || (t = 1)
                        }),
                        1 == a && 1 == t && (n.checked = !0,
                        s.renderForm("checkbox"),
                        l(e.parent("." + f)))))
                    }
                    )(c),
                    o.showLine && (e = c.siblings("." + f),
                    n = 1,
                    i = c.parent("." + g),
                    layui.each(e, function(e, i) {
                        u(i).children("." + g)[0] || (n = 0)
                    }),
                    1 == n ? (a[0] || (i.removeClass(L),
                    e.children("." + g).addClass(T),
                    e.children("." + g).children("." + f).removeClass(N)),
                    (c.next()[0] ? i.children("." + f).last() : c.prev()).children("." + g).children("." + f).last().addClass(N),
                    c.next()[0] || c.parents("." + f)[1] || c.parents("." + f).eq(0).next()[0] || c.prev("." + f).addClass(N)) : !c.next()[0] && c.hasClass(N) && c.prev().addClass(N))) : (e = c.parent("." + g).prev(),
                    o.showLine ? (e.find("." + C).removeClass("layui-tree-icon"),
                    e.find("." + C).children(".layui-icon").removeClass(v).addClass("layui-icon-file"),
                    (i = e.parents("." + g).eq(0)).addClass(L),
                    i.children("." + f).each(function() {
                        u(this).children("." + g).children("." + f).last().addClass(N)
                    })) : e.find(".layui-tree-iconArrow").addClass(y),
                    c.parents("." + f).eq(0).removeClass(w),
                    c.parent("." + g).remove()),
                    c.remove()
                })
        })
    }
    ,
    l.prototype.events = function() {
        var i = this
          , t = i.config;
        i.elem.find(".layui-tree-checkedFirst");
        i.setChecked(i.checkids),
        i.elem.find(".layui-tree-search").on("keyup", function() {
            var e = u(this)
              , n = e.val()
              , e = e.nextAll()
              , a = [];
            e.find("." + b).each(function() {
                var i, e = u(this).parents("." + m);
                -1 != u(this).html().indexOf(n) && (a.push(u(this).parent()),
                (i = function(e) {
                    e.addClass("layui-tree-searchShow"),
                    e.parent("." + g)[0] && i(e.parent("." + g).parent("." + f))
                }
                )(e.parent("." + f)))
            }),
            e.find("." + m).each(function() {
                var e = u(this).parent("." + f);
                e.hasClass("layui-tree-searchShow") || e.addClass(y)
            }),
            0 == e.find(".layui-tree-searchShow").length && i.elem.append(i.elemNone),
            t.onsearch && t.onsearch({
                elem: a
            })
        }),
        i.elem.find(".layui-tree-search").on("keydown", function() {
            u(this).nextAll().find("." + m).each(function() {
                u(this).parent("." + f).removeClass("layui-tree-searchShow " + y)
            }),
            u(".layui-tree-emptyText")[0] && u(".layui-tree-emptyText").remove()
        })
    }
    ,
    l.prototype.getChecked = function() {
        var e = this.config
          , i = []
          , n = []
          , t = (this.elem.find(".layui-form-checked").each(function() {
            i.push(u(this).prev()[0].value)
        }),
        function(e, a) {
            layui.each(e, function(e, n) {
                layui.each(i, function(e, i) {
                    if (n.id == i)
                        return delete (i = u.extend({}, n)).children,
                        a.push(i),
                        n.children && (i.children = [],
                        t(n.children, i.children)),
                        !0
                })
            })
        }
        );
        return t(u.extend({}, e.data), n),
        n
    }
    ,
    l.prototype.setChecked = function(l) {
        this.config;
        this.elem.find("." + f).each(function(e, i) {
            var n = u(this).data("id")
              , a = u(i).children("." + m).find('input[same="layuiTreeCheck"]')
              , t = a.next();
            if ("number" == typeof l) {
                if (n == l)
                    return a[0].checked || t.click(),
                    !1
            } else
                "object" == typeof l && layui.each(l, function(e, i) {
                    if (i == n && !a[0].checked)
                        return t.click(),
                        !0
                })
        })
    }
    ,
    t.that = {},
    t.config = {},
    a.reload = function(e, i) {
        e = t.that[e];
        return e.reload(i),
        t.call(e)
    }
    ,
    a.getChecked = function(e) {
        return t.that[e].getChecked()
    }
    ,
    a.setChecked = function(e, i) {
        return t.that[e].setChecked(i)
    }
    ,
    a.render = function(e) {
        e = new l(e);
        return t.call(e)
    }
    ,
    e(n, a)
});
layui.define(["laytpl", "form"], function(e) {
    "use strict";
    var d = layui.$
      , n = layui.laytpl
      , t = layui.form
      , a = "transfer"
      , i = {
        config: {},
        index: layui[a] ? layui[a].index + 1e4 : 0,
        set: function(e) {
            var t = this;
            return t.config = d.extend({}, t.config, e),
            t
        },
        on: function(e, t) {
            return layui.onevent.call(this, a, e, t)
        }
    }
      , l = function() {
        var t = this
          , e = t.config
          , a = e.id || t.index;
        return l.that[a] = t,
        {
            config: l.config[a] = e,
            reload: function(e) {
                t.reload.call(t, e)
            },
            getData: function() {
                return t.getData.call(t)
            }
        }
    }
      , s = "layui-hide"
      , h = "layui-btn-disabled"
      , r = "layui-none"
      , c = "layui-transfer-box"
      , u = "layui-transfer-header"
      , o = "layui-transfer-search"
      , f = "layui-transfer-data"
      , y = function(e) {
        return ['<div class="layui-transfer-box" data-index="' + (e = e || {}).index + '">', '<div class="layui-transfer-header">', '<input type="checkbox" name="' + e.checkAllName + '" lay-filter="layTransferCheckbox" lay-type="all" lay-skin="primary" title="{{ d.data.title[' + e.index + "] || 'list" + (e.index + 1) + "' }}\">", "</div>", "{{# if(d.data.showSearch){ }}", '<div class="layui-transfer-search">', '<i class="layui-icon layui-icon-search"></i>', '<input type="input" class="layui-input" placeholder="\u5173\u952e\u8bcd\u641c\u7d22">', "</div>", "{{# } }}", '<ul class="layui-transfer-data"></ul>', "</div>"].join("")
    }
      , p = ['<div class="layui-transfer layui-form layui-border-box" lay-filter="LAY-transfer-{{ d.index }}">', y({
        index: 0,
        checkAllName: "layTransferLeftCheckAll"
    }), '<div class="layui-transfer-active">', '<button type="button" class="layui-btn layui-btn-sm layui-btn-primary layui-btn-disabled" data-index="0">', '<i class="layui-icon layui-icon-next"></i>', "</button>", '<button type="button" class="layui-btn layui-btn-sm layui-btn-primary layui-btn-disabled" data-index="1">', '<i class="layui-icon layui-icon-prev"></i>', "</button>", "</div>", y({
        index: 1,
        checkAllName: "layTransferRightCheckAll"
    }), "</div>"].join("")
      , v = function(e) {
        var t = this;
        t.index = ++i.index,
        t.config = d.extend({}, t.config, i.config, e),
        t.render()
    };
    v.prototype.config = {
        title: ["\u5217\u8868\u4e00", "\u5217\u8868\u4e8c"],
        width: 200,
        height: 360,
        data: [],
        value: [],
        showSearch: !1,
        id: "",
        text: {
            none: "\u65e0\u6570\u636e",
            searchNone: "\u65e0\u5339\u914d\u6570\u636e"
        }
    },
    v.prototype.reload = function(e) {
        var t = this;
        t.config = d.extend({}, t.config, e),
        t.render()
    }
    ,
    v.prototype.render = function() {
        var e = this
          , t = e.config
          , a = e.elem = d(n(p).render({
            data: t,
            index: e.index
        }))
          , i = t.elem = d(t.elem);
        i[0] && (t.data = t.data || [],
        t.value = t.value || [],
        e.key = t.id || e.index,
        i.html(e.elem),
        e.layBox = e.elem.find("." + c),
        e.layHeader = e.elem.find("." + u),
        e.laySearch = e.elem.find("." + o),
        e.layData = a.find("." + f),
        e.layBtn = a.find(".layui-transfer-active .layui-btn"),
        e.layBox.css({
            width: t.width,
            height: t.height
        }),
        e.layData.css({
            height: (i = t.height - e.layHeader.outerHeight(),
            t.showSearch && (i -= e.laySearch.outerHeight()),
            i - 2)
        }),
        e.renderData(),
        e.events())
    }
    ,
    v.prototype.renderData = function() {
        var e = this
          , i = (e.config,
        [{
            checkName: "layTransferLeftCheck",
            views: []
        }, {
            checkName: "layTransferRightCheck",
            views: []
        }]);
        e.parseData(function(e) {
            var t = e.selected ? 1 : 0
              , a = ["<li>", '<input type="checkbox" name="' + i[t].checkName + '" lay-skin="primary" lay-filter="layTransferCheckbox" title="' + e.title + '"' + (e.disabled ? " disabled" : "") + (e.checked ? " checked" : "") + ' value="' + e.value + '">', "</li>"].join("");
            i[t].views.push(a),
            delete e.selected
        }),
        e.layData.eq(0).html(i[0].views.join("")),
        e.layData.eq(1).html(i[1].views.join("")),
        e.renderCheckBtn()
    }
    ,
    v.prototype.renderForm = function(e) {
        t.render(e, "LAY-transfer-" + this.index)
    }
    ,
    v.prototype.renderCheckBtn = function(r) {
        var c = this
          , o = c.config;
        r = r || {},
        c.layBox.each(function(e) {
            var t = d(this)
              , a = t.find("." + f)
              , t = t.find("." + u).find('input[type="checkbox"]')
              , i = a.find('input[type="checkbox"]')
              , n = 0
              , l = !1;
            i.each(function() {
                var e = d(this).data("hide");
                (this.checked || this.disabled || e) && n++,
                this.checked && !e && (l = !0)
            }),
            t.prop("checked", l && n === i.length),
            c.layBtn.eq(e)[l ? "removeClass" : "addClass"](h),
            r.stopNone || (i = a.children("li:not(." + s + ")").length,
            c.noneView(a, i ? "" : o.text.none))
        }),
        c.renderForm("checkbox")
    }
    ,
    v.prototype.noneView = function(e, t) {
        var a = d('<p class="layui-none">' + (t || "") + "</p>");
        e.find("." + r)[0] && e.find("." + r).remove(),
        t.replace(/\s/g, "") && e.append(a)
    }
    ,
    v.prototype.setValue = function() {
        var e = this.config
          , t = [];
        return this.layBox.eq(1).find("." + f + ' input[type="checkbox"]').each(function() {
            d(this).data("hide") || t.push(this.value)
        }),
        e.value = t,
        this
    }
    ,
    v.prototype.parseData = function(t) {
        var i = this.config
          , n = [];
        return layui.each(i.data, function(e, a) {
            a = ("function" == typeof i.parseData ? i.parseData(a) : a) || a,
            n.push(a = d.extend({}, a)),
            layui.each(i.value, function(e, t) {
                t == a.value && (a.selected = !0)
            }),
            t && t(a)
        }),
        i.data = n,
        this
    }
    ,
    v.prototype.getData = function(e) {
        var t = this.config
          , i = [];
        return this.setValue(),
        layui.each(e || t.value, function(e, a) {
            layui.each(t.data, function(e, t) {
                delete t.selected,
                a == t.value && i.push(t)
            })
        }),
        i
    }
    ,
    v.prototype.transfer = function(e, t) {
        var a, i = this, n = i.config, l = i.layBox.eq(e), r = [], t = (t ? ((a = (t = t).find('input[type="checkbox"]'))[0].checked = !1,
        l.siblings("." + c).find("." + f).append(t.clone()),
        t.remove(),
        r.push(a[0].value),
        i.setValue()) : l.each(function(e) {
            d(this).find("." + f).children("li").each(function() {
                var e = d(this)
                  , t = e.find('input[type="checkbox"]')
                  , a = t.data("hide");
                t[0].checked && !a && (t[0].checked = !1,
                l.siblings("." + c).find("." + f).append(e.clone()),
                e.remove(),
                r.push(t[0].value)),
                i.setValue()
            })
        }),
        i.renderCheckBtn(),
        l.siblings("." + c).find("." + o + " input"));
        "" !== t.val() && t.trigger("keyup"),
        n.onchange && n.onchange(i.getData(r), e)
    }
    ,
    v.prototype.events = function() {
        var n = this
          , a = n.config;
        n.elem.on("click", 'input[lay-filter="layTransferCheckbox"]+', function() {
            var e = d(this).prev()
              , t = e[0].checked
              , a = e.parents("." + c).eq(0).find("." + f);
            e[0].disabled || ("all" === e.attr("lay-type") && a.find('input[type="checkbox"]').each(function() {
                this.disabled || (this.checked = t)
            }),
            setTimeout(function() {
                n.renderCheckBtn({
                    stopNone: !0
                })
            }, 0))
        }),
        n.elem.on("dblclick", "." + f + ">li", function(e) {
            var t = d(this)
              , a = t.children('input[type="checkbox"]')
              , i = t.parent().parent();
            a[0].disabled || n.transfer(i.data("index"), t)
        }),
        n.layBtn.on("click", function() {
            var e = d(this)
              , t = e.data("index");
            e.hasClass(h) || n.transfer(t)
        }),
        n.laySearch.find("input").on("keyup", function() {
            var i = this.value
              , e = d(this).parents("." + o).eq(0).siblings("." + f)
              , t = e.children("li")
              , t = (t.each(function() {
                var e = d(this)
                  , t = e.find('input[type="checkbox"]')
                  , a = -1 !== t[0].title.indexOf(i);
                e[a ? "removeClass" : "addClass"](s),
                t.data("hide", !a)
            }),
            n.renderCheckBtn(),
            t.length === e.children("li." + s).length);
            n.noneView(e, t ? a.text.searchNone : "")
        })
    }
    ,
    l.that = {},
    l.config = {},
    i.reload = function(e, t) {
        e = l.that[e];
        return e.reload(t),
        l.call(e)
    }
    ,
    i.getData = function(e) {
        return l.that[e].getData()
    }
    ,
    i.render = function(e) {
        e = new v(e);
        return l.call(e)
    }
    ,
    e(a, i)
});
layui.define("jquery", function(e) {
    "use strict";
    var a = layui.$
      , n = (layui.hint(),
    layui.device(),
    {
        config: {},
        set: function(e) {
            var i = this;
            return i.config = a.extend({}, i.config, e),
            i
        },
        on: function(e, i) {
            return layui.onevent.call(this, d, e, i)
        }
    })
      , d = "carousel"
      , r = "layui-this"
      , s = "layui-carousel-left"
      , u = "layui-carousel-right"
      , c = "layui-carousel-prev"
      , m = "layui-carousel-next"
      , t = "layui-carousel-arrow"
      , l = "layui-carousel-ind"
      , i = function(e) {
        var i = this;
        i.config = a.extend({}, i.config, n.config, e),
        i.render()
    };
    i.prototype.config = {
        width: "600px",
        height: "280px",
        full: !1,
        arrow: "hover",
        indicator: "inside",
        autoplay: !0,
        interval: 3e3,
        anim: "",
        trigger: "click",
        index: 0
    },
    i.prototype.render = function() {
        var e = this
          , i = e.config;
        i.elem = a(i.elem),
        i.elem[0] && (e.elemItem = i.elem.find(">*[carousel-item]>*"),
        i.index < 0 && (i.index = 0),
        i.index >= e.elemItem.length && (i.index = e.elemItem.length - 1),
        i.interval < 800 && (i.interval = 800),
        i.full ? i.elem.css({
            position: "fixed",
            width: "100%",
            height: "100%",
            zIndex: 9999
        }) : i.elem.css({
            width: i.width,
            height: i.height
        }),
        i.elem.attr("lay-anim", i.anim),
        e.elemItem.eq(i.index).addClass(r),
        e.elemItem.length <= 1 || (e.indicator(),
        e.arrow(),
        e.autoplay(),
        e.events()))
    }
    ,
    i.prototype.reload = function(e) {
        var i = this;
        clearInterval(i.timer),
        i.config = a.extend({}, i.config, e),
        i.render()
    }
    ,
    i.prototype.prevIndex = function() {
        var e = this.config.index - 1;
        return e = e < 0 ? this.elemItem.length - 1 : e
    }
    ,
    i.prototype.nextIndex = function() {
        var e = this.config.index + 1;
        return e = e >= this.elemItem.length ? 0 : e
    }
    ,
    i.prototype.addIndex = function(e) {
        var i = this.config;
        i.index = i.index + (e = e || 1),
        i.index >= this.elemItem.length && (i.index = 0)
    }
    ,
    i.prototype.subIndex = function(e) {
        var i = this.config;
        i.index = i.index - (e = e || 1),
        i.index < 0 && (i.index = this.elemItem.length - 1)
    }
    ,
    i.prototype.autoplay = function() {
        var e = this
          , i = e.config;
        i.autoplay && (clearInterval(e.timer),
        e.timer = setInterval(function() {
            e.slide()
        }, i.interval))
    }
    ,
    i.prototype.arrow = function() {
        var i = this
          , e = i.config
          , n = a(['<button class="layui-icon ' + t + '" lay-type="sub">' + ("updown" === e.anim ? "&#xe619;" : "&#xe603;") + "</button>", '<button class="layui-icon ' + t + '" lay-type="add">' + ("updown" === e.anim ? "&#xe61a;" : "&#xe602;") + "</button>"].join(""));
        e.elem.attr("lay-arrow", e.arrow),
        e.elem.find("." + t)[0] && e.elem.find("." + t).remove(),
        e.elem.append(n),
        n.on("click", function() {
            var e = a(this).attr("lay-type");
            i.slide(e)
        })
    }
    ,
    i.prototype.indicator = function() {
        var i, n = this, t = n.config, e = n.elemInd = a(['<div class="' + l + '"><ul>', (i = [],
        layui.each(n.elemItem, function(e) {
            i.push("<li" + (t.index === e ? ' class="layui-this"' : "") + "></li>")
        }),
        i.join("")), "</ul></div>"].join(""));
        t.elem.attr("lay-indicator", t.indicator),
        t.elem.find("." + l)[0] && t.elem.find("." + l).remove(),
        t.elem.append(e),
        "updown" === t.anim && e.css("margin-top", -e.height() / 2),
        e.find("li").on("hover" === t.trigger ? "mouseover" : t.trigger, function() {
            var e = a(this).index();
            e > t.index ? n.slide("add", e - t.index) : e < t.index && n.slide("sub", t.index - e)
        })
    }
    ,
    i.prototype.slide = function(e, i) {
        var n = this
          , t = n.elemItem
          , a = n.config
          , l = a.index
          , o = a.elem.attr("lay-filter");
        n.haveSlide || ("sub" === e ? (n.subIndex(i),
        t.eq(a.index).addClass(c),
        setTimeout(function() {
            t.eq(l).addClass(u),
            t.eq(a.index).addClass(u)
        }, 50)) : (n.addIndex(i),
        t.eq(a.index).addClass(m),
        setTimeout(function() {
            t.eq(l).addClass(s),
            t.eq(a.index).addClass(s)
        }, 50)),
        setTimeout(function() {
            t.removeClass(r + " " + c + " " + m + " " + s + " " + u),
            t.eq(a.index).addClass(r),
            n.haveSlide = !1
        }, 300),
        n.elemInd.find("li").eq(a.index).addClass(r).siblings().removeClass(r),
        n.haveSlide = !0,
        e = {
            index: a.index,
            prevIndex: l,
            item: t.eq(a.index)
        },
        "function" == typeof a.change && a.change(e),
        layui.event.call(this, d, "change(" + o + ")", e))
    }
    ,
    i.prototype.events = function() {
        var e = this
          , i = e.config;
        i.elem.data("haveEvents") || (i.elem.on("mouseenter", function() {
            "always" !== e.config.autoplay && clearInterval(e.timer)
        }).on("mouseleave", function() {
            "always" !== e.config.autoplay && e.autoplay()
        }),
        i.elem.data("haveEvents", !0))
    }
    ,
    n.render = function(e) {
        return new i(e)
    }
    ,
    e(d, n)
});
layui.define("jquery", function(e) {
    "use strict";
    var u = layui.jquery
      , l = {
        config: {},
        index: layui.rate ? layui.rate.index + 1e4 : 0,
        set: function(e) {
            var a = this;
            return a.config = u.extend({}, a.config, e),
            a
        },
        on: function(e, a) {
            return layui.onevent.call(this, i, e, a)
        }
    }
      , i = "rate"
      , c = "layui-icon-rate"
      , r = "layui-icon-rate-solid"
      , o = "layui-icon-rate-half"
      , s = "layui-icon-rate-solid layui-icon-rate-half"
      , f = "layui-icon-rate layui-icon-rate-half"
      , a = function(e) {
        var a = this;
        a.index = ++l.index,
        a.config = u.extend({}, a.config, l.config, e),
        a.render()
    };
    a.prototype.config = {
        length: 5,
        text: !1,
        readonly: !1,
        half: !1,
        value: 0,
        theme: ""
    },
    a.prototype.render = function() {
        for (var e = this, a = e.config, l = a.theme ? 'style="color: ' + a.theme + ';"' : "", i = (a.elem = u(a.elem),
        a.value > a.length && (a.value = a.length),
        parseInt(a.value) === a.value || a.half || (a.value = Math.ceil(a.value) - a.value < .5 ? Math.ceil(a.value) : Math.floor(a.value)),
        '<ul class="layui-rate" ' + (a.readonly ? "readonly" : "") + ">"), n = 1; n <= a.length; n++) {
            var t = '<li class="layui-inline"><i class="layui-icon ' + (n > Math.floor(a.value) ? c : r) + '" ' + l + "></i></li>";
            a.half && parseInt(a.value) !== a.value && n == Math.ceil(a.value) ? i = i + '<li><i class="layui-icon layui-icon-rate-half" ' + l + "></i></li>" : i += t
        }
        i += "</ul>" + (a.text ? '<span class="layui-inline">' + a.value + "\u661f" : "") + "</span>";
        var o = a.elem
          , s = o.next(".layui-rate");
        s[0] && s.remove(),
        e.elemTemp = u(i),
        a.span = e.elemTemp.next("span"),
        a.setText && a.setText(a.value),
        o.html(e.elemTemp),
        o.addClass("layui-inline"),
        a.readonly || e.action()
    }
    ,
    a.prototype.setvalue = function(e) {
        this.config.value = e,
        this.render()
    }
    ,
    a.prototype.action = function() {
        var i = this.config
          , n = this.elemTemp
          , t = n.find("i").width();
        n.children("li").each(function(e) {
            var a = e + 1
              , l = u(this);
            l.on("click", function(e) {
                i.value = a,
                i.half && e.pageX - u(this).offset().left <= t / 2 && (i.value = i.value - .5),
                i.text && n.next("span").text(i.value + "\u661f"),
                i.choose && i.choose(i.value),
                i.setText && i.setText(i.value)
            }),
            l.on("mousemove", function(e) {
                n.find("i").each(function() {
                    u(this).addClass(c).removeClass(s)
                }),
                n.find("i:lt(" + a + ")").each(function() {
                    u(this).addClass(r).removeClass(f)
                }),
                i.half && e.pageX - u(this).offset().left <= t / 2 && l.children("i").addClass(o).removeClass(r)
            }),
            l.on("mouseleave", function() {
                n.find("i").each(function() {
                    u(this).addClass(c).removeClass(s)
                }),
                n.find("i:lt(" + Math.floor(i.value) + ")").each(function() {
                    u(this).addClass(r).removeClass(f)
                }),
                i.half && parseInt(i.value) !== i.value && n.children("li:eq(" + Math.floor(i.value) + ")").children("i").addClass(o).removeClass("layui-icon-rate-solid layui-icon-rate")
            })
        })
    }
    ,
    a.prototype.events = function() {
        this.config
    }
    ,
    l.render = function(e) {
        e = new a(e);
        return function() {
            var a = this;
            return {
                setvalue: function(e) {
                    a.setvalue.call(a, e)
                },
                config: a.config
            }
        }
        .call(e)
    }
    ,
    e(i, l)
});
layui.define("jquery", function(l) {
    "use strict";
    var g = layui.$
      , e = function(l) {};
    e.prototype.load = function(l) {
        var t, i, n, e, r, o, a, c, m, s, u, f, y, d = this, p = 0, h = g((l = l || {}).elem);
        if (h[0])
            return e = g(l.scrollElem || document),
            r = l.mb || 50,
            o = !("isAuto"in l) || l.isAuto,
            a = l.end || "\u6ca1\u6709\u66f4\u591a\u4e86",
            c = l.scrollElem && l.scrollElem !== document,
            m = "<cite>\u52a0\u8f7d\u66f4\u591a</cite>",
            s = g('<div class="layui-flow-more"><a href="javascript:;">' + m + "</a></div>"),
            h.find(".layui-flow-more")[0] || h.append(s),
            u = function(l, e) {
                l = g(l),
                s.before(l),
                (e = 0 == e || null) ? s.html(a) : s.find("a").html(m),
                i = e,
                t = null,
                y && y()
            }
            ,
            f = function() {
                t = !0,
                s.find("a").html('<i class="layui-anim layui-anim-rotate layui-anim-loop layui-icon ">&#xe63e;</i>'),
                "function" == typeof l.done && l.done(++p, u)
            }
            ,
            f(),
            s.find("a").on("click", function() {
                g(this);
                i || t || f()
            }),
            l.isLazyimg && (y = d.lazyimg({
                elem: l.elem + " img",
                scrollElem: l.scrollElem
            })),
            o && e.on("scroll", function() {
                var e = g(this)
                  , o = e.scrollTop();
                n && clearTimeout(n),
                !i && h.width() && (n = setTimeout(function() {
                    var l = (c ? e : g(window)).height();
                    (c ? e.prop("scrollHeight") : document.documentElement.scrollHeight) - o - l <= r && (t || f())
                }, 100))
            }),
            d
    }
    ,
    e.prototype.lazyimg = function(l) {
        var e, c = this, m = 0, s = g((l = l || {}).scrollElem || document), u = l.elem || "img", f = l.scrollElem && l.scrollElem !== document, y = function(e, l) {
            var o, t = s.scrollTop(), l = t + l, i = f ? e.offset().top - s.offset().top + t : e.offset().top;
            t <= i && i <= l && e.attr("lay-src") && (o = e.attr("lay-src"),
            layui.img(o, function() {
                var l = c.lazyimg.elem.eq(m);
                e.attr("src", o).removeAttr("lay-src"),
                l[0] && n(l),
                m++
            }, function() {
                c.lazyimg.elem.eq(m);
                e.removeAttr("lay-src")
            }))
        }, n = function(l, e) {
            var o = (f ? e || s : g(window)).height()
              , t = s.scrollTop()
              , i = t + o;
            if (c.lazyimg.elem = g(u),
            l)
                y(l, o);
            else
                for (var n = 0; n < c.lazyimg.elem.length; n++) {
                    var r = c.lazyimg.elem.eq(n)
                      , a = f ? r.offset().top - s.offset().top + t : r.offset().top;
                    if (y(r, o),
                    m = n,
                    i < a)
                        break
                }
        };
        return n(),
        s.on("scroll", function() {
            var l = g(this);
            e && clearTimeout(e),
            e = setTimeout(function() {
                n(null, l)
            }, 50)
        }),
        n
    }
    ,
    l("flow", new e)
});
layui.define(["layer", "form"], function(t) {
    "use strict";
    var u = layui.$
      , c = layui.layer
      , a = layui.form
      , d = (layui.hint(),
    layui.device())
      , i = "layedit"
      , y = "layui-disabled"
      , e = function() {
        this.index = 0,
        this.config = {
            tool: ["strong", "italic", "underline", "del", "|", "left", "center", "right", "|", "link", "unlink"],
            hideTool: [],
            height: 280
        }
    }
      , f = (e.prototype.set = function(t) {
        return u.extend(!0, this.config, t),
        this
    }
    ,
    e.prototype.on = function(t, e) {
        return layui.onevent(i, t, e)
    }
    ,
    e.prototype.build = function(t, e) {
        e = e || {};
        var i, l, a = this, n = a.config, o = "layui-layedit", s = u("string" == typeof t ? "#" + t : t), r = "LAY_layedit_" + ++a.index, c = s.next("." + o), n = u.extend({}, n, e), e = (i = [],
        l = {},
        layui.each(n.hideTool, function(t, e) {
            l[e] = !0
        }),
        layui.each(n.tool, function(t, e) {
            C[e] && !l[e] && i.push(C[e])
        }),
        i.join("")), o = u(['<div class="' + o + '">', '<div class="layui-unselect layui-layedit-tool">' + e + "</div>", '<div class="layui-layedit-iframe">', '<iframe id="' + r + '" name="' + r + '" textarea="' + t + '" frameborder="0"></iframe>', "</div>", "</div>"].join(""));
        return d.ie && d.ie < 8 ? s.removeClass("layui-hide").addClass("layui-show") : (c[0] && c.remove(),
        f.call(a, o, s[0], n),
        s.addClass("layui-hide").after(o),
        a.index)
    }
    ,
    e.prototype.getContent = function(t) {
        t = n(t);
        if (t[0])
            return l(t[0].document.body.innerHTML)
    }
    ,
    e.prototype.getText = function(t) {
        t = n(t);
        if (t[0])
            return u(t[0].document.body).text()
    }
    ,
    e.prototype.setContent = function(t, e, i) {
        var l = n(t);
        l[0] && (i ? u(l[0].document.body).append(e) : u(l[0].document.body).html(e),
        layedit.sync(t))
    }
    ,
    e.prototype.sync = function(t) {
        t = n(t);
        t[0] && u("#" + t[1].attr("textarea")).val(l(t[0].document.body.innerHTML))
    }
    ,
    e.prototype.getSelection = function(t) {
        var t = n(t);
        if (t[0])
            return t = p(t[0].document),
            document.selection ? t.text : t.toString()
    }
    ,
    function(a, n, o) {
        var s = this
          , r = a.find("iframe");
        r.css({
            height: o.height
        }).on("load", function() {
            var t = r.contents()
              , e = r.prop("contentWindow")
              , i = t.find("head")
              , l = u(["<style>", "*{margin: 0; padding: 0;}", "body{padding: 10px; line-height: 20px; overflow-x: hidden; word-wrap: break-word; font: 14px Helvetica Neue,Helvetica,PingFang SC,Microsoft YaHei,Tahoma,Arial,sans-serif; -webkit-box-sizing: border-box !important; -moz-box-sizing: border-box !important; box-sizing: border-box !important;}", "a{color:#01AAED; text-decoration:none;}a:hover{color:#c00}", "p{margin-bottom: 10px;}", "img{display: inline-block; border: none; vertical-align: middle;}", "pre{margin: 10px 0; padding: 10px; line-height: 20px; border: 1px solid #ddd; border-left-width: 6px; background-color: #F2F2F2; color: #333; font-family: Courier New; font-size: 12px;}", "</style>"].join(""))
              , t = t.find("body");
            i.append(l),
            t.attr("contenteditable", "true").css({
                "min-height": o.height
            }).html(n.value || ""),
            m.apply(s, [e, r, n, o]),
            g.call(s, e, a, o)
        })
    }
    )
      , n = function(t) {
        t = u("#LAY_layedit_" + t);
        return [t.prop("contentWindow"), t]
    }
      , l = function(t) {
        return t = 8 == d.ie ? t.replace(/<.+>/g, function(t) {
            return t.toLowerCase()
        }) : t
    }
      , m = function(e, t, i, l) {
        var a = e.document
          , n = u(a.body);
        n.on("keydown", function(t) {
            if (13 === t.keyCode) {
                var e = p(a);
                if ("pre" === h(e).parentNode.tagName.toLowerCase())
                    return t.shiftKey ? void 0 : (c.msg("\u8bf7\u6682\u65f6\u7528shift+enter"),
                    !1);
                a.execCommand("formatBlock", !1, "<p>")
            }
        }),
        u(i).parents("form").on("submit", function() {
            var t = n.html();
            8 == d.ie && (t = t.replace(/<.+>/g, function(t) {
                return t.toLowerCase()
            })),
            i.value = t
        }),
        n.on("paste", function(t) {
            a.execCommand("formatBlock", !1, "<p>"),
            setTimeout(function() {
                o.call(e, n),
                i.value = n.html()
            }, 100)
        })
    }
      , o = function(t) {
        this.document;
        t.find("*[style]").each(function() {
            var t = this.style.textAlign;
            this.removeAttribute("style"),
            u(this).css({
                "text-align": t || ""
            })
        }),
        t.find("table").addClass("layui-table"),
        t.find("script,link").remove()
    }
      , p = function(t) {
        return t.selection ? t.selection.createRange() : t.getSelection().getRangeAt(0)
    }
      , h = function(t) {
        return t.endContainer || t.parentElement().childNodes[0]
    }
      , v = function(t, e, i) {
        var l, a, n = this.document, o = document.createElement(t);
        for (l in e)
            o.setAttribute(l, e[l]);
        o.removeAttribute("text"),
        n.selection ? (a = i.text || e.text,
        "a" === t && !a || (a && (o.innerHTML = a),
        i.pasteHTML(u(o).prop("outerHTML")),
        i.select())) : (a = i.toString() || e.text,
        "a" === t && !a || (a && (o.innerHTML = a),
        i.deleteContents(),
        i.insertNode(o)))
    }
      , b = function(e, t) {
        var i = this.document
          , l = "layedit-tool-active"
          , i = h(p(i))
          , a = function(t) {
            return e.find(".layedit-tool-" + t)
        };
        t && t[t.hasClass(l) ? "removeClass" : "addClass"](l),
        e.find(">i").removeClass(l),
        a("unlink").addClass(y),
        u(i).parents().each(function() {
            var t = this.tagName.toLowerCase()
              , e = this.style.textAlign;
            "b" !== t && "strong" !== t || a("b").addClass(l),
            "i" !== t && "em" !== t || a("i").addClass(l),
            "u" === t && a("u").addClass(l),
            "strike" === t && a("d").addClass(l),
            "p" === t && a("center" === e ? "center" : "right" === e ? "right" : "left").addClass(l),
            "a" === t && (a("link").addClass(l),
            a("unlink").removeClass(y))
        })
    }
      , g = function(a, t, e) {
        var n = a.document
          , o = u(n.body)
          , s = {
            link: function(i) {
                var t = h(i)
                  , l = u(t).parent();
                x.call(o, {
                    href: l.attr("href"),
                    target: l.attr("target")
                }, function(t) {
                    var e = l[0];
                    "A" === e.tagName ? e.href = t.url : v.call(a, "a", {
                        target: t.target,
                        href: t.url,
                        text: t.url
                    }, i)
                })
            },
            unlink: function(t) {
                n.execCommand("unlink")
            },
            code: function(e) {
                k.call(o, function(t) {
                    v.call(a, "pre", {
                        text: t.code,
                        "lay-lang": t.lang
                    }, e)
                })
            },
            help: function() {
                c.open({
                    type: 2,
                    title: "\u5e2e\u52a9",
                    area: ["600px", "380px"],
                    shadeClose: !0,
                    shade: .1,
                    skin: "layui-layer-msg",
                    content: ["", "no"]
                })
            }
        }
          , r = t.find(".layui-layedit-tool")
          , i = function() {
            var t, e = u(this), i = e.attr("layedit-event"), l = e.attr("lay-command");
            e.hasClass(y) || (o.focus(),
            (t = p(n)).commonAncestorContainer,
            l ? (n.execCommand(l),
            /justifyLeft|justifyCenter|justifyRight/.test(l) && n.execCommand("formatBlock", !1, "<p>"),
            setTimeout(function() {
                o.focus()
            }, 10)) : s[i] && s[i].call(this, t),
            b.call(a, r, e))
        }
          , l = /image/;
        r.find(">i").on("mousedown", function() {
            var t = u(this).attr("layedit-event");
            l.test(t) || i.call(this)
        }).on("click", function() {
            var t = u(this).attr("layedit-event");
            l.test(t) && i.call(this)
        }),
        o.on("click", function() {
            b.call(a, r)
        })
    }
      , x = function(t, i) {
        var l = this
          , t = c.open({
            type: 1,
            id: "LAY_layedit_link",
            area: "350px",
            shade: .05,
            shadeClose: !0,
            moveType: 1,
            title: "\u8d85\u94fe\u63a5",
            skin: "layui-layer-msg",
            content: ['<ul class="layui-form" style="margin: 15px;">', '<li class="layui-form-item">', '<label class="layui-form-label" style="width: 60px;">URL</label>', '<div class="layui-input-block" style="margin-left: 90px">', '<input name="url" lay-verify="url" value="' + (t.href || "") + '" autofocus="true" autocomplete="off" class="layui-input">', "</div>", "</li>", '<li class="layui-form-item">', '<label class="layui-form-label" style="width: 60px;">\u6253\u5f00\u65b9\u5f0f</label>', '<div class="layui-input-block" style="margin-left: 90px">', '<input type="radio" name="target" value="_self" class="layui-input" title="\u5f53\u524d\u7a97\u53e3"' + ("_self" !== t.target && t.target ? "" : "checked") + ">", '<input type="radio" name="target" value="_blank" class="layui-input" title="\u65b0\u7a97\u53e3" ' + ("_blank" === t.target ? "checked" : "") + ">", "</div>", "</li>", '<li class="layui-form-item" style="text-align: center;">', '<button type="button" lay-submit lay-filter="layedit-link-yes" class="layui-btn"> \u786e\u5b9a </button>', '<button style="margin-left: 20px;" type="button" class="layui-btn layui-btn-primary"> \u53d6\u6d88 </button>', "</li>", "</ul>"].join(""),
            success: function(t, e) {
                a.render("radio"),
                t.find(".layui-btn-primary").on("click", function() {
                    c.close(e),
                    l.focus()
                }),
                a.on("submit(layedit-link-yes)", function(t) {
                    c.close(x.index),
                    i && i(t.field)
                })
            }
        });
        x.index = t
    }
      , k = function(i) {
        var l = this
          , t = c.open({
            type: 1,
            id: "LAY_layedit_code",
            area: "550px",
            shade: .05,
            shadeClose: !0,
            moveType: 1,
            title: "\u63d2\u5165\u4ee3\u7801",
            skin: "layui-layer-msg",
            content: ['<ul class="layui-form layui-form-pane" style="margin: 15px;">', '<li class="layui-form-item">', '<label class="layui-form-label">\u8bf7\u9009\u62e9\u8bed\u8a00</label>', '<div class="layui-input-block">', '<select name="lang">', '<option value="JavaScript">JavaScript</option>', '<option value="HTML">HTML</option>', '<option value="CSS">CSS</option>', '<option value="Java">Java</option>', '<option value="PHP">PHP</option>', '<option value="C#">C#</option>', '<option value="Python">Python</option>', '<option value="Ruby">Ruby</option>', '<option value="Go">Go</option>', "</select>", "</div>", "</li>", '<li class="layui-form-item layui-form-text">', '<label class="layui-form-label">\u4ee3\u7801</label>', '<div class="layui-input-block">', '<textarea name="code" lay-verify="required" autofocus="true" class="layui-textarea" style="height: 200px;"></textarea>', "</div>", "</li>", '<li class="layui-form-item" style="text-align: center;">', '<button type="button" lay-submit lay-filter="layedit-code-yes" class="layui-btn"> \u786e\u5b9a </button>', '<button style="margin-left: 20px;" type="button" class="layui-btn layui-btn-primary"> \u53d6\u6d88 </button>', "</li>", "</ul>"].join(""),
            success: function(t, e) {
                a.render("select"),
                t.find(".layui-btn-primary").on("click", function() {
                    c.close(e),
                    l.focus()
                }),
                a.on("submit(layedit-code-yes)", function(t) {
                    c.close(k.index),
                    i && i(t.field)
                })
            }
        });
        k.index = t
    }
      , C = {
        html: '<i class="layui-icon layedit-tool-html" title="HTML\u6e90\u4ee3\u7801" lay-command="html" layedit-event="html"">&#xe64b;</i><span class="layedit-tool-mid"></span>',
        strong: '<i class="layui-icon layedit-tool-b" title="\u52a0\u7c97" lay-command="Bold" layedit-event="b"">&#xe62b;</i>',
        italic: '<i class="layui-icon layedit-tool-i" title="\u659c\u4f53" lay-command="italic" layedit-event="i"">&#xe644;</i>',
        underline: '<i class="layui-icon layedit-tool-u" title="\u4e0b\u5212\u7ebf" lay-command="underline" layedit-event="u"">&#xe646;</i>',
        del: '<i class="layui-icon layedit-tool-d" title="\u5220\u9664\u7ebf" lay-command="strikeThrough" layedit-event="d"">&#xe64f;</i>',
        "|": '<span class="layedit-tool-mid"></span>',
        left: '<i class="layui-icon layedit-tool-left" title="\u5de6\u5bf9\u9f50" lay-command="justifyLeft" layedit-event="left"">&#xe649;</i>',
        center: '<i class="layui-icon layedit-tool-center" title="\u5c45\u4e2d\u5bf9\u9f50" lay-command="justifyCenter" layedit-event="center"">&#xe647;</i>',
        right: '<i class="layui-icon layedit-tool-right" title="\u53f3\u5bf9\u9f50" lay-command="justifyRight" layedit-event="right"">&#xe648;</i>',
        link: '<i class="layui-icon layedit-tool-link" title="\u63d2\u5165\u94fe\u63a5" layedit-event="link"">&#xe64c;</i>',
        unlink: '<i class="layui-icon layedit-tool-unlink layui-disabled" title="\u6e05\u9664\u94fe\u63a5" lay-command="unlink" layedit-event="unlink"">&#xe64d;</i>',
        face: '<i class="layui-icon layedit-tool-face" title="\u8868\u60c5" layedit-event="face"">&#xe650;</i>',
        image: '<i class="layui-icon layedit-tool-image" title="\u56fe\u7247" layedit-event="image">&#xe64a;<input type="file" name="file"></i>',
        code: '<i class="layui-icon layedit-tool-code" title="\u63d2\u5165\u4ee3\u7801" layedit-event="code">&#xe64e;</i>',
        help: '<i class="layui-icon layedit-tool-help" title="\u5e2e\u52a9" layedit-event="help">&#xe607;</i>'
    }
      , e = new e;
    t(i, e)
});
layui.define(["lay", "util"], function(e) {
    "use strict";
    var d = layui.$
      , o = layui.util
      , u = "layui-code-title"
      , l = {
        elem: ".layui-code",
        title: "&lt;/&gt;",
        about: "",
        ln: !0
    };
    e("code", function(e) {
        var c = e = d.extend({}, l, e);
        e.elem = d(e.elem),
        e.elem[0] && layui.each(e.elem.get().reverse(), function(e, l) {
            var t, a = d(l), i = (i = a.html(),
            d.trim(i).replace(/^\n|\n$/, "")), l = d.extend({}, c, lay.options(l), (t = {},
            layui.each(["title", "height", "encode", "skin", "about"], function(e, l) {
                var i = a.attr("lay-" + l);
                "string" == typeof i && (t[l] = i)
            }),
            t)), s = l.ln ? "ol" : "ul", s = d("<" + s + ' class="layui-code-' + s + '">'), n = d('<div class="' + u + '">');
            a.addClass("layui-code-view layui-box"),
            l.skin && ("notepad" === l.skin && (l.skin = "dark"),
            a.addClass("layui-code-" + l.skin)),
            i = (i = l.encode ? o.escape(i) : i).replace(/[\r\t\n]+/g, "</li><li>"),
            a.html(s.html("<li>" + i + "</li>")),
            a.children("." + u)[0] || (n.html(l.title + (l.about ? '<div class="layui-code-about">' + l.about + "</div>" : "")),
            a.prepend(n)),
            0 < (i = Math.floor(s.find("li").length / 100)) && s.css("margin-left", i + "px"),
            l.height && s.css("max-height", l.height)
        })
    })
}).addcss("modules/code.css?v=3", "skincodecss");