初始上传
This commit is contained in:
160
public/static/ext/layui/lay/modules/autocomplete.js
Executable file
160
public/static/ext/layui/lay/modules/autocomplete.js
Executable file
@@ -0,0 +1,160 @@
|
||||
layui.define(['jquery', 'laytpl', 'layer'], function (e) {
|
||||
"use strict";
|
||||
// layui.link('/resource/css/autocomplete.css');
|
||||
var hint = layui.hint(),
|
||||
$ = layui.jquery,
|
||||
laytpl = layui.laytpl,
|
||||
layer = layui.layer,
|
||||
module = 'autocomplete',
|
||||
filter = 'layui-autocomplete',
|
||||
container = 'layui-form-autocomplete',
|
||||
container_focus = 'layui-form-autocomplete-focus',
|
||||
system = {
|
||||
config: {
|
||||
template: ['<div class="layui-form-autocomplete">', '<dl class="layui-anim layui-anim-upbit">', '</dl>', '</div>'].join(''),
|
||||
layout: ['<dd data-index="{{d.index}}">{{d.text}}</dd>'].join(''),
|
||||
template_txt: '{{d.text}}',
|
||||
template_val: '{{d.value}}',
|
||||
cache: false
|
||||
},
|
||||
index: layui.autocomplete ? layui.autocomplete.index + 1e4: 0,
|
||||
data: {},
|
||||
},
|
||||
callback = function() {
|
||||
var _self = this,
|
||||
_config = _self.config,
|
||||
_id = _config.id;
|
||||
return _id && (callback.config[_id] = _config), {
|
||||
config: _self.config
|
||||
}
|
||||
},
|
||||
job = function(e) {
|
||||
var _self = this;
|
||||
_self.index = ++system.index,
|
||||
_self.config = $.extend({}, _self.config, system.config, e),
|
||||
_self.render()
|
||||
};
|
||||
job.prototype.config = {
|
||||
text: {
|
||||
none: "无数据",
|
||||
loading: "加载中"
|
||||
},
|
||||
response: {
|
||||
code: 'code',
|
||||
data: 'data'
|
||||
},
|
||||
time_limit: 500,
|
||||
ajax: [],
|
||||
_ajax: null,
|
||||
data: [],
|
||||
filter: ''
|
||||
},
|
||||
job.prototype.render = function() {
|
||||
var _self = this, _config = _self.config;
|
||||
if (_config.elem = $(_config.elem), _config.where = _config.where || {}, !_config.elem[0]) return _self;
|
||||
var _elem = _config.elem,
|
||||
_container = _elem.next('.' + container),
|
||||
_html = _self.elem = $(laytpl(_config.template).render({}));
|
||||
_config.id = _self.id, _container[0] && _container.remove(), _elem.attr('autocomplete', 'off'), _elem.after(_html);
|
||||
_self.events()
|
||||
},
|
||||
job.prototype.pullData = function () {
|
||||
var _self = this,
|
||||
_config = _self.config,
|
||||
_elem = _config.elem,
|
||||
_container = _elem.next('.' + container),
|
||||
_dom = _container.find('dl');
|
||||
if (!_config.filter) return _self.renderData([]);
|
||||
if (_config.cache && _config.data[_self.index]) {
|
||||
var arr = [];
|
||||
layui.each(_config.data[_self.index], function (i, e) {
|
||||
if (typeof e === "string") e = new Array(e);
|
||||
layui.each(e, function (_i, _e) {
|
||||
if(_e && _e.toString().toLowerCase().indexOf(_config.filter.toLowerCase()) > -1) {
|
||||
arr.push(e);
|
||||
return false;
|
||||
}
|
||||
});
|
||||
});
|
||||
return _self.renderData(arr);
|
||||
}
|
||||
if (_config.cache && _config.ajax[_self.index] != undefined) return;
|
||||
(!_config.cache && _config.ajax[_self.index] != undefined) && _config.ajax[_self.index].abort(), _config.ajax[_self.index] = $.ajax({
|
||||
type: _config.method || "get",
|
||||
url: _config.url,
|
||||
data: {search_text: _config.filter},
|
||||
dataType: "json",
|
||||
beforeSend: function () {
|
||||
_container.addClass(container_focus), _dom.html(['<dd style="text-align: center" autocomplete-load>', _config.text.loading, '</dd>'].join(''))
|
||||
},
|
||||
success: function (resp) {
|
||||
return 0 != eval('resp.' + _config.response.code) ? layer.msg(eval('resp.' + _config.response.data)) : _config.data[_self.index] = eval('resp.' + _config.response.data), _self.renderData(_config.data[_self.index])
|
||||
},
|
||||
error: function () {
|
||||
hint.error("请求失败")
|
||||
},
|
||||
complete: function () {
|
||||
delete _config.ajax[_self.index]
|
||||
}
|
||||
})
|
||||
},
|
||||
job.prototype.renderData = function (resp) {
|
||||
var _self = this,
|
||||
_config = _self.config,
|
||||
_elem = _config.elem,
|
||||
_container = _elem.next('.' + container),
|
||||
_dom = _container.find('dl'),
|
||||
_list = [];
|
||||
|
||||
layui.each(resp, function (i, e) {
|
||||
_list.push(laytpl(_config.layout).render({index: i, text: laytpl(_config.template_txt).render(e)}));
|
||||
});
|
||||
_dom.html(_list.join('')), _list.length > 0 ? _container.addClass(container_focus) : _container.removeClass(container_focus)
|
||||
},
|
||||
job.prototype.events = function () {
|
||||
var _self = this,
|
||||
_config = _self.config,
|
||||
_elem = _config.elem,
|
||||
_container = _elem.next('.' + container),
|
||||
_dom = _container.find('dl');
|
||||
_elem.on('focus', function () {
|
||||
_config.filter = this.value, _config.cache ? _self.pullData() : _self.renderData(_config.data[_self.index])
|
||||
}).on('input propertychange', function (e) {
|
||||
var _value = this.value;
|
||||
clearTimeout(_config._ajax), _config._ajax = setTimeout(function () {
|
||||
_config.filter = _value, _self.pullData()
|
||||
}, _config.time_limit)
|
||||
}),
|
||||
$(document).on('click', function (e) {
|
||||
var _target = e.target, _item = _dom.find(_target), _e = _item.length > 0 ? _item.closest('dd') : undefined;
|
||||
if (_target === _elem[0]) return false;
|
||||
if (_e !== undefined) {
|
||||
if (_e.attr('autocomplete-load') !== undefined) return false;
|
||||
_elem.val(laytpl(_config.template_val).render(_config.data[_self.index][_e.index()])), _config.onselect == undefined || _config.onselect(_config.data[_self.index][_e.index()])
|
||||
}
|
||||
_container.removeClass(container_focus);
|
||||
})
|
||||
};
|
||||
callback.config = {},
|
||||
callback.job = {},
|
||||
system.init = function (e, c) {
|
||||
var c = c || {}, _self = this, _elems = $(e ? 'input[lay-filter="' + e + '"]': 'input[' + filter + ']');
|
||||
_elems.each(function (_i, _e) {
|
||||
var _elem = $(_e),
|
||||
_lay_data = _elem.attr('lay-data');
|
||||
try {
|
||||
_lay_data = new Function("return " + _lay_data)()
|
||||
} catch (ex) {
|
||||
return hint.error("autocomplete元素属性lay-data配置项存在语法错误:" + _lay_data)
|
||||
}
|
||||
var _config = $.extend({elem: this}, system.config, c, _lay_data);
|
||||
_config.url == undefined && (_config.data == undefined || _config.length === 0) && hint.error("autocomplete配置有误,缺少获取数据方式");
|
||||
system.render(_config);
|
||||
})
|
||||
},
|
||||
system.render = function (e) {
|
||||
var j = new job(e);
|
||||
return callback.call(j)
|
||||
}
|
||||
system.init(), e(module, system);
|
||||
})
|
||||
2
public/static/ext/layui/lay/modules/carousel.js
Executable file
2
public/static/ext/layui/lay/modules/carousel.js
Executable file
@@ -0,0 +1,2 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;layui.define("jquery",function(e){"use strict";var i=layui.$,n=(layui.hint(),layui.device(),{config:{},set:function(e){var n=this;return n.config=i.extend({},n.config,e),n},on:function(e,i){return layui.onevent.call(this,t,e,i)}}),t="carousel",a="layui-this",l=">*[carousel-item]>*",o="layui-carousel-left",r="layui-carousel-right",d="layui-carousel-prev",s="layui-carousel-next",u="layui-carousel-arrow",c="layui-carousel-ind",m=function(e){var t=this;t.config=i.extend({},t.config,n.config,e),t.render()};m.prototype.config={width:"600px",height:"280px",full:!1,arrow:"hover",indicator:"inside",autoplay:!0,interval:3e3,anim:"",trigger:"click",index:0},m.prototype.render=function(){var e=this,n=e.config;n.elem=i(n.elem),n.elem[0]&&(e.elemItem=n.elem.find(l),n.index<0&&(n.index=0),n.index>=e.elemItem.length&&(n.index=e.elemItem.length-1),n.interval<800&&(n.interval=800),n.full?n.elem.css({position:"fixed",width:"100%",height:"100%",zIndex:9999}):n.elem.css({width:n.width,height:n.height}),n.elem.attr("lay-anim",n.anim),e.elemItem.eq(n.index).addClass(a),e.elemItem.length<=1||(e.indicator(),e.arrow(),e.autoplay(),e.events()))},m.prototype.reload=function(e){var n=this;clearInterval(n.timer),n.config=i.extend({},n.config,e),n.render()},m.prototype.prevIndex=function(){var e=this,i=e.config,n=i.index-1;return n<0&&(n=e.elemItem.length-1),n},m.prototype.nextIndex=function(){var e=this,i=e.config,n=i.index+1;return n>=e.elemItem.length&&(n=0),n},m.prototype.addIndex=function(e){var i=this,n=i.config;e=e||1,n.index=n.index+e,n.index>=i.elemItem.length&&(n.index=0)},m.prototype.subIndex=function(e){var i=this,n=i.config;e=e||1,n.index=n.index-e,n.index<0&&(n.index=i.elemItem.length-1)},m.prototype.autoplay=function(){var e=this,i=e.config;i.autoplay&&(clearInterval(e.timer),e.timer=setInterval(function(){e.slide()},i.interval))},m.prototype.arrow=function(){var e=this,n=e.config,t=i(['<button class="layui-icon '+u+'" lay-type="sub">'+("updown"===n.anim?"":"")+"</button>",'<button class="layui-icon '+u+'" lay-type="add">'+("updown"===n.anim?"":"")+"</button>"].join(""));n.elem.attr("lay-arrow",n.arrow),n.elem.find("."+u)[0]&&n.elem.find("."+u).remove(),n.elem.append(t),t.on("click",function(){var n=i(this),t=n.attr("lay-type");e.slide(t)})},m.prototype.indicator=function(){var e=this,n=e.config,t=e.elemInd=i(['<div class="'+c+'"><ul>',function(){var i=[];return layui.each(e.elemItem,function(e){i.push("<li"+(n.index===e?' class="layui-this"':"")+"></li>")}),i.join("")}(),"</ul></div>"].join(""));n.elem.attr("lay-indicator",n.indicator),n.elem.find("."+c)[0]&&n.elem.find("."+c).remove(),n.elem.append(t),"updown"===n.anim&&t.css("margin-top",-(t.height()/2)),t.find("li").on("hover"===n.trigger?"mouseover":n.trigger,function(){var t=i(this),a=t.index();a>n.index?e.slide("add",a-n.index):a<n.index&&e.slide("sub",n.index-a)})},m.prototype.slide=function(e,i){var n=this,l=n.elemItem,u=n.config,c=u.index,m=u.elem.attr("lay-filter");n.haveSlide||("sub"===e?(n.subIndex(i),l.eq(u.index).addClass(d),setTimeout(function(){l.eq(c).addClass(r),l.eq(u.index).addClass(r)},50)):(n.addIndex(i),l.eq(u.index).addClass(s),setTimeout(function(){l.eq(c).addClass(o),l.eq(u.index).addClass(o)},50)),setTimeout(function(){l.removeClass(a+" "+d+" "+s+" "+o+" "+r),l.eq(u.index).addClass(a),n.haveSlide=!1},300),n.elemInd.find("li").eq(u.index).addClass(a).siblings().removeClass(a),n.haveSlide=!0,layui.event.call(this,t,"change("+m+")",{index:u.index,prevIndex:c,item:l.eq(u.index)}))},m.prototype.events=function(){var e=this,i=e.config;i.elem.data("haveEvents")||(i.elem.on("mouseenter",function(){clearInterval(e.timer)}).on("mouseleave",function(){e.autoplay()}),i.elem.data("haveEvents",!0))},n.render=function(e){var i=new m(e);return i},e(t,n)});
|
||||
2
public/static/ext/layui/lay/modules/code.js
Executable file
2
public/static/ext/layui/lay/modules/code.js
Executable file
@@ -0,0 +1,2 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;layui.define("jquery",function(e){"use strict";var a=layui.$,l="http://www.layui.com/doc/modules/code.html";e("code",function(e){var t=[];e=e||{},e.elem=a(e.elem||".layui-code"),e.about=!("about"in e)||e.about,e.elem.each(function(){t.push(this)}),layui.each(t.reverse(),function(t,i){var c=a(i),o=c.html();(c.attr("lay-encode")||e.encode)&&(o=o.replace(/&(?!#?[a-zA-Z0-9]+;)/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/'/g,"'").replace(/"/g,""")),c.html('<ol class="layui-code-ol"><li>'+o.replace(/[\r\t\n]+/g,"</li><li>")+"</li></ol>"),c.find(">.layui-code-h3")[0]||c.prepend('<h3 class="layui-code-h3">'+(c.attr("lay-title")||e.title||"code")+(e.about?'<a href="'+l+'" target="_blank">layui.code</a>':"")+"</h3>");var d=c.find(">.layui-code-ol");c.addClass("layui-box layui-code-view"),(c.attr("lay-skin")||e.skin)&&c.addClass("layui-code-"+(c.attr("lay-skin")||e.skin)),(d.find("li").length/100|0)>0&&d.css("margin-left",(d.find("li").length/100|0)+"px"),(c.attr("lay-height")||e.height)&&d.css("max-height",c.attr("lay-height")||e.height)})})}).addcss("modules/code.css","skincodecss");
|
||||
2
public/static/ext/layui/lay/modules/colorpicker.js
Executable file
2
public/static/ext/layui/lay/modules/colorpicker.js
Executable file
File diff suppressed because one or more lines are too long
273
public/static/ext/layui/lay/modules/element.js
Executable file
273
public/static/ext/layui/lay/modules/element.js
Executable file
@@ -0,0 +1,273 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;
|
||||
layui.define("jquery", function (t) {
|
||||
"use strict";
|
||||
var a = layui.$,
|
||||
i = (layui.hint(), layui.device()),
|
||||
e = "element",
|
||||
l = "layui-this",
|
||||
n = "layui-show",
|
||||
s = function () {
|
||||
this.config = {}
|
||||
};
|
||||
s.prototype.set = function (t) {
|
||||
var i = this;
|
||||
return a.extend(!0, i.config, t), i
|
||||
}, s.prototype.on = function (t, a) {
|
||||
return layui.onevent.call(this, e, t, a)
|
||||
}, s.prototype.tabAdd = function (t, i) {
|
||||
var e = ".layui-tab-title",
|
||||
l = a(".layui-tab[lay-filter=" + t + "]"),
|
||||
n = l.children(e),
|
||||
s = n.children(".layui-tab-bar"),
|
||||
o = l.children(".layui-tab-content"),
|
||||
r = '<li lay-id="' + (i.id || "") + '"' + (i.attr ? ' lay-attr="' + i.attr + '"' : "") + ">" + (i.title ||
|
||||
"unnaming") + "</li>";
|
||||
return s[0] ? s.before(r) : n.append(r), o.append('<div class="layui-tab-item">' + (i.content || "") + "</div>"),
|
||||
f.hideTabMore(!0), f.tabAuto(), this
|
||||
}, s.prototype.tabDelete = function (t, i) {
|
||||
var e = ".layui-tab-title",
|
||||
l = a(".layui-tab[lay-filter=" + t + "]"),
|
||||
n = l.children(e),
|
||||
s = n.find('>li[lay-id="' + i + '"]');
|
||||
return f.tabDelete(null, s), this
|
||||
}, s.prototype.tabChange = function (t, i) {
|
||||
var e = ".layui-tab-title",
|
||||
l = a(".layui-tab[lay-filter=" + t + "]"),
|
||||
n = l.children(e),
|
||||
s = n.find('>li[lay-id="' + i + '"]');
|
||||
return f.tabClick.call(s[0], null, null, s), this
|
||||
}, s.prototype.tab = function (t) {
|
||||
t = t || {}, b.on("click", t.headerElem, function (i) {
|
||||
var e = a(this).index();
|
||||
f.tabClick.call(this, i, e, null, t)
|
||||
})
|
||||
}, s.prototype.progress = function (t, i) {
|
||||
var e = "layui-progress",
|
||||
l = a("." + e + "[lay-filter=" + t + "]"),
|
||||
n = l.find("." + e + "-bar"),
|
||||
s = n.find("." + e + "-text");
|
||||
return n.css("width", i), s.text(i), this
|
||||
};
|
||||
var o = ".layui-nav",
|
||||
r = "layui-nav-item",
|
||||
c = "layui-nav-bar",
|
||||
u = "layui-nav-tree",
|
||||
d = "layui-nav-child",
|
||||
y = "layui-nav-more",
|
||||
h = "layui-anim layui-anim-upbit",
|
||||
f = {
|
||||
tabClick: function (t, i, s, o) {
|
||||
o = o || {};
|
||||
var r = s || a(this),
|
||||
i = i || r.parent().children("li").index(r),
|
||||
c = o.headerElem ? r.parent() : r.parents(".layui-tab").eq(0),
|
||||
u = o.bodyElem ? a(o.bodyElem) : c.children(".layui-tab-content").children(".layui-tab-item"),
|
||||
d = r.find("a"),
|
||||
y = c.attr("lay-filter");
|
||||
"javascript:;" !== d.attr("href") && "_blank" === d.attr("target") || (r.addClass(l).siblings().removeClass(l),
|
||||
u.eq(i).addClass(n).siblings().removeClass(n)), layui.event.call(this, e, "tab(" + y + ")", {
|
||||
elem: c,
|
||||
index: i
|
||||
})
|
||||
},
|
||||
tabDelete: function (t, i) {
|
||||
var n = i || a(this).parent(),
|
||||
s = n.index(),
|
||||
o = n.parents(".layui-tab").eq(0),
|
||||
r = o.children(".layui-tab-content").children(".layui-tab-item"),
|
||||
c = o.attr("lay-filter");
|
||||
n.hasClass(l) && (n.next()[0] ? f.tabClick.call(n.next()[0], null, s + 1) : n.prev()[0] && f.tabClick.call(n.prev()[
|
||||
0], null, s - 1)), n.remove(), r.eq(s).remove(), setTimeout(function () {
|
||||
f.tabAuto()
|
||||
}, 50), layui.event.call(this, e, "tabDelete(" + c + ")", {
|
||||
elem: o,
|
||||
index: s
|
||||
})
|
||||
},
|
||||
tabAuto: function () {
|
||||
var t = "layui-tab-more",
|
||||
e = "layui-tab-bar",
|
||||
l = "layui-tab-close",
|
||||
n = this;
|
||||
a(".layui-tab").each(function () {
|
||||
var s = a(this),
|
||||
o = s.children(".layui-tab-title"),
|
||||
r = (s.children(".layui-tab-content").children(".layui-tab-item"), 'lay-stope="tabmore"'),
|
||||
c = a('<span class="layui-unselect layui-tab-bar" ' + r + "><i " + r +
|
||||
' class="layui-icon"></i></span>');
|
||||
if (n === window && 8 != i.ie && f.hideTabMore(!0), s.attr("lay-allowClose") && o.find("li").each(function () {
|
||||
var t = a(this);
|
||||
if (!t.find("." + l)[0]) {
|
||||
var i = a('<i class="layui-icon layui-unselect ' + l + '">ဆ</i>');
|
||||
i.on("click", f.tabDelete), t.append(i)
|
||||
}
|
||||
}), "string" != typeof s.attr("lay-unauto"))
|
||||
if (o.prop("scrollWidth") > o.outerWidth() + 1) {
|
||||
if (o.find("." + e)[0]) return;
|
||||
o.append(c), s.attr("overflow", ""), c.on("click", function (a) {
|
||||
o[this.title ? "removeClass" : "addClass"](t), this.title = this.title ? "" : "收缩"
|
||||
})
|
||||
} else o.find("." + e).remove(), s.removeAttr("overflow")
|
||||
})
|
||||
},
|
||||
hideTabMore: function (t) {
|
||||
var i = a(".layui-tab-title");
|
||||
t !== !0 && "tabmore" === a(t.target).attr("lay-stope") || (i.removeClass("layui-tab-more"), i.find(
|
||||
".layui-tab-bar").attr("title", ""))
|
||||
},
|
||||
clickThis: function () {
|
||||
var t = a(this),
|
||||
i = t.parents(o),
|
||||
n = i.attr("lay-filter"),
|
||||
s = t.parent(),
|
||||
c = t.siblings("." + d),
|
||||
y = "string" == typeof s.attr("lay-unselect");
|
||||
|
||||
//禁用
|
||||
if ((s.attr("lay-disabled") === "")) return;
|
||||
|
||||
if (c[0]) {
|
||||
"javascript:;" !== t.attr("href") && "_blank" === t.attr("target") || y || c[0] || (i.find("." + l).removeClass(
|
||||
l), s.addClass(l)), i.hasClass(u) && (c.removeClass(h), c[0] && (s["none" === c.css("display") ? "addClass" :
|
||||
"removeClass"](r + "ed"), "all" === i.attr("lay-shrink") && s.siblings().removeClass(r + "ed"))), layui.event.call(
|
||||
this, e, "nav(" + n + ")", t)
|
||||
} else {
|
||||
"javascript:;" !== t.attr("href") && "_blank" === t.attr("target") || y || c[0] || i.hasClass(u) && (c.removeClass(h), c[0] && (s["none" === c.css("display") ? "addClass" :
|
||||
"removeClass"](r + "ed"), "all" === i.attr("lay-shrink") && s.siblings().removeClass(r + "ed"))), layui.event.call(
|
||||
this, e, "nav(" + n + ")", t)
|
||||
}
|
||||
|
||||
},
|
||||
collapse: function () {
|
||||
var t = a(this),
|
||||
i = t.find(".layui-colla-icon"),
|
||||
l = t.siblings(".layui-colla-content"),
|
||||
s = t.parents(".layui-collapse").eq(0),
|
||||
o = s.attr("lay-filter"),
|
||||
r = "none" === l.css("display");
|
||||
if ("string" == typeof s.attr("lay-accordion")) {
|
||||
var c = s.children(".layui-colla-item").children("." + n);
|
||||
c.siblings(".layui-colla-title").children(".layui-colla-icon").html(""), c.removeClass(n)
|
||||
}
|
||||
l[r ? "addClass" : "removeClass"](n), i.html(r ? "" : ""), layui.event.call(this, e, "collapse(" +
|
||||
o + ")", {
|
||||
title: t,
|
||||
content: l,
|
||||
show: r
|
||||
})
|
||||
}
|
||||
};
|
||||
s.prototype.init = function (t, e) {
|
||||
var l = function () {
|
||||
return e ? '[lay-filter="' + e + '"]' : ""
|
||||
}(),
|
||||
s = {
|
||||
tab: function () {
|
||||
f.tabAuto.call({})
|
||||
},
|
||||
nav: function () {
|
||||
var t = 200,
|
||||
e = {},
|
||||
s = {},
|
||||
p = {},
|
||||
b = function (l, o, r) {
|
||||
var c = a(this),
|
||||
f = c.find("." + d);
|
||||
o.hasClass(u) ? l.css({
|
||||
top: c.position().top,
|
||||
height: c.children("a").outerHeight(),
|
||||
opacity: 1
|
||||
}) : (f.addClass(h), l.css({
|
||||
left: c.position().left + parseFloat(c.css("marginLeft")),
|
||||
top: c.position().top + c.height() - l.height()
|
||||
}), e[r] = setTimeout(function () {
|
||||
l.css({
|
||||
width: c.width(),
|
||||
opacity: 1
|
||||
})
|
||||
}, i.ie && i.ie < 10 ? 0 : t), clearTimeout(p[r]), "block" === f.css("display") && clearTimeout(s[r]), s[r] =
|
||||
setTimeout(function () {
|
||||
f.addClass(n), c.find("." + y).addClass(y + "d")
|
||||
}, 300))
|
||||
};
|
||||
a(o + l).each(function (i) {
|
||||
var l = a(this),
|
||||
o = a('<span class="' + c + '"></span>'),
|
||||
h = l.find("." + r);
|
||||
l.find("." + c)[0] || (l.append(o), h.on("mouseenter", function () {
|
||||
b.call(this, o, l, i)
|
||||
}).on("mouseleave", function () {
|
||||
l.hasClass(u) || (clearTimeout(s[i]), s[i] = setTimeout(function () {
|
||||
l.find("." + d).removeClass(n), l.find("." + y).removeClass(y + "d")
|
||||
}, 300))
|
||||
}), l.on("mouseleave", function () {
|
||||
clearTimeout(e[i]), p[i] = setTimeout(function () {
|
||||
l.hasClass(u) ? o.css({
|
||||
height: 0,
|
||||
top: o.position().top + o.height() / 2,
|
||||
opacity: 0
|
||||
}) : o.css({
|
||||
width: 0,
|
||||
left: o.position().left + o.width() / 2,
|
||||
opacity: 0
|
||||
})
|
||||
}, t)
|
||||
})), h.find("a").each(function () {
|
||||
var t = a(this),
|
||||
i = (t.parent(), t.siblings("." + d));
|
||||
i[0] && !t.children("." + y)[0] && t.append('<span class="' + y + '"></span>'), t.off("click", f.clickThis)
|
||||
.on("click", f.clickThis)
|
||||
})
|
||||
})
|
||||
},
|
||||
breadcrumb: function () {
|
||||
var t = ".layui-breadcrumb";
|
||||
a(t + l).each(function () {
|
||||
var t = a(this),
|
||||
i = "lay-separator",
|
||||
e = t.attr(i) || "/",
|
||||
l = t.find("a");
|
||||
l.next("span[" + i + "]")[0] || (l.each(function (t) {
|
||||
t !== l.length - 1 && a(this).after("<span " + i + ">" + e + "</span>")
|
||||
}), t.css("visibility", "visible"))
|
||||
})
|
||||
},
|
||||
progress: function () {
|
||||
var t = "layui-progress";
|
||||
a("." + t + l).each(function () {
|
||||
var i = a(this),
|
||||
e = i.find(".layui-progress-bar"),
|
||||
l = e.attr("lay-percent");
|
||||
e.css("width", function () {
|
||||
return /^.+\/.+$/.test(l) ? 100 * new Function("return " + l)() + "%" : l
|
||||
}()), i.attr("lay-showPercent") && setTimeout(function () {
|
||||
e.html('<span class="' + t + '-text">' + l + "</span>")
|
||||
}, 350)
|
||||
})
|
||||
},
|
||||
collapse: function () {
|
||||
var t = "layui-collapse";
|
||||
a("." + t + l).each(function () {
|
||||
var t = a(this).find(".layui-colla-item");
|
||||
t.each(function () {
|
||||
var t = a(this),
|
||||
i = t.find(".layui-colla-title"),
|
||||
e = t.find(".layui-colla-content"),
|
||||
l = "none" === e.css("display");
|
||||
i.find(".layui-colla-icon").remove(), i.append('<i class="layui-icon layui-colla-icon">' + (l ?
|
||||
"" : "") + "</i>"), i.off("click", f.collapse).on("click", f.collapse)
|
||||
})
|
||||
})
|
||||
}
|
||||
};
|
||||
return s[t] ? s[t]() : layui.each(s, function (t, a) {
|
||||
a()
|
||||
})
|
||||
}, s.prototype.render = s.prototype.init;
|
||||
var p = new s,
|
||||
b = a(document);
|
||||
p.render();
|
||||
var v = ".layui-tab-title li";
|
||||
b.on("click", v, f.tabClick), b.on("click", f.hideTabMore), a(window).on("resize", f.tabAuto), t(e, p)
|
||||
});
|
||||
2
public/static/ext/layui/lay/modules/flow.js
Executable file
2
public/static/ext/layui/lay/modules/flow.js
Executable file
@@ -0,0 +1,2 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;layui.define("jquery",function(e){"use strict";var l=layui.$,o=function(e){},t='<i class="layui-anim layui-anim-rotate layui-anim-loop layui-icon "></i>';o.prototype.load=function(e){var o,i,n,r,a=this,c=0;e=e||{};var f=l(e.elem);if(f[0]){var m=l(e.scrollElem||document),u=e.mb||50,s=!("isAuto"in e)||e.isAuto,v=e.end||"没有更多了",y=e.scrollElem&&e.scrollElem!==document,d="<cite>加载更多</cite>",h=l('<div class="layui-flow-more"><a href="javascript:;">'+d+"</a></div>");f.find(".layui-flow-more")[0]||f.append(h);var p=function(e,t){e=l(e),h.before(e),t=0==t||null,t?h.html(v):h.find("a").html(d),i=t,o=null,n&&n()},g=function(){o=!0,h.find("a").html(t),"function"==typeof e.done&&e.done(++c,p)};if(g(),h.find("a").on("click",function(){l(this);i||o||g()}),e.isLazyimg)var n=a.lazyimg({elem:e.elem+" img",scrollElem:e.scrollElem});return s?(m.on("scroll",function(){var e=l(this),t=e.scrollTop();r&&clearTimeout(r),i||(r=setTimeout(function(){var i=y?e.height():l(window).height(),n=y?e.prop("scrollHeight"):document.documentElement.scrollHeight;n-t-i<=u&&(o||g())},100))}),a):a}},o.prototype.lazyimg=function(e){var o,t=this,i=0;e=e||{};var n=l(e.scrollElem||document),r=e.elem||"img",a=e.scrollElem&&e.scrollElem!==document,c=function(e,l){var o=n.scrollTop(),r=o+l,c=a?function(){return e.offset().top-n.offset().top+o}():e.offset().top;if(c>=o&&c<=r&&!e.attr("src")){var m=e.attr("lay-src");layui.img(m,function(){var l=t.lazyimg.elem.eq(i);e.attr("src",m).removeAttr("lay-src"),l[0]&&f(l),i++})}},f=function(e,o){var f=a?(o||n).height():l(window).height(),m=n.scrollTop(),u=m+f;if(t.lazyimg.elem=l(r),e)c(e,f);else for(var s=0;s<t.lazyimg.elem.length;s++){var v=t.lazyimg.elem.eq(s),y=a?function(){return v.offset().top-n.offset().top+m}():v.offset().top;if(c(v,f),i=s,y>u)break}};if(f(),!o){var m;n.on("scroll",function(){var e=l(this);m&&clearTimeout(m),m=setTimeout(function(){f(null,e)},50)}),o=!0}return f},e("flow",new o)});
|
||||
244
public/static/ext/layui/lay/modules/form.js
Executable file
244
public/static/ext/layui/lay/modules/form.js
Executable file
@@ -0,0 +1,244 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;layui.define("layer", function (e) {
|
||||
"use strict";
|
||||
var t = layui.$, i = layui.layer, a = layui.hint(), n = layui.device(), l = "form", r = ".layui-form",
|
||||
s = "layui-this", o = "layui-hide", c = "layui-disabled", u = function () {
|
||||
this.config = {
|
||||
verify: {
|
||||
required: [/[\S]+/, "必填项不能为空"],
|
||||
phone: [/^1\d{10}$/, "请输入正确的手机号"],
|
||||
email: [/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
|
||||
url: [/(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
|
||||
number: function (e) {
|
||||
if (!e || isNaN(e)) return "只能填写数字"
|
||||
},
|
||||
date: [/^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
|
||||
identity: [/(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
|
||||
}
|
||||
}
|
||||
};
|
||||
u.prototype.set = function (e) {
|
||||
var i = this;
|
||||
return t.extend(!0, i.config, e), i
|
||||
}, u.prototype.verify = function (e) {
|
||||
var i = this;
|
||||
return t.extend(!0, i.config.verify, e), i
|
||||
}, u.prototype.on = function (e, t) {
|
||||
return layui.onevent.call(this, l, e, t)
|
||||
}, u.prototype.val = function (e, i) {
|
||||
var a = this, n = t(r + '[lay-filter="' + e + '"]');
|
||||
return n.each(function (e, a) {
|
||||
var n = t(this);
|
||||
layui.each(i, function (e, t) {
|
||||
var i, a = n.find('[name="' + e + '"]');
|
||||
a[0] && (i = a[0].type, "checkbox" === i ? a[0].checked = t : "radio" === i ? a.each(function () {
|
||||
this.value == t && (this.checked = !0)
|
||||
}) : a.val(t))
|
||||
})
|
||||
}), f.render(null, e), a.getValue(e)
|
||||
}, u.prototype.getValue = function (e, i) {
|
||||
i = i || t(r + '[lay-filter="' + e + '"]').eq(0);
|
||||
var a = {}, n = {}, l = i.find("input,select,textarea");
|
||||
return layui.each(l, function (e, t) {
|
||||
if (t.name = (t.name || "").replace(/^\s*|\s*&/, ""), t.name) {
|
||||
if (/^.*\[\]$/.test(t.name)) {
|
||||
var i = t.name.match(/^(.*)\[\]$/g)[0];
|
||||
a[i] = 0 | a[i], t.name = t.name.replace(/^(.*)\[\]$/, "$1[" + a[i]++ + "]")
|
||||
}
|
||||
/^checkbox|radio$/.test(t.type) && !t.checked || (n[t.name] = t.value)
|
||||
}
|
||||
}), n
|
||||
}, u.prototype.render = function (e, i) {
|
||||
var n = this, u = t(r + function () {
|
||||
return i ? '[lay-filter="' + i + '"]' : ""
|
||||
}()), d = {
|
||||
select: function () {
|
||||
var e, i = "请选择", a = "layui-form-select", n = "layui-select-title", r = "layui-select-none", d = "",
|
||||
f = u.find("select"), v = function (i, l) {
|
||||
t(i.target).parent().hasClass(n) && !l || (t("." + a).removeClass(a + "ed " + a + "up"), e && d && e.val(d)), e = null
|
||||
}, y = function (i, u, f) {
|
||||
var y, p = t(this), m = i.find("." + n), k = m.find("input"), g = i.find("dl"),
|
||||
x = g.children("dd"), b = this.selectedIndex;
|
||||
if (!u) {
|
||||
var C = function () {
|
||||
var e = i.offset().top + i.outerHeight() + 5 - h.scrollTop(), t = g.outerHeight();
|
||||
b = p[0].selectedIndex, i.addClass(a + "ed"), x.removeClass(o), y = null, x.eq(b).addClass(s).siblings().removeClass(s), e + t > h.height() && e >= t && i.addClass(a + "up"), T()
|
||||
}, w = function (e) {
|
||||
i.removeClass(a + "ed " + a + "up"), k.blur(), y = null, e || $(k.val(), function (e) {
|
||||
var i = p[0].selectedIndex;
|
||||
e && (d = t(p[0].options[i]).html(), 0 === i && d === k.attr("placeholder") && (d = ""), k.val(d || ""))
|
||||
})
|
||||
}, T = function () {
|
||||
var e = g.children("dd." + s);
|
||||
if (e[0]) {
|
||||
var t = e.position().top, i = g.height(), a = e.height();
|
||||
t > i && g.scrollTop(t + g.scrollTop() - i + a - 5), t < 0 && g.scrollTop(t + g.scrollTop() - 5)
|
||||
}
|
||||
};
|
||||
m.on("click", function (e) {
|
||||
i.hasClass(a + "ed") ? w() : (v(e, !0), C()), g.find("." + r).remove()
|
||||
}), m.find(".layui-edge").on("click", function () {
|
||||
k.focus()
|
||||
}), k.on("keyup", function (e) {
|
||||
var t = e.keyCode;
|
||||
9 === t && C()
|
||||
}).on("keydown", function (e) {
|
||||
var t = e.keyCode;
|
||||
9 === t && w();
|
||||
var i = function (t, a) {
|
||||
var n, l;
|
||||
e.preventDefault();
|
||||
var r = function () {
|
||||
var e = g.children("dd." + s);
|
||||
if (g.children("dd." + o)[0] && "next" === t) {
|
||||
var i = g.children("dd:not(." + o + ",." + c + ")"), n = i.eq(0).index();
|
||||
if (n >= 0 && n < e.index() && !i.hasClass(s)) return i.eq(0).prev()[0] ? i.eq(0).prev() : g.children(":last")
|
||||
}
|
||||
return a && a[0] ? a : y && y[0] ? y : e
|
||||
}();
|
||||
return l = r[t](), n = r[t]("dd:not(." + o + ")"), l[0] ? (y = r[t](), n[0] && !n.hasClass(c) || !y[0] ? (n.addClass(s).siblings().removeClass(s), void T()) : i(t, y)) : y = null
|
||||
};
|
||||
38 === t && i("prev"), 40 === t && i("next"), 13 === t && (e.preventDefault(), g.children("dd." + s).trigger("click"))
|
||||
});
|
||||
var $ = function (e, i, a) {
|
||||
var n = 0;
|
||||
layui.each(x, function () {
|
||||
var i = t(this), l = i.text(), r = l.indexOf(e) === -1;
|
||||
("" === e || "blur" === a ? e !== l : r) && n++, "keyup" === a && i[r ? "addClass" : "removeClass"](o)
|
||||
});
|
||||
var l = n === x.length;
|
||||
return i(l), l
|
||||
}, q = function (e) {
|
||||
var t = this.value, i = e.keyCode;
|
||||
return 9 !== i && 13 !== i && 37 !== i && 38 !== i && 39 !== i && 40 !== i && ($(t, function (e) {
|
||||
e ? g.find("." + r)[0] || g.append('<p class="' + r + '">无匹配项</p>') : g.find("." + r).remove()
|
||||
}, "keyup"), "" === t && g.find("." + r).remove(), void T())
|
||||
};
|
||||
f && k.on("keyup", q).on("blur", function (i) {
|
||||
var a = p[0].selectedIndex;
|
||||
e = k, d = t(p[0].options[a]).html().replace(/ /g,""), 0 === a && d === k.attr("placeholder") && (d = ""), setTimeout(function () {
|
||||
$(k.val(), function (e) {
|
||||
d || k.val("")
|
||||
}, "blur")
|
||||
}, 200)
|
||||
}), x.on("click", function () {
|
||||
var e = t(this), a = e.attr("lay-value"), n = p.attr("lay-filter");
|
||||
return !e.hasClass(c) && (e.hasClass("layui-select-tips") ? k.val("") : (k.val(layui.$.trim(e.text())), e.addClass(s)), e.siblings().removeClass(s), p.val(a).removeClass("layui-form-danger"), layui.event.call(this, l, "select(" + n + ")", {
|
||||
elem: p[0],
|
||||
value: a,
|
||||
othis: i
|
||||
}), w(!0), !1)
|
||||
}), i.find("dl>dt").on("click", function (e) {
|
||||
return !1
|
||||
}), t(document).off("click", v).on("click", v)
|
||||
}
|
||||
};
|
||||
f.each(function (e, l) {
|
||||
var r = t(this), o = r.next("." + a), u = this.disabled, d = l.value,
|
||||
f = t(l.options[l.selectedIndex]), v = l.options[0];
|
||||
if ("string" == typeof r.attr("lay-ignore")) return r.show();
|
||||
var h = "string" == typeof r.attr("lay-search"), p = v ? v.value ? i : v.innerHTML || i : i,
|
||||
m = t(['<div class="' + (h ? "" : "layui-unselect ") + a, (u ? " layui-select-disabled" : "") + '">', '<div class="' + n + '">', '<input type="text" placeholder="' + p + '" ' + ('value="' + (d ? f.html() : "") + '"') + (h ? "" : " readonly") + ' class="layui-input' + (h ? "" : " layui-unselect") + (u ? " " + c : "") + '">', '<i class="layui-edge"></i></div>', '<dl class="layui-anim layui-anim-upbit' + (r.find("optgroup")[0] ? " layui-select-group" : "") + '">', function (e) {
|
||||
var t = [];
|
||||
return layui.each(e, function (e, a) {
|
||||
0 !== e || a.value ? "optgroup" === a.tagName.toLowerCase() ? t.push("<dt>" + a.label + "</dt>") : t.push('<dd lay-value="' + a.value + '" class="' + (d === a.value ? s : "") + (a.disabled ? " " + c : "") + '">' + a.innerHTML + "</dd>") : t.push('<dd lay-value="" class="layui-select-tips">' + (a.innerHTML || i) + "</dd>")
|
||||
}), 0 === t.length && t.push('<dd lay-value="" class="' + c + '">没有选项</dd>'), t.join("")
|
||||
}(r.find("*")) + "</dl>", "</div>"].join(""));
|
||||
o[0] && o.remove(), r.after(m), y.call(this, m, u, h)
|
||||
})
|
||||
}, checkbox: function () {
|
||||
var e = {
|
||||
checkbox: ["layui-form-checkbox", "layui-form-checked", "checkbox"],
|
||||
_switch: ["layui-form-switch", "layui-form-onswitch", "switch"]
|
||||
}, i = u.find("input[type=checkbox]"), a = function (e, i) {
|
||||
var a = t(this);
|
||||
e.on("click", function () {
|
||||
var t = a.attr("lay-filter"), n = (a.attr("lay-text") || "").split("|");
|
||||
a[0].disabled || (a[0].checked ? (a[0].checked = !1, e.removeClass(i[1]).find("em").text(n[1])) : (a[0].checked = !0, e.addClass(i[1]).find("em").text(n[0])), layui.event.call(a[0], l, i[2] + "(" + t + ")", {
|
||||
elem: a[0],
|
||||
value: a[0].value,
|
||||
othis: e
|
||||
}))
|
||||
})
|
||||
};
|
||||
i.each(function (i, n) {
|
||||
var l = t(this), r = l.attr("lay-skin"), s = (l.attr("lay-text") || "").split("|"),
|
||||
o = this.disabled;
|
||||
"switch" === r && (r = "_" + r);
|
||||
var u = e[r] || e.checkbox;
|
||||
if ("string" == typeof l.attr("lay-ignore")) return l.show();
|
||||
var d = l.next("." + u[0]),
|
||||
f = t(['<div class="layui-unselect ' + u[0], n.checked ? " " + u[1] : "", o ? " layui-checkbox-disbaled " + c : "", '"', r ? ' lay-skin="' + r + '"' : "", ">", function () {
|
||||
var e = n.title.replace(/\s/g, ""), t = {
|
||||
checkbox: [e ? "<span>" + n.title + "</span>" : "", '<i class="layui-icon layui-icon-ok"></i>'].join(""),
|
||||
_switch: "<em>" + ((n.checked ? s[0] : s[1]) || "") + "</em><i></i>"
|
||||
};
|
||||
return t[r] || t.checkbox
|
||||
}(), "</div>"].join(""));
|
||||
d[0] && d.remove(), l.after(f), a.call(this, f, u)
|
||||
})
|
||||
}, radio: function () {
|
||||
var e = "layui-form-radio", i = ["", ""], a = u.find("input[type=radio]"),
|
||||
n = function (a) {
|
||||
var n = t(this), s = "layui-anim-scaleSpring";
|
||||
a.on("click", function () {
|
||||
var o = n[0].name, c = n.parents(r), u = n.attr("lay-filter"),
|
||||
d = c.find("input[name=" + o.replace(/(\.|#|\[|\])/g, "\\$1") + "]");
|
||||
n[0].disabled || (layui.each(d, function () {
|
||||
var a = t(this).next("." + e);
|
||||
this.checked = !1, a.removeClass(e + "ed"), a.find(".layui-icon").removeClass(s).html(i[1])
|
||||
}), n[0].checked = !0, a.addClass(e + "ed"), a.find(".layui-icon").addClass(s).html(i[0]), layui.event.call(n[0], l, "radio(" + u + ")", {
|
||||
elem: n[0],
|
||||
value: n[0].value,
|
||||
othis: a
|
||||
}))
|
||||
})
|
||||
};
|
||||
a.each(function (a, l) {
|
||||
var r = t(this), s = r.next("." + e), o = this.disabled;
|
||||
if ("string" == typeof r.attr("lay-ignore")) return r.show();
|
||||
s[0] && s.remove();
|
||||
var u = t(['<div class="layui-unselect ' + e, l.checked ? " " + e + "ed" : "", (o ? " layui-radio-disbaled " + c : "") + '">', '<i class="layui-anim layui-icon">' + i[l.checked ? 0 : 1] + "</i>", "<div>" + function () {
|
||||
var e = l.title || "";
|
||||
return "string" == typeof r.next().attr("lay-radio") && (e = r.next().html(), r.next().remove()), e
|
||||
}() + "</div>", "</div>"].join(""));
|
||||
r.after(u), n.call(this, u)
|
||||
})
|
||||
}
|
||||
};
|
||||
return e ? d[e] ? d[e]() : a.error("不支持的" + e + "表单渲染") : layui.each(d, function (e, t) {
|
||||
t()
|
||||
}), n
|
||||
};
|
||||
var d = function () {
|
||||
var e = null, a = f.config.verify, s = "layui-form-danger", o = {}, c = t(this), u = c.parents(r),
|
||||
d = u.find("*[lay-verify]"), v = c.parents("form")[0], h = c.attr("lay-filter");
|
||||
return layui.each(d, function (l, r) {
|
||||
var o = t(this), c = o.attr("lay-verify").split("|"), u = o.attr("lay-verType"), d = o.val();
|
||||
if (o.removeClass(s), layui.each(c, function (t, l) {
|
||||
var c, f = "", v = "function" == typeof a[l];
|
||||
if (a[l]) {
|
||||
var c = v ? f = a[l](d, r) : !a[l][0].test(d);
|
||||
if (f = f || a[l][1], "required" === l && (f = o.attr("lay-reqText") || f), c) return "tips" === u ? i.tips(f, function () {
|
||||
return "string" == typeof o.attr("lay-ignore") || "select" !== r.tagName.toLowerCase() && !/^checkbox|radio$/.test(r.type) ? o : o.next()
|
||||
}(), {tips: 1}) : "alert" === u ? i.alert(f, {title: "提示", shadeClose: !0}) : i.msg(f, {
|
||||
icon: 5,
|
||||
shift: 6
|
||||
}), n.android || n.ios || setTimeout(function () {
|
||||
r.focus()
|
||||
}, 7), o.addClass(s), e = !0
|
||||
}
|
||||
}), e) return e
|
||||
}), !e && (o = f.getValue(null, u), layui.event.call(this, l, "submit(" + h + ")", {
|
||||
elem: this,
|
||||
form: v,
|
||||
field: o
|
||||
}))
|
||||
}, f = new u, v = t(document), h = t(window);
|
||||
f.render(), v.on("reset", r, function () {
|
||||
var e = t(this).attr("lay-filter");
|
||||
setTimeout(function () {
|
||||
f.render(null, e)
|
||||
}, 50)
|
||||
}), v.on("submit", r, d).on("click", "*[lay-submit]", d), e(l, f)
|
||||
});
|
||||
2
public/static/ext/layui/lay/modules/form_b.js
Executable file
2
public/static/ext/layui/lay/modules/form_b.js
Executable file
File diff suppressed because one or more lines are too long
5
public/static/ext/layui/lay/modules/jquery.js
vendored
Executable file
5
public/static/ext/layui/lay/modules/jquery.js
vendored
Executable file
File diff suppressed because one or more lines are too long
2
public/static/ext/layui/lay/modules/laydate.js
Executable file
2
public/static/ext/layui/lay/modules/laydate.js
Executable file
File diff suppressed because one or more lines are too long
2
public/static/ext/layui/lay/modules/layedit.js
Executable file
2
public/static/ext/layui/lay/modules/layedit.js
Executable file
File diff suppressed because one or more lines are too long
733
public/static/ext/layui/lay/modules/layer.js
Executable file
733
public/static/ext/layui/lay/modules/layer.js
Executable file
@@ -0,0 +1,733 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;
|
||||
!function (e, t) {
|
||||
"use strict";
|
||||
var i, n, a = e.layui && layui.define,
|
||||
o = {
|
||||
getPath: function () {
|
||||
var e = document.currentScript ? document.currentScript.src : function () {
|
||||
for (var e, t = document.scripts, i = t.length - 1, n = i; n > 0; n--)
|
||||
if ("interactive" === t[n].readyState) {
|
||||
e = t[n].src;
|
||||
break
|
||||
}
|
||||
return e || t[i].src
|
||||
}();
|
||||
return e.substring(0, e.lastIndexOf("/") + 1)
|
||||
}(),
|
||||
config: {},
|
||||
end: {},
|
||||
minIndex: 0,
|
||||
minLeft: [],
|
||||
btn: ["确定", "取消"],
|
||||
type: ["dialog", "page", "iframe", "loading", "tips"],
|
||||
getStyle: function (t, i) {
|
||||
var n = t.currentStyle ? t.currentStyle : e.getComputedStyle(t, null);
|
||||
return n[n.getPropertyValue ? "getPropertyValue" : "getAttribute"](i)
|
||||
},
|
||||
link: function (t, i, n) {
|
||||
if (r.path) {
|
||||
var a = document.getElementsByTagName("head")[0],
|
||||
s = document.createElement("link");
|
||||
"string" == typeof i && (n = i);
|
||||
var l = (n || t).replace(/\.|\//g, ""),
|
||||
f = "layuicss-" + l,
|
||||
c = 0;
|
||||
s.rel = "stylesheet", s.href = r.path + t, s.id = f, document.getElementById(f) || a.appendChild(s), "function" ==
|
||||
typeof i && !function u() {
|
||||
return ++c > 80 ? e.console && console.error("layer.css: Invalid") : void (1989 === parseInt(o.getStyle(document
|
||||
.getElementById(f), "width")) ? i() : setTimeout(u, 100))
|
||||
}()
|
||||
}
|
||||
}
|
||||
},
|
||||
r = {
|
||||
v: "3.1.1",
|
||||
ie: function () {
|
||||
var t = navigator.userAgent.toLowerCase();
|
||||
return !!(e.ActiveXObject || "ActiveXObject" in e) && ((t.match(/msie\s(\d+)/) || [])[1] || "11")
|
||||
}(),
|
||||
index: e.layer && e.layer.v ? 1e5 : 0,
|
||||
path: o.getPath,
|
||||
config: function (e, t) {
|
||||
return e = e || {}, r.cache = o.config = i.extend({}, o.config, e), r.path = o.config.path || r.path, "string" ==
|
||||
typeof e.extend && (e.extend = [e.extend]), o.config.path && r.ready(), e.extend ? (a ? layui.addcss(
|
||||
"modules/layer/" + e.extend) : o.link("theme/" + e.extend), this) : this
|
||||
},
|
||||
ready: function (e) {
|
||||
var t = "layer",
|
||||
i = "",
|
||||
n = (a ? "modules/layer/" : "theme/") + "default/layer.css?v=" + r.v + i;
|
||||
return a ? layui.addcss(n, e, t) : o.link(n, e, t), this
|
||||
},
|
||||
alert: function (e, t, n) {
|
||||
var a = "function" == typeof t;
|
||||
return a && (n = t), r.open(i.extend({
|
||||
content: e,
|
||||
yes: n
|
||||
}, a ? {} : t))
|
||||
},
|
||||
confirm: function (e, t, n, a) {
|
||||
var s = "function" == typeof t;
|
||||
return s && (a = n, n = t), r.open(i.extend({
|
||||
content: e,
|
||||
btn: o.btn,
|
||||
yes: n,
|
||||
btn2: a
|
||||
}, s ? {} : t))
|
||||
},
|
||||
msg: function (e, n, a) {
|
||||
var s = "function" == typeof n,
|
||||
f = o.config.skin,
|
||||
c = (f ? f + " " + f + "-msg" : "") || "layui-layer-msg",
|
||||
u = l.anim.length - 1;
|
||||
return s && (a = n), r.open(i.extend({
|
||||
content: e,
|
||||
time: 3e3,
|
||||
shade: !1,
|
||||
skin: c,
|
||||
title: !1,
|
||||
closeBtn: !1,
|
||||
btn: !1,
|
||||
resize: !1,
|
||||
end: a
|
||||
}, s && !o.config.skin ? {
|
||||
skin: c + " layui-layer-hui",
|
||||
anim: u
|
||||
} : function () {
|
||||
return n = n || {}, (n.icon === -1 || n.icon === t && !o.config.skin) && (n.skin = c + " " + (n.skin ||
|
||||
"layui-layer-hui")), n
|
||||
}()))
|
||||
},
|
||||
load: function (e, t) {
|
||||
return r.open(i.extend({
|
||||
type: 3,
|
||||
icon: e || 0,
|
||||
resize: !1,
|
||||
shade: .01
|
||||
}, t))
|
||||
},
|
||||
tips: function (e, t, n) {
|
||||
return r.open(i.extend({
|
||||
type: 4,
|
||||
content: [e, t],
|
||||
closeBtn: !1,
|
||||
time: 3e3,
|
||||
shade: !1,
|
||||
resize: !1,
|
||||
fixed: !1,
|
||||
maxWidth: 210
|
||||
}, n))
|
||||
}
|
||||
},
|
||||
s = function (e) {
|
||||
var t = this;
|
||||
t.index = ++r.index, t.config = i.extend({}, t.config, o.config, e), document.body ? t.creat() : setTimeout(function () {
|
||||
t.creat()
|
||||
}, 30)
|
||||
};
|
||||
s.pt = s.prototype;
|
||||
var l = ["layui-layer", ".layui-layer-title", ".layui-layer-main", ".layui-layer-dialog", "layui-layer-iframe",
|
||||
"layui-layer-content", "layui-layer-btn", "layui-layer-close"
|
||||
];
|
||||
l.anim = ["layer-anim-00", "layer-anim-01", "layer-anim-02", "layer-anim-03", "layer-anim-04", "layer-anim-05",
|
||||
"layer-anim-06"
|
||||
], s.pt.config = {
|
||||
type: 0,
|
||||
shade: .3,
|
||||
fixed: !0,
|
||||
move: l[1],
|
||||
title: "信息",
|
||||
offset: "auto",
|
||||
area: "auto",
|
||||
closeBtn: 1,
|
||||
time: 0,
|
||||
zIndex: 19891014,
|
||||
maxWidth: 360,
|
||||
anim: 0,
|
||||
isOutAnim: !0,
|
||||
icon: -1,
|
||||
moveType: 1,
|
||||
resize: !0,
|
||||
scrollbar: !0,
|
||||
tips: 2
|
||||
}, s.pt.vessel = function (e, t) {
|
||||
var n = this,
|
||||
a = n.index,
|
||||
r = n.config,
|
||||
s = r.zIndex + a,
|
||||
f = "object" == typeof r.title,
|
||||
c = r.maxmin && (1 === r.type || 2 === r.type),
|
||||
u = r.title ? '<div class="layui-layer-title" style="' + (f ? r.title[1] : "") + '">' + (f ? r.title[0] : r.title) +
|
||||
"</div>" : "";
|
||||
return r.zIndex = s, t([r.shade ? '<div class="layui-layer-shade" id="layui-layer-shade' + a + '" times="' + a +
|
||||
'" style="' + ("z-index:" + (s - 1) + "; ") + '"></div>' : "", '<div class="' + l[0] + (" layui-layer-" + o.type[
|
||||
r.type]) + (0 != r.type && 2 != r.type || r.shade ? "" : " layui-layer-border") + " " + (r.skin || "") +
|
||||
'" id="' + l[0] + a + '" type="' + o.type[r.type] + '" times="' + a + '" showtime="' + r.time + '" conType="' + (
|
||||
e ? "object" : "string") + '" style="z-index: ' + s + "; width:" + r.area[0] + ";height:" + r.area[1] + (r.fixed ?
|
||||
"" : ";position:absolute;") + '">' + (e && 2 != r.type ? "" : u) + '<div id="' + (r.id || "") +
|
||||
'" class="layui-layer-content' + (0 == r.type && r.icon !== -1 ? " layui-layer-padding" : "") + (3 == r.type ?
|
||||
" layui-layer-loading" + r.icon : "") + '">' + (0 == r.type && r.icon !== -1 ?
|
||||
'<i class="layui-layer-ico layui-layer-ico' + r.icon + '"></i>' : "") + (1 == r.type && e ? "" : r.content || "") +
|
||||
'</div><span class="layui-layer-setwin">' + function () {
|
||||
var e = c ?
|
||||
'<a class="layui-layer-min" href="javascript:;"><cite></cite></a><a class="layui-layer-ico layui-layer-max" href="javascript:;"></a>' :
|
||||
"";
|
||||
return r.closeBtn && (e += '<a class="layui-layer-ico ' + l[7] + " " + l[7] + (r.title ? r.closeBtn : 4 == r.type ?
|
||||
"1" : "2") + '" href="javascript:;"></a>'), e
|
||||
}() + "</span>" + (r.btn ? function () {
|
||||
var e = "";
|
||||
"string" == typeof r.btn && (r.btn = [r.btn]);
|
||||
for (var t = 0, i = r.btn.length; t < i; t++) e += '<a class="' + l[6] + t + '">' + r.btn[t] + "</a>";
|
||||
return '<div class="' + l[6] + " layui-layer-btn-" + (r.btnAlign || "") + '">' + e + "</div>"
|
||||
}() : "") + (r.resize ? '<span class="layui-layer-resize"></span>' : "") + "</div>"
|
||||
], u, i('<div class="layui-layer-move"></div>')), n
|
||||
}, s.pt.creat = function () {
|
||||
var e = this,
|
||||
t = e.config,
|
||||
a = e.index,
|
||||
s = t.content,
|
||||
f = "object" == typeof s,
|
||||
c = i("body");
|
||||
if (!t.id || !i("#" + t.id)[0]) {
|
||||
switch ("string" == typeof t.area && (t.area = "auto" === t.area ? ["", ""] : [t.area, ""]), t.shift && (t.anim = t
|
||||
.shift), 6 == r.ie && (t.fixed = !1), t.type) {
|
||||
case 0:
|
||||
t.btn = "btn" in t ? t.btn : o.btn[0], r.closeAll("dialog");
|
||||
break;
|
||||
case 2:
|
||||
var s = t.content = f ? t.content : [t.content || "", "auto"];
|
||||
t.content = '<iframe scrolling="' + (t.content[1] || "auto") + '" allowtransparency="true" id="' + l[4] + a +
|
||||
'" name="' + l[4] + a + '" onload="this.className=\'\';" class="layui-layer-load" frameborder="0" src="' + t.content[
|
||||
0] + '"></iframe>';
|
||||
break;
|
||||
case 3:
|
||||
delete t.title, delete t.closeBtn, t.icon === -1 && 0 === t.icon, r.closeAll("loading");
|
||||
break;
|
||||
case 4:
|
||||
f || (t.content = [t.content, "body"]), t.follow = t.content[1], t.content = t.content[0] +
|
||||
'<i class="layui-layer-TipsG"></i>', delete t.title, t.tips = "object" == typeof t.tips ? t.tips : [t.tips, !0],
|
||||
t.tipsMore || r.closeAll("tips")
|
||||
}
|
||||
if (e.vessel(f, function (n, r, u) {
|
||||
c.append(n[0]), f ? function () {
|
||||
2 == t.type || 4 == t.type ? function () {
|
||||
i("body").append(n[1])
|
||||
}() : function () {
|
||||
s.parents("." + l[0])[0] || (s.data("display", s.css("display")).show().addClass("layui-layer-wrap").wrap(n[
|
||||
1]), i("#" + l[0] + a).find("." + l[5]).before(r))
|
||||
}()
|
||||
}() : c.append(n[1]), i(".layui-layer-move")[0] || c.append(o.moveElem = u), e.layero = i("#" + l[0] + a), t.scrollbar ||
|
||||
l.html.css("overflow", "hidden").attr("layer-full", a)
|
||||
}).auto(a), i("#layui-layer-shade" + e.index).css({
|
||||
"background-color": t.shade[1] || "#000",
|
||||
opacity: t.shade[0] || t.shade
|
||||
}), 2 == t.type && 6 == r.ie && e.layero.find("iframe").attr("src", s[0]), 4 == t.type ? e.tips() : e.offset(), t.fixed &&
|
||||
n.on("resize", function () {
|
||||
e.offset(), (/^\d+%$/.test(t.area[0]) || /^\d+%$/.test(t.area[1])) && e.auto(a), 4 == t.type && e.tips()
|
||||
}), t.time <= 0 || setTimeout(function () {
|
||||
r.close(e.index)
|
||||
}, t.time), e.move().callback(), l.anim[t.anim]) {
|
||||
var u = "layer-anim " + l.anim[t.anim];
|
||||
e.layero.addClass(u).one("webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend", function () {
|
||||
i(this).removeClass(u)
|
||||
})
|
||||
}
|
||||
t.isOutAnim && e.layero.data("isOutAnim", !0)
|
||||
}
|
||||
}, s.pt.auto = function (e) {
|
||||
var t = this,
|
||||
a = t.config,
|
||||
o = i("#" + l[0] + e);
|
||||
"" === a.area[0] && a.maxWidth > 0 && (r.ie && r.ie < 8 && a.btn && o.width(o.innerWidth()), o.outerWidth() > a.maxWidth &&
|
||||
o.width(a.maxWidth));
|
||||
var s = [o.innerWidth(), o.innerHeight()],
|
||||
f = o.find(l[1]).outerHeight() || 0,
|
||||
c = o.find("." + l[6]).outerHeight() || 0,
|
||||
u = function (e) {
|
||||
e = o.find(e), e.height(s[1] - f - c - 2 * (0 | parseFloat(e.css("padding-top"))))
|
||||
};
|
||||
switch (a.type) {
|
||||
case 2:
|
||||
u("iframe");
|
||||
break;
|
||||
default:
|
||||
"" === a.area[1] ? a.maxHeight > 0 && o.outerHeight() > a.maxHeight ? (s[1] = a.maxHeight, u("." + l[5])) : a.fixed &&
|
||||
s[1] >= n.height() && (s[1] = n.height(), u("." + l[5])) : u("." + l[5])
|
||||
}
|
||||
return t
|
||||
}, s.pt.offset = function () {
|
||||
var e = this,
|
||||
t = e.config,
|
||||
i = e.layero,
|
||||
a = [i.outerWidth(), i.outerHeight()],
|
||||
o = "object" == typeof t.offset;
|
||||
e.offsetTop = (n.height() - a[1]) / 2, e.offsetLeft = (n.width() - a[0]) / 2, o ? (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 =
|
||||
n.width() - a[0] : "b" === t.offset ? e.offsetTop = n.height() - a[1] : "l" === t.offset ? e.offsetLeft = 0 : "lt" ===
|
||||
t.offset ? (e.offsetTop = 0, e.offsetLeft = 0) : "lb" === t.offset ? (e.offsetTop = n.height() - a[1], e.offsetLeft =
|
||||
0) : "rt" === t.offset ? (e.offsetTop = 0, e.offsetLeft = n.width() - a[0]) : "rb" === t.offset ? (e.offsetTop =
|
||||
n.height() - a[1], e.offsetLeft = n.width() - a[0]) : e.offsetTop = t.offset), t.fixed || (e.offsetTop = /%$/.test(
|
||||
e.offsetTop) ? n.height() * parseFloat(e.offsetTop) / 100 : parseFloat(e.offsetTop), e.offsetLeft = /%$/.test(e.offsetLeft) ?
|
||||
n.width() * parseFloat(e.offsetLeft) / 100 : parseFloat(e.offsetLeft), e.offsetTop += n.scrollTop(), e.offsetLeft +=
|
||||
n.scrollLeft()), i.attr("minLeft") && (e.offsetTop = n.height() - (i.find(l[1]).outerHeight() || 0), e.offsetLeft =
|
||||
i.css("left")), i.css({
|
||||
top: e.offsetTop,
|
||||
left: e.offsetLeft
|
||||
})
|
||||
}, s.pt.tips = function () {
|
||||
var e = this,
|
||||
t = e.config,
|
||||
a = e.layero,
|
||||
o = [a.outerWidth(), a.outerHeight()],
|
||||
r = i(t.follow);
|
||||
r[0] || (r = i("body"));
|
||||
var s = {
|
||||
width: r.outerWidth(),
|
||||
height: r.outerHeight(),
|
||||
top: r.offset().top,
|
||||
left: r.offset().left
|
||||
},
|
||||
f = a.find(".layui-layer-TipsG"),
|
||||
c = t.tips[0];
|
||||
t.tips[1] || f.remove(), s.autoLeft = function () {
|
||||
s.left + o[0] - n.width() > 0 ? (s.tipLeft = s.left + s.width - o[0], f.css({
|
||||
right: 12,
|
||||
left: "auto"
|
||||
})) : s.tipLeft = s.left
|
||||
}, s.where = [function () {
|
||||
s.autoLeft(), s.tipTop = s.top - o[1] - 10, f.removeClass("layui-layer-TipsB").addClass("layui-layer-TipsT").css(
|
||||
"border-right-color", t.tips[1])
|
||||
}, function () {
|
||||
s.tipLeft = s.left + s.width + 10, s.tipTop = s.top, f.removeClass("layui-layer-TipsL").addClass(
|
||||
"layui-layer-TipsR").css("border-bottom-color", t.tips[1])
|
||||
}, function () {
|
||||
s.autoLeft(), s.tipTop = s.top + s.height + 10, f.removeClass("layui-layer-TipsT").addClass("layui-layer-TipsB").css(
|
||||
"border-right-color", t.tips[1])
|
||||
}, function () {
|
||||
s.tipLeft = s.left - o[0] - 10, s.tipTop = s.top, f.removeClass("layui-layer-TipsR").addClass("layui-layer-TipsL")
|
||||
.css("border-bottom-color", t.tips[1])
|
||||
}], s.where[c - 1](), 1 === c ? s.top - (n.scrollTop() + o[1] + 16) < 0 && s.where[2]() : 2 === c ? n.width() - (s.left +
|
||||
s.width + o[0] + 16) > 0 || s.where[3]() : 3 === c ? s.top - n.scrollTop() + s.height + o[1] + 16 - n.height() > 0 &&
|
||||
s.where[0]() : 4 === c && o[0] + 16 - s.left > 0 && s.where[1](), a.find("." + l[5]).css({
|
||||
"background-color": t.tips[1],
|
||||
"padding-right": t.closeBtn ? "30px" : ""
|
||||
}), a.css({
|
||||
left: s.tipLeft - (t.fixed ? n.scrollLeft() : 0),
|
||||
top: s.tipTop - (t.fixed ? n.scrollTop() : 0)
|
||||
})
|
||||
}, s.pt.move = function () {
|
||||
var e = this,
|
||||
t = e.config,
|
||||
a = i(document),
|
||||
s = e.layero,
|
||||
l = s.find(t.move),
|
||||
f = s.find(".layui-layer-resize"),
|
||||
c = {};
|
||||
return t.move && l.css("cursor", "move"), l.on("mousedown", function (e) {
|
||||
e.preventDefault(), t.move && (c.moveStart = !0, c.offset = [e.clientX - parseFloat(s.css("left")), e.clientY -
|
||||
parseFloat(s.css("top"))
|
||||
], o.moveElem.css("cursor", "move").show())
|
||||
}), f.on("mousedown", function (e) {
|
||||
e.preventDefault(), c.resizeStart = !0, c.offset = [e.clientX, e.clientY], c.area = [s.outerWidth(), s.outerHeight()],
|
||||
o.moveElem.css("cursor", "se-resize").show()
|
||||
}), a.on("mousemove", function (i) {
|
||||
if (c.moveStart) {
|
||||
var a = i.clientX - c.offset[0],
|
||||
o = i.clientY - c.offset[1],
|
||||
l = "fixed" === s.css("position");
|
||||
if (i.preventDefault(), c.stX = l ? 0 : n.scrollLeft(), c.stY = l ? 0 : n.scrollTop(), !t.moveOut) {
|
||||
var f = n.width() - s.outerWidth() + c.stX,
|
||||
u = n.height() - s.outerHeight() + c.stY;
|
||||
a < c.stX && (a = c.stX), a > f && (a = f), o < c.stY && (o = c.stY), o > u && (o = u)
|
||||
}
|
||||
s.css({
|
||||
left: a,
|
||||
top: o
|
||||
})
|
||||
}
|
||||
if (t.resize && c.resizeStart) {
|
||||
var a = i.clientX - c.offset[0],
|
||||
o = i.clientY - c.offset[1];
|
||||
i.preventDefault(), r.style(e.index, {
|
||||
width: c.area[0] + a,
|
||||
height: c.area[1] + o
|
||||
}), c.isResize = !0, t.resizing && t.resizing(s)
|
||||
}
|
||||
}).on("mouseup", function (e) {
|
||||
c.moveStart && (delete c.moveStart, o.moveElem.hide(), t.moveEnd && t.moveEnd(s)), c.resizeStart && (delete c.resizeStart,
|
||||
o.moveElem.hide())
|
||||
}), e
|
||||
}, s.pt.callback = function () {
|
||||
function e() {
|
||||
var e = a.cancel && a.cancel(t.index, n);
|
||||
e === !1 || r.close(t.index)
|
||||
}
|
||||
|
||||
var t = this,
|
||||
n = t.layero,
|
||||
a = t.config;
|
||||
t.openLayer(), a.success && (2 == a.type ? n.find("iframe").on("load", function () {
|
||||
a.success(n, t.index)
|
||||
}) : a.success(n, t.index)), 6 == r.ie && t.IE6(n), n.find("." + l[6]).children("a").on("click", function () {
|
||||
var e = i(this).index();
|
||||
if (0 === e) a.yes ? a.yes(t.index, n) : a.btn1 ? a.btn1(t.index, n) : r.close(t.index);
|
||||
else {
|
||||
var o = a["btn" + (e + 1)] && a["btn" + (e + 1)](t.index, n);
|
||||
o === !1 || r.close(t.index)
|
||||
}
|
||||
}), n.find("." + l[7]).on("click", e), a.shadeClose && i("#layui-layer-shade" + t.index).on("click", function () {
|
||||
r.close(t.index)
|
||||
}), n.find(".layui-layer-min").on("click", function () {
|
||||
var e = a.min && a.min(n);
|
||||
e === !1 || r.min(t.index, a)
|
||||
}), n.find(".layui-layer-max").on("click", function () {
|
||||
i(this).hasClass("layui-layer-maxmin") ? (r.restore(t.index), a.restore && a.restore(n)) : (r.full(t.index, a),
|
||||
setTimeout(function () {
|
||||
a.full && a.full(n)
|
||||
}, 100))
|
||||
}), a.end && (o.end[t.index] = a.end)
|
||||
}, o.reselect = function () {
|
||||
i.each(i("select"), function (e, t) {
|
||||
var n = i(this);
|
||||
n.parents("." + l[0])[0] || 1 == n.attr("layer") && i("." + l[0]).length < 1 && n.removeAttr("layer").show(), n =
|
||||
null
|
||||
})
|
||||
}, s.pt.IE6 = function (e) {
|
||||
i("select").each(function (e, t) {
|
||||
var n = i(this);
|
||||
n.parents("." + l[0])[0] || "none" === n.css("display") || n.attr({
|
||||
layer: "1"
|
||||
}).hide(), n = null
|
||||
})
|
||||
}, s.pt.openLayer = function () {
|
||||
var e = this;
|
||||
r.zIndex = e.config.zIndex, r.setTop = function (e) {
|
||||
var t = function () {
|
||||
r.zIndex++, e.css("z-index", r.zIndex + 1)
|
||||
};
|
||||
return r.zIndex = parseInt(e[0].style.zIndex), e.on("mousedown", t), r.zIndex
|
||||
}
|
||||
}, o.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
|
||||
})
|
||||
}, o.rescollbar = function (e) {
|
||||
l.html.attr("layer-full") == e && (l.html[0].style.removeProperty ? l.html[0].style.removeProperty("overflow") : l.html[
|
||||
0].style.removeAttribute("overflow"), l.html.removeAttr("layer-full"))
|
||||
}, e.layer = r, r.getChildFrame = function (e, t) {
|
||||
return t = t || i("." + l[4]).attr("times"), i("#" + l[0] + t).find("iframe").contents().find(e)
|
||||
}, r.getFrameIndex = function (e) {
|
||||
return i("#" + e).parents("." + l[4]).attr("times")
|
||||
}, r.iframeAuto = function (e) {
|
||||
if (e) {
|
||||
var t = r.getChildFrame("html", e).outerHeight(),
|
||||
n = i("#" + l[0] + e),
|
||||
a = n.find(l[1]).outerHeight() || 0,
|
||||
o = n.find("." + l[6]).outerHeight() || 0;
|
||||
n.css({
|
||||
height: t + a + o
|
||||
}), n.find("iframe").css({
|
||||
height: t
|
||||
})
|
||||
}
|
||||
}, r.iframeSrc = function (e, t) {
|
||||
i("#" + l[0] + e).find("iframe").attr("src", t)
|
||||
}, r.style = function (e, t, n) {
|
||||
var a = i("#" + l[0] + e),
|
||||
r = a.find(".layui-layer-content"),
|
||||
s = a.attr("type"),
|
||||
f = a.find(l[1]).outerHeight() || 0,
|
||||
c = a.find("." + l[6]).outerHeight() || 0;
|
||||
a.attr("minLeft");
|
||||
s !== o.type[3] && s !== o.type[4] && (n || (parseFloat(t.width) <= 260 && (t.width = 260), parseFloat(t.height) - f -
|
||||
c <= 64 && (t.height = 64 + f + c)), a.css(t), c = a.find("." + l[6]).outerHeight(), s === o.type[2] ? a.find(
|
||||
"iframe").css({
|
||||
height: parseFloat(t.height) - f - c
|
||||
}) : r.css({
|
||||
height: parseFloat(t.height) - f - c - parseFloat(r.css("padding-top")) - parseFloat(r.css("padding-bottom"))
|
||||
}))
|
||||
}, r.min = function (e, t) {
|
||||
var a = i("#" + l[0] + e),
|
||||
s = a.find(l[1]).outerHeight() || 0,
|
||||
f = a.attr("minLeft") || 181 * o.minIndex + "px",
|
||||
c = a.css("position");
|
||||
o.record(a), o.minLeft[0] && (f = o.minLeft[0], o.minLeft.shift()), a.attr("position", c), r.style(e, {
|
||||
width: 180,
|
||||
height: s,
|
||||
left: f,
|
||||
top: n.height() - s,
|
||||
position: "fixed",
|
||||
overflow: "hidden"
|
||||
}, !0), a.find(".layui-layer-min").hide(), "page" === a.attr("type") && a.find(l[4]).hide(), o.rescollbar(e), a.attr(
|
||||
"minLeft") || o.minIndex++, a.attr("minLeft", f)
|
||||
}, r.restore = function (e) {
|
||||
var t = i("#" + l[0] + e),
|
||||
n = t.attr("area").split(",");
|
||||
t.attr("type");
|
||||
r.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(l[4]).show(), o.rescollbar(e)
|
||||
}, r.full = function (e) {
|
||||
var t, a = i("#" + l[0] + e);
|
||||
o.record(a), l.html.attr("layer-full") || l.html.css("overflow", "hidden").attr("layer-full", e), clearTimeout(t), t =
|
||||
setTimeout(function () {
|
||||
var t = "fixed" === a.css("position");
|
||||
r.style(e, {
|
||||
top: t ? 0 : n.scrollTop(),
|
||||
left: t ? 0 : n.scrollLeft(),
|
||||
width: n.width(),
|
||||
height: n.height()
|
||||
}, !0), a.find(".layui-layer-min").hide()
|
||||
}, 100)
|
||||
}, r.title = function (e, t) {
|
||||
var n = i("#" + l[0] + (t || r.index)).find(l[1]);
|
||||
n.html(e)
|
||||
}, r.close = function (e, callback) {
|
||||
var t = i("#" + l[0] + e),
|
||||
n = t.attr("type"),
|
||||
a = "layer-anim-close";
|
||||
if (t[0]) {
|
||||
var s = "layui-layer-wrap",
|
||||
f = function () {
|
||||
if (n === o.type[1] && "object" === t.attr("conType")) {
|
||||
t.children(":not(." + l[5] + ")").remove();
|
||||
for (var a = t.find("." + s), r = 0; r < 2; r++) a.unwrap();
|
||||
a.css("display", a.data("display")).removeClass(s)
|
||||
} else {
|
||||
if (n === o.type[2]) try {
|
||||
var f = i("#" + l[4] + e)[0];
|
||||
f.contentWindow.document.write(""), f.contentWindow.close(), t.find("." + l[5])[0].removeChild(f)
|
||||
} catch (c) {
|
||||
}
|
||||
t[0].innerHTML = "", t.remove()
|
||||
}
|
||||
"function" == typeof o.end[e] && o.end[e](), delete o.end[e]
|
||||
};
|
||||
t.data("isOutAnim") && t.addClass("layer-anim " + a), i("#layui-layer-moves, #layui-layer-shade" + e).remove(), 6 ==
|
||||
r.ie && o.reselect(), o.rescollbar(e), t.attr("minLeft") && (o.minIndex--, o.minLeft.push(t.attr("minLeft"))), r.ie &&
|
||||
r.ie < 10 || !t.data("isOutAnim") ? f() : setTimeout(function () {
|
||||
f()
|
||||
}, 200)
|
||||
}
|
||||
typeof callback === 'function' && callback();
|
||||
}, r.closeAll = function (e) {
|
||||
i.each(i("." + l[0]), function () {
|
||||
var t = i(this),
|
||||
n = e ? t.attr("type") === e : 1;
|
||||
n && r.close(t.attr("times")), n = null
|
||||
})
|
||||
};
|
||||
var f = r.cache || {},
|
||||
c = function (e) {
|
||||
return f.skin ? " " + f.skin + " " + f.skin + "-" + e : ""
|
||||
};
|
||||
r.prompt = function (e, t) {
|
||||
e.rquired = e.rquired == undefined ? true : e.rquired;
|
||||
var a = "";
|
||||
if (e = e || {}, "function" == typeof e && (t = e), e.area) {
|
||||
var o = e.area;
|
||||
a = 'style="width: ' + o[0] + "; height: " + o[1] + ';"', delete e.area
|
||||
}
|
||||
var s, l = 2 == e.formType ? '<textarea class="layui-layer-input"' + a + "></textarea>" : function () {
|
||||
return '<input type="' + (1 == e.formType ? "password" : "text") + '" class="layui-layer-input">'
|
||||
}(),
|
||||
f = e.success;
|
||||
return delete e.success, r.open(i.extend({
|
||||
type: 1,
|
||||
btn: ["确定", "取消"],
|
||||
content: l,
|
||||
skin: "layui-layer-prompt" + c("prompt"),
|
||||
maxWidth: n.width(),
|
||||
success: function (t) {
|
||||
s = t.find(".layui-layer-input"), s.val(e.value || "").focus(), "function" == typeof f && f(t)
|
||||
},
|
||||
resize: !1,
|
||||
yes: function (i) {
|
||||
var n = s.val();
|
||||
"" === n && e.rquired ? s.focus() : n.length > (e.maxlength || 500) ? r.tips("最多输入" + (e.maxlength ||
|
||||
500) + "个字数", s, {
|
||||
tips: 1
|
||||
}) : t && t(n, i, s)
|
||||
}
|
||||
}, e))
|
||||
}, r.tab = function (e) {
|
||||
e = e || {};
|
||||
var t = e.tab || {},
|
||||
n = "layui-this",
|
||||
a = e.success;
|
||||
return delete e.success, r.open(i.extend({
|
||||
type: 1,
|
||||
skin: "layui-layer-tab" + c("tab"),
|
||||
resize: !1,
|
||||
title: function () {
|
||||
var e = t.length,
|
||||
i = 1,
|
||||
a = "";
|
||||
if (e > 0)
|
||||
for (a = '<span class="' + n + '">' + t[0].title + "</span>"; i < e; i++) a += "<span>" + t[i].title +
|
||||
"</span>";
|
||||
return a
|
||||
}(),
|
||||
content: '<ul class="layui-layer-tabmain">' + function () {
|
||||
var e = t.length,
|
||||
i = 1,
|
||||
a = "";
|
||||
if (e > 0)
|
||||
for (a = '<li class="layui-layer-tabli ' + n + '">' + (t[0].content || "no content") + "</li>"; i < e; i++) a +=
|
||||
'<li class="layui-layer-tabli">' + (t[i].content || "no content") + "</li>";
|
||||
return a
|
||||
}() + "</ul>",
|
||||
success: function (t) {
|
||||
var o = t.find(".layui-layer-title").children(),
|
||||
r = t.find(".layui-layer-tabmain").children();
|
||||
o.on("mousedown", function (t) {
|
||||
t.stopPropagation ? t.stopPropagation() : t.cancelBubble = !0;
|
||||
var a = i(this),
|
||||
o = a.index();
|
||||
a.addClass(n).siblings().removeClass(n), r.eq(o).show().siblings().hide(), "function" == typeof e.change &&
|
||||
e.change(o)
|
||||
}), "function" == typeof a && a(t)
|
||||
}
|
||||
}, e))
|
||||
}, r.photos = function (t, n, a) {
|
||||
function o(e, t, i) {
|
||||
var n = new Image;
|
||||
return n.src = e, n.complete ? t(n) : (n.onload = function () {
|
||||
n.onload = null, t(n)
|
||||
}, void (n.onerror = function (e) {
|
||||
n.onerror = null, i(e)
|
||||
}))
|
||||
}
|
||||
|
||||
var s = {};
|
||||
if (t = t || {}, t.photos) {
|
||||
var l = t.photos.constructor === Object,
|
||||
f = l ? t.photos : {},
|
||||
u = f.data || [],
|
||||
d = f.start || 0;
|
||||
s.imgIndex = (0 | d) + 1, t.img = t.img || "[layer-src]"; //要添加放到的DOM属性默认值
|
||||
var y = t.success;
|
||||
if (delete t.success, l) {
|
||||
if (0 === u.length) return r.msg("没有图片")
|
||||
} else {
|
||||
var p = i(t.photos),
|
||||
h = function () {
|
||||
u = [], p.find(t.img).each(function (e) {
|
||||
var t = i(this);
|
||||
t.attr("layer-index", e), u.push({
|
||||
alt: t.attr("alt"),
|
||||
pid: t.attr("layer-pid"),
|
||||
src: t.attr("layer-src") || t.attr("src"),
|
||||
thumb: t.attr("src")
|
||||
})
|
||||
})
|
||||
};
|
||||
if (h(), 0 === u.length) return;
|
||||
if (n || p.off("click").on("click", t.img, function (event) {
|
||||
event.stopPropagation();
|
||||
var e = i(this),
|
||||
n = e.attr("layer-index");
|
||||
r.photos(i.extend(t, {
|
||||
photos: {
|
||||
start: n,
|
||||
data: u,
|
||||
tab: t.tab
|
||||
},
|
||||
full: t.full
|
||||
}), !0), h()
|
||||
}), !n) return
|
||||
}
|
||||
s.imgprev = function (e) {
|
||||
s.imgIndex--, s.imgIndex < 1 && (s.imgIndex = u.length), s.tabimg(e)
|
||||
}, s.imgnext = function (e, t) {
|
||||
s.imgIndex++, s.imgIndex > u.length && (s.imgIndex = 1, t) || s.tabimg(e)
|
||||
}, s.keyup = function (e) {
|
||||
if (!s.end) {
|
||||
var t = e.keyCode;
|
||||
e.preventDefault(), 37 === t ? s.imgprev(!0) : 39 === t ? s.imgnext(!0) : 27 === t && r.close(s.index)
|
||||
}
|
||||
}, s.tabimg = function (e) {
|
||||
if (!(u.length <= 1)) return f.start = s.imgIndex - 1, r.close(s.index), r.photos(t, !0, e)
|
||||
}, s.event = function () {
|
||||
s.bigimg.hover(function () {
|
||||
s.imgsee.show()
|
||||
}, function () {
|
||||
s.imgsee.hide()
|
||||
}), s.bigimg.find(".layui-layer-imgprev").on("click", function (e) {
|
||||
e.preventDefault(), s.imgprev()
|
||||
}), s.bigimg.find(".layui-layer-imgnext").on("click", function (e) {
|
||||
e.preventDefault(), s.imgnext()
|
||||
}), i(document).on("keyup", s.keyup)
|
||||
}, s.loadi = r.load(1, {
|
||||
shade: !("shade" in t) && .9,
|
||||
scrollbar: !1
|
||||
}), o(u[d].src, function (n) {
|
||||
r.close(s.loadi), s.index = r.open(i.extend({
|
||||
type: 1,
|
||||
id: "layui-layer-photos",
|
||||
area: function () {
|
||||
var a = [n.width, n.height],
|
||||
o = [i(e).width() - 100, i(e).height() - 100];
|
||||
if (!t.full && (a[0] > o[0] || a[1] > o[1])) {
|
||||
var r = [a[0] / o[0], a[1] / o[1]];
|
||||
r[0] > r[1] ? (a[0] = a[0] / r[0], a[1] = a[1] / r[0]) : r[0] < r[1] && (a[0] = a[0] / r[1], a[1] = a[1] /
|
||||
r[1])
|
||||
}
|
||||
return [a[0] + "px", a[1] + "px"]
|
||||
}(),
|
||||
title: !1,
|
||||
shade: .9,
|
||||
shadeClose: !0,
|
||||
closeBtn: !1,
|
||||
move: ".layui-layer-phimg img",
|
||||
moveType: 1,
|
||||
scrollbar: !1,
|
||||
moveOut: !0,
|
||||
isOutAnim: !1,
|
||||
skin: "layui-layer-photos" + c("photos"),
|
||||
content: '<div class="layui-layer-phimg"><img src="' + u[d].src + '" alt="' + (u[d].alt || "") +
|
||||
'" layer-pid="' + u[d].pid + '"><div class="layui-layer-imgsee">' + (u.length > 1 ?
|
||||
'<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:' + (a ? "block" : "") +
|
||||
'"><span class="layui-layer-imgtit"><a href="javascript:;">' + (u[d].alt || "") + "</a><em>" + s.imgIndex +
|
||||
"/" + u.length + "</em></span></div></div></div>",
|
||||
success: function (e, i) {
|
||||
s.bigimg = e.find(".layui-layer-phimg"), s.imgsee = e.find(".layui-layer-imguide,.layui-layer-imgbar"), s.event(
|
||||
e), t.tab && t.tab(u[d], e), "function" == typeof y && y(e)
|
||||
},
|
||||
end: function () {
|
||||
s.end = !0, i(document).off("keyup", s.keyup)
|
||||
}
|
||||
}, t))
|
||||
}, function () {
|
||||
r.close(s.loadi), r.msg(
|
||||
"当前图片地址异常<br>是否继续查看下一张?", {
|
||||
time: 3e4,
|
||||
btn: ["下一张", "不看了"],
|
||||
yes: function () {
|
||||
u.length > 1 && s.imgnext(!0, !0)
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
}, o.run = function (t) {
|
||||
i = t, n = i(e), l.html = i("html"), r.open = function (e) {
|
||||
var t = new s(e);
|
||||
return t.index
|
||||
}
|
||||
}, e.layui && layui.define ? (r.ready(), layui.define("jquery", function (t) {
|
||||
r.path = layui.cache.dir, o.run(layui.$), e.layer = r, t("layer", r)
|
||||
})) : "function" == typeof define && define.amd ? define(["jquery"], function () {
|
||||
return o.run(e.jQuery), r
|
||||
}) : function () {
|
||||
o.run(e.jQuery), r.ready()
|
||||
}()
|
||||
}(window);
|
||||
2
public/static/ext/layui/lay/modules/laypage.js
Executable file
2
public/static/ext/layui/lay/modules/laypage.js
Executable file
@@ -0,0 +1,2 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;layui.define(function(e){"use strict";var a=document,t="getElementById",n="getElementsByTagName",i="laypage",r="layui-disabled",u=function(e){var a=this;a.config=e||{},a.config.index=++s.index,a.render(!0)};u.prototype.type=function(){var e=this.config;if("object"==typeof e.elem)return void 0===e.elem.length?2:3},u.prototype.view=function(){var e=this,a=e.config,t=a.groups="groups"in a?0|a.groups:5;a.layout="object"==typeof a.layout?a.layout:["prev","page","next"],a.count=0|a.count,a.curr=0|a.curr||1,a.limits="object"==typeof a.limits?a.limits:[10,20,30,40,50],a.limit=0|a.limit||10,a.pages=Math.ceil(a.count/a.limit)||1,a.curr>a.pages&&(a.curr=a.pages),t<0?t=1:t>a.pages&&(t=a.pages),a.prev="prev"in a?a.prev:"上一页",a.next="next"in a?a.next:"下一页";var n=a.pages>t?Math.ceil((a.curr+(t>1?1:0))/(t>0?t:1)):1,i={prev:function(){return a.prev?'<a href="javascript:;" class="layui-laypage-prev'+(1==a.curr?" "+r:"")+'" data-page="'+(a.curr-1)+'">'+a.prev+"</a>":""}(),page:function(){var e=[];if(a.count<1)return"";n>1&&a.first!==!1&&0!==t&&e.push('<a href="javascript:;" class="layui-laypage-first" data-page="1" title="首页">'+(a.first||1)+"</a>");var i=Math.floor((t-1)/2),r=n>1?a.curr-i:1,u=n>1?function(){var e=a.curr+(t-i-1);return e>a.pages?a.pages:e}():t;for(u-r<t-1&&(r=u-t+1),a.first!==!1&&r>2&&e.push('<span class="layui-laypage-spr">…</span>');r<=u;r++)r===a.curr?e.push('<span class="layui-laypage-curr"><em class="layui-laypage-em" '+(/^#/.test(a.theme)?'style="background-color:'+a.theme+';"':"")+"></em><em>"+r+"</em></span>"):e.push('<a href="javascript:;" data-page="'+r+'">'+r+"</a>");return a.pages>t&&a.pages>u&&a.last!==!1&&(u+1<a.pages&&e.push('<span class="layui-laypage-spr">…</span>'),0!==t&&e.push('<a href="javascript:;" class="layui-laypage-last" title="尾页" data-page="'+a.pages+'">'+(a.last||a.pages)+"</a>")),e.join("")}(),next:function(){return a.next?'<a href="javascript:;" class="layui-laypage-next'+(a.curr==a.pages?" "+r:"")+'" data-page="'+(a.curr+1)+'">'+a.next+"</a>":""}(),count:'<span class="layui-laypage-count">共 '+a.count+" 条</span>",limit:function(){var e=['<span class="layui-laypage-limits"><select lay-ignore>'];return layui.each(a.limits,function(t,n){e.push('<option value="'+n+'"'+(n===a.limit?"selected":"")+">"+n+" 条/页</option>")}),e.join("")+"</select></span>"}(),refresh:['<a href="javascript:;" data-page="'+a.curr+'" class="layui-laypage-refresh">','<i class="layui-icon layui-icon-refresh"></i>',"</a>"].join(""),skip:function(){return['<span class="layui-laypage-skip">到第','<input type="text" min="1" value="'+a.curr+'" class="layui-input">','页<button type="button" class="layui-laypage-btn">确定</button>',"</span>"].join("")}()};return['<div class="layui-box layui-laypage layui-laypage-'+(a.theme?/^#/.test(a.theme)?"molv":a.theme:"default")+'" id="layui-laypage-'+a.index+'">',function(){var e=[];return layui.each(a.layout,function(a,t){i[t]&&e.push(i[t])}),e.join("")}(),"</div>"].join("")},u.prototype.jump=function(e,a){if(e){var t=this,i=t.config,r=e.children,u=e[n]("button")[0],l=e[n]("input")[0],p=e[n]("select")[0],c=function(){var e=0|l.value.replace(/\s|\D/g,"");e&&(i.curr=e,t.render())};if(a)return c();for(var o=0,y=r.length;o<y;o++)"a"===r[o].nodeName.toLowerCase()&&s.on(r[o],"click",function(){var e=0|this.getAttribute("data-page");e<1||e>i.pages||(i.curr=e,t.render())});p&&s.on(p,"change",function(){var e=this.value;i.curr*e>i.count&&(i.curr=Math.ceil(i.count/e)),i.limit=e,t.render()}),u&&s.on(u,"click",function(){c()})}},u.prototype.skip=function(e){if(e){var a=this,t=e[n]("input")[0];t&&s.on(t,"keyup",function(t){var n=this.value,i=t.keyCode;/^(37|38|39|40)$/.test(i)||(/\D/.test(n)&&(this.value=n.replace(/\D/,"")),13===i&&a.jump(e,!0))})}},u.prototype.render=function(e){var n=this,i=n.config,r=n.type(),u=n.view();2===r?i.elem&&(i.elem.innerHTML=u):3===r?i.elem.html(u):a[t](i.elem)&&(a[t](i.elem).innerHTML=u),i.jump&&i.jump(i,e);var s=a[t]("layui-laypage-"+i.index);n.jump(s),i.hash&&!e&&(location.hash="!"+i.hash+"="+i.curr),n.skip(s)};var s={render:function(e){var a=new u(e);return a.index},index:layui.laypage?layui.laypage.index+1e4:0,on:function(e,a,t){return e.attachEvent?e.attachEvent("on"+a,function(a){a.target=a.srcElement,t.call(e,a)}):e.addEventListener(a,t,!1),this}};e(i,s)});
|
||||
2
public/static/ext/layui/lay/modules/laytpl.js
Executable file
2
public/static/ext/layui/lay/modules/laytpl.js
Executable file
@@ -0,0 +1,2 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;layui.define(function(e){"use strict";var r={open:"{{",close:"}}"},c={exp:function(e){return new RegExp(e,"g")},query:function(e,c,t){var o=["#([\\s\\S])+?","([^{#}])*?"][e||0];return n((c||"")+r.open+o+r.close+(t||""))},escape:function(e){return String(e||"").replace(/&(?!#?[a-zA-Z0-9]+;)/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/'/g,"'").replace(/"/g,""")},error:function(e,r){var c="Laytpl Error:";return"object"==typeof console&&console.error(c+e+"\n"+(r||"")),c+e}},n=c.exp,t=function(e){this.tpl=e};t.pt=t.prototype,window.errors=0,t.pt.parse=function(e,t){var o=this,p=e,a=n("^"+r.open+"#",""),l=n(r.close+"$","");e=e.replace(/\s+|\r|\t|\n/g," ").replace(n(r.open+"#"),r.open+"# ").replace(n(r.close+"}"),"} "+r.close).replace(/\\/g,"\\\\").replace(n(r.open+"!(.+?)!"+r.close),function(e){return e=e.replace(n("^"+r.open+"!"),"").replace(n("!"+r.close),"").replace(n(r.open+"|"+r.close),function(e){return e.replace(/(.)/g,"\\$1")})}).replace(/(?="|')/g,"\\").replace(c.query(),function(e){return e=e.replace(a,"").replace(l,""),'";'+e.replace(/\\/g,"")+';view+="'}).replace(c.query(1),function(e){var c='"+(';return e.replace(/\s/g,"")===r.open+r.close?"":(e=e.replace(n(r.open+"|"+r.close),""),/^=/.test(e)&&(e=e.replace(/^=/,""),c='"+_escape_('),c+e.replace(/\\/g,"")+')+"')}),e='"use strict";var view = "'+e+'";return view;';try{return o.cache=e=new Function("d, _escape_",e),e(t,c.escape)}catch(u){return delete o.cache,c.error(u,p)}},t.pt.render=function(e,r){var n,t=this;return e?(n=t.cache?t.cache(e,c.escape):t.parse(t.tpl,e),r?void r(n):n):c.error("no data")};var o=function(e){return"string"!=typeof e?c.error("Template not found"):new t(e)};o.config=function(e){e=e||{};for(var c in e)r[c]=e[c]},o.v="1.2.0",e("laytpl",o)});
|
||||
2
public/static/ext/layui/lay/modules/mobile.js
Executable file
2
public/static/ext/layui/lay/modules/mobile.js
Executable file
File diff suppressed because one or more lines are too long
2
public/static/ext/layui/lay/modules/rate.js
Executable file
2
public/static/ext/layui/lay/modules/rate.js
Executable file
@@ -0,0 +1,2 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;layui.define("jquery",function(e){"use strict";var a=layui.jquery,i={config:{},index:layui.rate?layui.rate.index+1e4:0,set:function(e){var i=this;return i.config=a.extend({},i.config,e),i},on:function(e,a){return layui.onevent.call(this,n,e,a)}},l=function(){var e=this,a=e.config;return{setvalue:function(a){e.setvalue.call(e,a)},config:a}},n="rate",t="layui-rate",o="layui-icon-rate",s="layui-icon-rate-solid",u="layui-icon-rate-half",r="layui-icon-rate-solid layui-icon-rate-half",c="layui-icon-rate-solid layui-icon-rate",f="layui-icon-rate layui-icon-rate-half",v=function(e){var l=this;l.index=++i.index,l.config=a.extend({},l.config,i.config,e),l.render()};v.prototype.config={length:5,text:!1,readonly:!1,half:!1,value:0,theme:""},v.prototype.render=function(){var e=this,i=e.config,l=i.theme?'style="color: '+i.theme+';"':"";i.elem=a(i.elem),parseInt(i.value)!==i.value&&(i.half||(i.value=Math.ceil(i.value)-i.value<.5?Math.ceil(i.value):Math.floor(i.value)));for(var n='<ul class="layui-rate" '+(i.readonly?"readonly":"")+">",u=1;u<=i.length;u++){var r='<li class="layui-inline"><i class="layui-icon '+(u>Math.floor(i.value)?o:s)+'" '+l+"></i></li>";i.half&&parseInt(i.value)!==i.value&&u==Math.ceil(i.value)?n=n+'<li><i class="layui-icon layui-icon-rate-half" '+l+"></i></li>":n+=r}n+="</ul>"+(i.text?'<span class="layui-inline">'+i.value+"星":"")+"</span>";var c=i.elem,f=c.next("."+t);f[0]&&f.remove(),e.elemTemp=a(n),i.span=e.elemTemp.next("span"),i.setText&&i.setText(i.value),c.html(e.elemTemp),c.addClass("layui-inline"),i.readonly||e.action()},v.prototype.setvalue=function(e){var a=this,i=a.config;i.value=e,a.render()},v.prototype.action=function(){var e=this,i=e.config,l=e.elemTemp,n=l.find("i").width();l.children("li").each(function(e){var t=e+1,v=a(this);v.on("click",function(e){if(i.value=t,i.half){var o=e.pageX-a(this).offset().left;o<=n/2&&(i.value=i.value-.5)}i.text&&l.next("span").text(i.value+"星"),i.choose&&i.choose(i.value),i.setText&&i.setText(i.value)}),v.on("mousemove",function(e){if(l.find("i").each(function(){a(this).addClass(o).removeClass(r)}),l.find("i:lt("+t+")").each(function(){a(this).addClass(s).removeClass(f)}),i.half){var c=e.pageX-a(this).offset().left;c<=n/2&&v.children("i").addClass(u).removeClass(s)}}),v.on("mouseleave",function(){l.find("i").each(function(){a(this).addClass(o).removeClass(r)}),l.find("i:lt("+Math.floor(i.value)+")").each(function(){a(this).addClass(s).removeClass(f)}),i.half&&parseInt(i.value)!==i.value&&l.children("li:eq("+Math.floor(i.value)+")").children("i").addClass(u).removeClass(c)})})},v.prototype.events=function(){var e=this;e.config},i.render=function(e){var a=new v(e);return l.call(a)},e(n,i)});
|
||||
2
public/static/ext/layui/lay/modules/slider.js
Executable file
2
public/static/ext/layui/lay/modules/slider.js
Executable file
File diff suppressed because one or more lines are too long
1071
public/static/ext/layui/lay/modules/table.js
Executable file
1071
public/static/ext/layui/lay/modules/table.js
Executable file
File diff suppressed because it is too large
Load Diff
2
public/static/ext/layui/lay/modules/transfer.js
Executable file
2
public/static/ext/layui/lay/modules/transfer.js
Executable file
File diff suppressed because one or more lines are too long
2
public/static/ext/layui/lay/modules/tree.js
Executable file
2
public/static/ext/layui/lay/modules/tree.js
Executable file
File diff suppressed because one or more lines are too long
1390
public/static/ext/layui/lay/modules/treeGrid.js
Executable file
1390
public/static/ext/layui/lay/modules/treeGrid.js
Executable file
File diff suppressed because it is too large
Load Diff
309
public/static/ext/layui/lay/modules/upload.js
Executable file
309
public/static/ext/layui/lay/modules/upload.js
Executable file
@@ -0,0 +1,309 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */ ;
|
||||
layui.define("layer", function(e) {
|
||||
"use strict";
|
||||
var t = layui.$,
|
||||
i = layui.layer,
|
||||
n = layui.hint(),
|
||||
o = layui.device(),
|
||||
a = {
|
||||
config: {},
|
||||
set: function(e) {
|
||||
var i = this;
|
||||
return i.config = t.extend({}, i.config, e), i
|
||||
},
|
||||
on: function(e, t) {
|
||||
return layui.onevent.call(this, r, e, t)
|
||||
}
|
||||
},
|
||||
l = function() {
|
||||
var e = this;
|
||||
return {
|
||||
upload: function(t) {
|
||||
e.upload.call(e, t)
|
||||
},
|
||||
reload: function(t) {
|
||||
e.reload.call(e, t)
|
||||
},
|
||||
config: e.config
|
||||
}
|
||||
},
|
||||
r = "upload",
|
||||
u = "layui-upload-file",
|
||||
c = "layui-upload-form",
|
||||
f = "layui-upload-iframe",
|
||||
s = "layui-upload-choose",
|
||||
p = function(e) {
|
||||
var i = this;
|
||||
i.config = t.extend({}, i.config, a.config, e), i.render()
|
||||
};
|
||||
p.prototype.config = {
|
||||
accept: "images",
|
||||
exts: "",
|
||||
auto: !0,
|
||||
bindAction: "",
|
||||
url: "",
|
||||
field: "file",
|
||||
acceptMime: "",
|
||||
method: "post",
|
||||
data: {},
|
||||
drag: !0,
|
||||
size: 0,
|
||||
number: 0,
|
||||
multiple: !1
|
||||
}, p.prototype.render = function(e) {
|
||||
var i = this,
|
||||
e = i.config;
|
||||
e.elem = t(e.elem), e.bindAction = t(e.bindAction), i.file(), i.events()
|
||||
}, p.prototype.file = function() {
|
||||
var e = this,
|
||||
i = e.config,
|
||||
n = e.elemFile = t(['<input class="' + u + '" type="file" accept="' + i.acceptMime +
|
||||
'" name="' + i.field + '"', i.multiple ? " multiple" : "", ">"
|
||||
].join("")),
|
||||
a = i.elem.next();
|
||||
(a.hasClass(u) || a.hasClass(c)) && a.remove(), o.ie && o.ie < 10 && i.elem.wrap(
|
||||
'<div class="layui-upload-wrap"></div>'), e.isFile() ? (e.elemFile = i.elem, i.field = i
|
||||
.elem[0].name) : i.elem.after(n), o.ie && o.ie < 10 && e.initIE()
|
||||
}, p.prototype.initIE = function() {
|
||||
var e = this,
|
||||
i = e.config,
|
||||
n = t('<iframe id="' + f + '" class="' + f + '" name="' + f + '" frameborder="0"></iframe>'),
|
||||
o = t(['<form target="' + f + '" class="' + c +
|
||||
'" method="post" key="set-mine" enctype="multipart/form-data" action="' + i.url + '">',
|
||||
"</form>"
|
||||
].join(""));
|
||||
t("#" + f)[0] || t("body").append(n), i.elem.next().hasClass(c) || (e.elemFile.wrap(o), i.elem.next(
|
||||
"." + c).append(function() {
|
||||
var e = [];
|
||||
return layui.each(i.data, function(t, i) {
|
||||
i = "function" == typeof i ? i() : i, e.push(
|
||||
'<input type="hidden" name="' + t + '" value="' + i + '">')
|
||||
}), e.join("")
|
||||
}()))
|
||||
}, p.prototype.msg = function(e) {
|
||||
return i.msg(e, {
|
||||
icon: 2,
|
||||
shift: 6
|
||||
})
|
||||
}, p.prototype.isFile = function() {
|
||||
var e = this.config.elem[0];
|
||||
if (e) return "input" === e.tagName.toLocaleLowerCase() && "file" === e.type
|
||||
}, p.prototype.preview = function(e) {
|
||||
var t = this;
|
||||
window.FileReader && layui.each(t.chooseFiles, function(t, i) {
|
||||
var n = new FileReader;
|
||||
n.readAsDataURL(i), n.onload = function() {
|
||||
e && e(t, i, this.result)
|
||||
}
|
||||
})
|
||||
}, p.prototype.upload = function(e, i) {
|
||||
var n, a = this,
|
||||
l = a.config,
|
||||
r = a.elemFile[0],
|
||||
u = function() {
|
||||
var i = 0,
|
||||
n = 0,
|
||||
o = e || a.files || a.chooseFiles || r.files,
|
||||
u = function() {
|
||||
l.multiple && i + n === a.fileLength && "function" == typeof l.allDone && l
|
||||
.allDone({
|
||||
total: a.fileLength,
|
||||
successful: i,
|
||||
aborted: n
|
||||
})
|
||||
};
|
||||
layui.each(o, function(e, o) {
|
||||
var r = new FormData;
|
||||
r.append(l.field, o), layui.each(l.data, function(e, t) {
|
||||
t = "function" == typeof t ? t() : t, r.append(e, t)
|
||||
}), t.ajax({
|
||||
url: l.url,
|
||||
type: "post",
|
||||
data: r,
|
||||
contentType: !1,
|
||||
processData: !1,
|
||||
dataType: "json",
|
||||
headers: l.headers || {},
|
||||
success: function(t) {
|
||||
i++, d(e, t), u()
|
||||
},
|
||||
error: function(e) {
|
||||
n++, e.responseJSON && e.responseJSON.message ? a.msg(e.responseJSON.message) : a.msg("请求上传接口出现异常"), m(e), u()
|
||||
},
|
||||
xhr: function() {
|
||||
var e = new XMLHttpRequest;
|
||||
return e.upload.addEventListener("progress", function(e) {
|
||||
if (e.lengthComputable) {
|
||||
var t = Math.floor(e.loaded / e.total *
|
||||
100);
|
||||
"function" == typeof l.progress && l
|
||||
.progress(t, e)
|
||||
}
|
||||
}), e
|
||||
}
|
||||
})
|
||||
})
|
||||
},
|
||||
c = function() {
|
||||
var e = t("#" + f);
|
||||
a.elemFile.parent().submit(), clearInterval(p.timer), p.timer = setInterval(function() {
|
||||
var t, i = e.contents().find("body");
|
||||
try {
|
||||
t = i.text()
|
||||
} catch (n) {
|
||||
a.msg("获取上传后的响应信息出现异常"), clearInterval(p.timer), m()
|
||||
}
|
||||
t && (clearInterval(p.timer), i.html(""), d(0, t))
|
||||
}, 30)
|
||||
},
|
||||
d = function(e, t) {
|
||||
if (a.elemFile.next("." + s).remove(), r.value = "", "object" != typeof t) try {
|
||||
t = JSON.parse(t)
|
||||
} catch (i) {
|
||||
return t = {}, a.msg("请对上传接口返回有效JSON")
|
||||
}
|
||||
"function" == typeof l.done && l.done(t, e || 0, function(e) {
|
||||
a.upload(e)
|
||||
})
|
||||
},
|
||||
m = function(e) {
|
||||
l.auto && (r.value = ""), "function" == typeof l.error && l.error(e || 0, function(e) {
|
||||
a.upload(e)
|
||||
})
|
||||
},
|
||||
h = l.exts,
|
||||
v = function() {
|
||||
var t = [];
|
||||
return layui.each(e || a.chooseFiles, function(e, i) {
|
||||
t.push(i.name)
|
||||
}), t
|
||||
}(),
|
||||
g = {
|
||||
preview: function(e) {
|
||||
a.preview(e)
|
||||
},
|
||||
upload: function(e, t) {
|
||||
var i = {};
|
||||
i[e] = t, a.upload(i)
|
||||
},
|
||||
pushFile: function() {
|
||||
return a.files = a.files || {}, layui.each(a.chooseFiles, function(e, t) {
|
||||
a.files[e] = t
|
||||
}), a.files
|
||||
},
|
||||
resetFile: function(e, t, i) {
|
||||
var n = new File([t], i);
|
||||
a.files = a.files || {}, a.files[e] = n
|
||||
}
|
||||
},
|
||||
y = function() {
|
||||
if ("choose" !== i && !l.auto || (l.choose && l.choose(g), "choose" !== i)) return l
|
||||
.before && l.before(g), o.ie ? o.ie > 9 ? u() : c() : void u()
|
||||
};
|
||||
if (v = 0 === v.length ? r.value.match(/[^\/\\]+\..+/g) || [] || "" : v, 0 !== v.length) {
|
||||
switch (l.accept) {
|
||||
case "file":
|
||||
if (h && !RegExp("\\w\\.(" + h + ")$", "i").test(escape(v))) return a.msg(
|
||||
"选择的文件中包含不支持的格式"), r.value = "";
|
||||
break;
|
||||
case "video":
|
||||
if (!RegExp("\\w\\.(" + (h || "avi|mp4|wma|rmvb|rm|flash|3gp|flv") + ")$", "i").test(
|
||||
escape(v))) return a.msg("选择的视频中包含不支持的格式"), r.value = "";
|
||||
break;
|
||||
case "audio":
|
||||
if (!RegExp("\\w\\.(" + (h || "mp3|wav|mid") + ")$", "i").test(escape(v))) return a.msg(
|
||||
"选择的音频中包含不支持的格式"), r.value = "";
|
||||
break;
|
||||
default:
|
||||
if (layui.each(v, function(e, t) {
|
||||
RegExp(".(" + (h || "jpg|png|gif|bmp|jpeg$") + ")", "i").test(escape(t)) ||
|
||||
(n = !0)
|
||||
}), n) return a.msg("选择的图片中包含不支持的格式"), r.value = ""
|
||||
}
|
||||
if (a.fileLength = function() {
|
||||
var t = 0,
|
||||
i = e || a.files || a.chooseFiles || r.files;
|
||||
return layui.each(i, function() {
|
||||
t++
|
||||
}), t
|
||||
}(), l.number && a.fileLength > l.number) return a.msg("同时最多只能上传的数量为:" + l.number);
|
||||
if (l.size > 0 && !(o.ie && o.ie < 10)) {
|
||||
var F;
|
||||
if (layui.each(a.chooseFiles, function(e, t) {
|
||||
if (t.size > 1024 * l.size) {
|
||||
var i = l.size / 1024;
|
||||
i = i >= 1 ? i.toFixed(2) + "MB" : l.size + "KB", r.value = "", F = i
|
||||
}
|
||||
}), F) return a.msg("文件不能超过" + F)
|
||||
}
|
||||
y()
|
||||
}
|
||||
}, p.prototype.reload = function(e) {
|
||||
e = e || {}, delete e.elem, delete e.bindAction;
|
||||
var i = this,
|
||||
e = i.config = t.extend({}, i.config, a.config, e),
|
||||
n = e.elem.next();
|
||||
n.attr({
|
||||
name: e.name,
|
||||
accept: e.acceptMime,
|
||||
multiple: e.multiple
|
||||
})
|
||||
}, p.prototype.events = function() {
|
||||
var e = this,
|
||||
i = e.config,
|
||||
a = function(t) {
|
||||
e.chooseFiles = {}, layui.each(t, function(t, i) {
|
||||
var n = (new Date).getTime();
|
||||
e.chooseFiles[n + "-" + t] = i
|
||||
})
|
||||
},
|
||||
l = function(t, n) {
|
||||
var o = e.elemFile,
|
||||
a = t.length > 1 ? t.length + "个文件" : (t[0] || {}).name || o[0].value.match(
|
||||
/[^\/\\]+\..+/g) || [] || "";
|
||||
o.next().hasClass(s) && o.next().remove(), e.upload(null, "choose"), e.isFile() || i
|
||||
.choose || o.after('<span class="layui-inline ' + s + '">' + a + "</span>")
|
||||
};
|
||||
i.elem.off("upload.start").on("upload.start", function() {
|
||||
var o = t(this),
|
||||
a = o.attr("lay-data");
|
||||
if (a) try {
|
||||
a = new Function("return " + a)(), e.config = t.extend({}, i, a)
|
||||
} catch (l) {
|
||||
n.error("Upload element property lay-data configuration item has a syntax error: " +
|
||||
a)
|
||||
}
|
||||
e.config.item = o, e.elemFile[0].click()
|
||||
}), o.ie && o.ie < 10 || i.elem.off("upload.over").on("upload.over", function() {
|
||||
var e = t(this);
|
||||
e.attr("lay-over", "")
|
||||
}).off("upload.leave").on("upload.leave", function() {
|
||||
var e = t(this);
|
||||
e.removeAttr("lay-over")
|
||||
}).off("upload.drop").on("upload.drop", function(n, o) {
|
||||
var r = t(this),
|
||||
u = o.originalEvent.dataTransfer.files || [];
|
||||
r.removeAttr("lay-over"), a(u), i.auto ? e.upload(u) : l(u)
|
||||
}), e.elemFile.off("upload.change").on("upload.change", function() {
|
||||
var t = this.files || [];
|
||||
a(t), i.auto ? e.upload() : l(t)
|
||||
}), i.bindAction.off("upload.action").on("upload.action", function() {
|
||||
e.upload()
|
||||
}), i.elem.data("haveEvents") || (e.elemFile.on("change", function() {
|
||||
t(this).trigger("upload.change")
|
||||
}), i.elem.on("click", function() {
|
||||
e.isFile() || t(this).trigger("upload.start")
|
||||
}), i.drag && i.elem.on("dragover", function(e) {
|
||||
e.preventDefault(), t(this).trigger("upload.over")
|
||||
}).on("dragleave", function(e) {
|
||||
t(this).trigger("upload.leave")
|
||||
}).on("drop", function(e) {
|
||||
e.preventDefault(), t(this).trigger("upload.drop", e)
|
||||
}), i.bindAction.on("click", function() {
|
||||
t(this).trigger("upload.action")
|
||||
}), i.elem.data("haveEvents", !0))
|
||||
}, a.render = function(e) {
|
||||
var t = new p(e);
|
||||
return l.call(t)
|
||||
}, e(r, a)
|
||||
});
|
||||
2
public/static/ext/layui/lay/modules/util.js
Executable file
2
public/static/ext/layui/lay/modules/util.js
Executable file
@@ -0,0 +1,2 @@
|
||||
/** layui-v2.5.5 MIT License By https://www.layui.com */
|
||||
;layui.define("jquery",function(t){"use strict";var e=layui.$,i={fixbar:function(t){var i,n,a="layui-fixbar",o="layui-fixbar-top",r=e(document),l=e("body");t=e.extend({showHeight:200},t),t.bar1=t.bar1===!0?"":t.bar1,t.bar2=t.bar2===!0?"":t.bar2,t.bgcolor=t.bgcolor?"background-color:"+t.bgcolor:"";var c=[t.bar1,t.bar2,""],g=e(['<ul class="'+a+'">',t.bar1?'<li class="layui-icon" lay-type="bar1" style="'+t.bgcolor+'">'+c[0]+"</li>":"",t.bar2?'<li class="layui-icon" lay-type="bar2" style="'+t.bgcolor+'">'+c[1]+"</li>":"",'<li class="layui-icon '+o+'" lay-type="top" style="'+t.bgcolor+'">'+c[2]+"</li>","</ul>"].join("")),s=g.find("."+o),u=function(){var e=r.scrollTop();e>=t.showHeight?i||(s.show(),i=1):i&&(s.hide(),i=0)};e("."+a)[0]||("object"==typeof t.css&&g.css(t.css),l.append(g),u(),g.find("li").on("click",function(){var i=e(this),n=i.attr("lay-type");"top"===n&&e("html,body").animate({scrollTop:0},200),t.click&&t.click.call(this,n)}),r.on("scroll",function(){clearTimeout(n),n=setTimeout(function(){u()},100)}))},countdown:function(t,e,i){var n=this,a="function"==typeof e,o=new Date(t).getTime(),r=new Date(!e||a?(new Date).getTime():e).getTime(),l=o-r,c=[Math.floor(l/864e5),Math.floor(l/36e5)%24,Math.floor(l/6e4)%60,Math.floor(l/1e3)%60];a&&(i=e);var g=setTimeout(function(){n.countdown(t,r+1e3,i)},1e3);return i&&i(l>0?c:[0,0,0,0],e,g),l<=0&&clearTimeout(g),g},timeAgo:function(t,e){var i=this,n=[[],[]],a=(new Date).getTime()-new Date(t).getTime();return a>6912e5?(a=new Date(t),n[0][0]=i.digit(a.getFullYear(),4),n[0][1]=i.digit(a.getMonth()+1),n[0][2]=i.digit(a.getDate()),e||(n[1][0]=i.digit(a.getHours()),n[1][1]=i.digit(a.getMinutes()),n[1][2]=i.digit(a.getSeconds())),n[0].join("-")+" "+n[1].join(":")):a>=864e5?(a/1e3/60/60/24|0)+"天前":a>=36e5?(a/1e3/60/60|0)+"小时前":a>=12e4?(a/1e3/60|0)+"分钟前":a<0?"未来":"刚刚"},digit:function(t,e){var i="";t=String(t),e=e||2;for(var n=t.length;n<e;n++)i+="0";return t<Math.pow(10,e)?i+(0|t):t},toDateString:function(t,e){var i=this,n=new Date(t||new Date),a=[i.digit(n.getFullYear(),4),i.digit(n.getMonth()+1),i.digit(n.getDate())],o=[i.digit(n.getHours()),i.digit(n.getMinutes()),i.digit(n.getSeconds())];return e=e||"yyyy-MM-dd HH:mm:ss",e.replace(/yyyy/g,a[0]).replace(/MM/g,a[1]).replace(/dd/g,a[2]).replace(/HH/g,o[0]).replace(/mm/g,o[1]).replace(/ss/g,o[2])},escape:function(t){return String(t||"").replace(/&(?!#?[a-zA-Z0-9]+;)/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/'/g,"'").replace(/"/g,""")},event:function(t,n,a){n=i.event[t]=e.extend(!0,i.event[t],n)||{},e("body").on(a||"click","*["+t+"]",function(){var i=e(this),a=i.attr(t);n[a]&&n[a].call(this,i)})}};!function(t,e,i){"$:nomunge";function n(){a=e[l](function(){o.each(function(){var e=t(this),i=e.width(),n=e.height(),a=t.data(this,g);(i!==a.w||n!==a.h)&&e.trigger(c,[a.w=i,a.h=n])}),n()},r[s])}var a,o=t([]),r=t.resize=t.extend(t.resize,{}),l="setTimeout",c="resize",g=c+"-special-event",s="delay",u="throttleWindow";r[s]=250,r[u]=!0,t.event.special[c]={setup:function(){if(!r[u]&&this[l])return!1;var e=t(this);o=o.add(e),t.data(this,g,{w:e.width(),h:e.height()}),1===o.length&&n()},teardown:function(){if(!r[u]&&this[l])return!1;var e=t(this);o=o.not(e),e.removeData(g),o.length||clearTimeout(a)},add:function(e){function n(e,n,o){var r=t(this),l=t.data(this,g)||{};l.w=n!==i?n:r.width(),l.h=o!==i?o:r.height(),a.apply(this,arguments)}if(!r[u]&&this[l])return!1;var a;return t.isFunction(e)?(a=e,n):(a=e.handler,void(e.handler=n))}}}(e,window),t("util",i)});
|
||||
Reference in New Issue
Block a user