var pageCurr;
layui.use(['table', 'laydate', 'form'], function () {
var table = layui.table;
var $ = layui.jquery;
var layer = layui.layer;
var layDate = layui.laydate;
var form = layui.form;
// 数据渲染
tableIns = table.render({
elem: '#config',
headers: { token: localStorage.getItem('token') },
url: baseUrl + '/config/list/auth',
page: true,
limit: 16,
limits: [16, 30, 50, 100, 200, 500],
toolbar: '#toolbar',
cellMinWidth: 50,
cols: [[
{ type: 'checkbox', fixed: 'left' }
, { field: 'id', title: 'ID', sort: true, align: 'center', fixed: 'left', width: 80 }
, { field: 'name', align: 'center', title: '名称' }
, { field: 'code', align: 'center', title: '编码' }
, { field: 'value', align: 'center', title: '对应值' }
, { field: 'selectType', align: 'center', title: '筛选类型' }
, { field: 'type$', align: 'center', title: '类型' }
, { field: 'status$', align: 'center', title: '状态' }
, { fixed: 'right', title: '操作', align: 'center', toolbar: '#operate', width: 150 }
]],
request: {
pageName: 'curr',
pageSize: 'limit'
},
parseData: function (res) {
return {
'code': res.code,
'msg': res.msg,
'count': res.data.total,
'data': res.data.records
}
},
response: {
statusCode: 200
},
done: function (res, curr, count) {
if (res.code === 403) {
top.location.href = baseUrl + "/";
}
pageCurr = curr;
limit();
}
});
// 监听排序事件
table.on('sort(config)', function (obj) {
var searchData = {};
$.each($('#search-box [name]').serializeArray(), function () {
searchData[this.name] = this.value;
});
searchData['orderByField'] = obj.field;
searchData['orderByType'] = obj.type;
tableIns.reload({
where: searchData,
page: {
curr: 1
},
done: function (res, curr, count) {
if (res.code === 403) {
top.location.href = baseUrl + "/";
}
pageCurr = curr;
limit();
}
});
});
// 监听头工具栏事件
table.on('toolbar(config)', function (obj) {
var checkStatus = table.checkStatus(obj.config.id);
switch (obj.event) {
case 'addData':
layer.open({
type: 2,
title: '新增',
maxmin: true,
area: [top.detailWidth, top.detailHeight],
shadeClose: false,
content: 'config_detail.html',
success: function (layero, index) {
clearFormVal(layer.getChildFrame('#detail', index));
layer.iframeAuto(index); layer.style(index, { top: (($(window).height() - layer.getChildFrame('#data-detail', index).height()) / 3) + "px" });
}
});
break;
case 'refreshData':
tableIns.reload({
page: {
curr: pageCurr
}
});
limit();
break;
case 'deleteData':
var data = checkStatus.data;
var ids = [];
data.map(function (track) {
ids.push(track.id);
});
if (ids.length === 0) {
layer.msg('请选择数据');
} else {
layer.confirm('确定删除' + (ids.length === 1 ? '此' : ids.length) + '条数据吗', function () {
$.ajax({
url: baseUrl + "/config/delete/auth",
headers: { 'token': localStorage.getItem('token') },
data: { ids: ids },
method: 'POST',
traditional: true,
success: function (res) {
if (res.code === 200) {
layer.closeAll();
tableReload(false);
} else if (res.code === 403) {
top.location.href = baseUrl + "/";
} else {
layer.msg(res.msg)
}
}
})
});
}
break;
case 'refreshCache':
layer.confirm('确定刷新Redis缓存吗', function () {
$.ajax({
url: baseUrl + "/config/refreshCache",
headers: { 'token': localStorage.getItem('token') },
method: 'POST',
success: function (res) {
if (res.code === 200) {
layer.msg('刷新成功');
} else if (res.code === 403) {
top.location.href = baseUrl + "/";
} else {
layer.msg(res.msg)
}
}
})
});
break;
case 'exportData':
layer.confirm('确定导出Excel吗', { shadeClose: true }, function () {
var titles = [];
var fields = [];
obj.config.cols[0].map(function (col) {
if (col.type === 'normal' && col.hide === false && col.toolbar == null) {
titles.push(col.title);
fields.push(col.field);
}
});
var exportData = {};
$.each($('#search-box [name]').serializeArray(), function () {
exportData[this.name] = this.value;
});
var param = {
'config': exportData,
'fields': fields
};
$.ajax({
url: baseUrl + "/config/export/auth",
headers: { 'token': localStorage.getItem('token') },
data: JSON.stringify(param),
dataType: 'json',
contentType: 'application/json;charset=UTF-8',
method: 'POST',
success: function (res) {
layer.closeAll();
if (res.code === 200) {
table.exportFile(titles, res.data, 'xls');
} else if (res.code === 403) {
top.location.href = baseUrl + "/";
} else {
layer.msg(res.msg)
}
}
});
});
break;
case 'serverInfo':
$.ajax({
url: baseUrl + "/license/getServerInfos",
headers: { 'token': localStorage.getItem('token') },
method: 'GET',
success: function (res) {
var pretty = '';
try {
pretty = JSON.stringify(res, null, 2);
} catch (e) {
pretty = res;
}
var html = ''
+ '
'
+ '
系统配置信息
'
+ '
'
+ pretty
+ ''
+ '
'
+ ''
+ '
'
+ '
';
layer.open({
type: 1,
title: '获取系统配置',
area: ['640px', '480px'],
shadeClose: true,
content: html,
success: function (layero, index) {
layero.find('#copy-server-info').on('click', function () {
var text = layero.find('#server-info-pre').text();
if (navigator.clipboard && navigator.clipboard.writeText) {
navigator.clipboard.writeText(text).then(function () {
layer.msg('已复制到剪贴板');
}).catch(function () {
try {
var textarea = document.createElement('textarea');
textarea.value = text;
textarea.style.position = 'fixed';
textarea.style.opacity = '0';
document.body.appendChild(textarea);
textarea.select();
document.execCommand('copy');
document.body.removeChild(textarea);
layer.msg('已复制到剪贴板');
} catch (err) {
layer.msg('复制失败');
}
});
} else {
try {
var textarea = document.createElement('textarea');
textarea.value = text;
textarea.style.position = 'fixed';
textarea.style.opacity = '0';
document.body.appendChild(textarea);
textarea.select();
document.execCommand('copy');
document.body.removeChild(textarea);
layer.msg('已复制到剪贴板');
} catch (err) {
layer.msg('复制失败');
}
}
});
}
});
},
error: function () {
layer.msg('获取系统配置信息失败');
}
});
break;
case 'activate':
layer.confirm('确定执行一键激活吗', function () {
$.ajax({
url: baseUrl + "/license/activate",
headers: { 'token': localStorage.getItem('token') },
method: 'POST',
success: function (res) {
if (res.code === 200) {
layer.msg('激活成功');
} else if (res.code === 403) {
top.location.href = baseUrl + "/";
} else {
layer.msg(res.msg)
}
},
error: function () {
layer.msg('激活失败');
}
});
});
break;
case 'projectName':
$.ajax({
url: baseUrl + "/license/getProjectName",
headers: { 'token': localStorage.getItem('token') },
method: 'GET',
success: function (res) {
if (res.code === 200) {
layer.alert(res.msg);
} else {
layer.msg(res.msg)
}
},
error: function () {
layer.msg('获取项目名称失败');
}
});
break;
}
});
// 监听行工具事件
table.on('tool(config)', function (obj) {
var data = obj.data;
switch (obj.event) {
// 详情
case 'detail':
layer.open({
type: 2,
title: '详情',
maxmin: true,
area: [top.detailWidth, top.detailHeight],
shadeClose: false,
content: 'config_detail.html',
success: function (layero, index) {
setFormVal(layer.getChildFrame('#detail', index), data, true);
top.convertDisabled(layer.getChildFrame('#data-detail :input', index), true);
layer.getChildFrame('#data-detail-submit,#prompt', index).hide();
layer.iframeAuto(index); layer.style(index, { top: (($(window).height() - layer.getChildFrame('#data-detail', index).height()) / 3) + "px" });
layero.find('iframe')[0].contentWindow.layui.form.render('select');
}
});
break;
// 编辑
case 'edit':
layer.open({
type: 2,
title: '修改',
maxmin: true,
area: [top.detailWidth, top.detailHeight],
shadeClose: false,
content: 'config_detail.html',
success: function (layero, index) {
setFormVal(layer.getChildFrame('#detail', index), data, false);
top.convertDisabled(layer.getChildFrame('#data-detail :input', index), false);
layer.iframeAuto(index); layer.style(index, { top: (($(window).height() - layer.getChildFrame('#data-detail', index).height()) / 3) + "px" });
layero.find('iframe')[0].contentWindow.layui.form.render('select');
}
});
break;
}
});
// 数据修改动作
form.on('submit(edit)', function () {
var index = layer.load(1, {
shade: [0.5, '#000'] //0.1透明度的背景
});
var data = {
id: $('#id').val(),
name: $('#name').val(),
code: $('#code').val(),
value: $('#value').val(),
selectType: $('#selectType').val(),
type: $('#type').val(),
status: $('#status').val(),
};
$.ajax({
url: baseUrl + "/config/edit/auth",
headers: { 'token': localStorage.getItem('token') },
data: top.reObject(data),
method: 'POST',
success: function (res) {
if (res.code === 200) {
parent.layer.closeAll();
tableReload(true);
$("#data-detail :input").each(function () {
$(this).val("");
});
} else if (res.code === 403) {
top.location.href = baseUrl + "/";
} else {
layer.msg(res.msg)
}
layer.close(index);
}
})
});
// 搜索栏搜索事件
form.on('submit(search)', function (data) {
pageCurr = 1;
tableReload(false);
});
// 搜索栏重置事件
form.on('submit(reset)', function (data) {
pageCurr = 1;
clearFormVal($('#search-box'));
tableReload(false);
});
// 时间选择器
// 初始化筛选类型下拉框
$.ajax({
url: baseUrl + "/config/getSelectTypes",
headers: { 'token': localStorage.getItem('token') },
method: 'POST',
success: function (res) {
if (res.code === 200) {
var types = res.data;
var select = $("#selectTypeSearch");
for (var i = 0; i < types.length; i++) {
select.append("");
}
form.render('select');
}
}
});
});
// 关闭动作
$(document).on('click', '#data-detail-close', function () {
parent.layer.closeAll();
});
function tableReload(child) {
var searchData = {};
$.each($('#search-box [name]').serializeArray(), function () {
searchData[this.name] = this.value;
});
(child ? parent.tableIns : tableIns).reload({
where: searchData,
page: {
curr: pageCurr
},
done: function (res, curr, count) {
if (res.code === 403) {
top.location.href = baseUrl + "/";
}
pageCurr = curr;
if (res.data.length === 0 && count !== 0) {
tableIns.reload({
where: searchData,
page: {
curr: pageCurr - 1
}
});
pageCurr -= 1;
}
limit(child);
}
});
}
function setFormVal(el, data, showImg) {
for (var val in data) {
var find = el.find(":input[id='" + val + "']");
find.val(data[val]);
if (showImg) {
var next = find.next();
if (next.get(0)) {
if (next.get(0).localName === "img") {
find.hide();
next.attr("src", data[val]);
next.show();
}
}
}
}
}
function clearFormVal(el) {
$(':input', el)
.val('')
.removeAttr('checked')
.removeAttr('selected');
}
function detailScreen(index) {
var detail = layer.getChildFrame('#data-detail', index);
var height = detail.height() + 60;
if (height > ($(window).height() * 0.9)) {
height = ($(window).height() * 0.9);
}
layer.style(index, {
top: (($(window).height() - height) / 3) + "px",
height: height + 'px'
});
$(".layui-layer-shade").remove();
}
$('body').keydown(function () {
if (event.keyCode === 13) {
$("#search").click();
}
});