TaoLer/public/static/admin/modules/addons.js

224 lines
6.7 KiB
JavaScript
Raw Normal View History

2020-10-19 17:23:55 +08:00
//网站app版本发布
2022-11-25 22:44:04 +08:00
layui.define(["table", "form", "upload","notify","hxNav"], function (exports) {
2021-12-15 15:46:04 +08:00
var $ = layui.jquery,
table = layui.table,
form = layui.form,
upload = layui.upload;
2022-11-25 22:44:04 +08:00
var notify = layui.notify;
2020-10-19 17:23:55 +08:00
2021-12-15 15:46:04 +08:00
function addList(type) {
$.ajax({
type: "post",
url: addonsList,
data: { type: type },
dataType: "json",
success: function (res) {
//渲染表格
table.render({
elem: "#addons-list",
toolbar: "#toolbar",
defaultToolbar: [],
url: addonsList + "?type=" + type,
cols: [res["col"]],
page: true,
limit: 10,
height: "full-220",
text: "对不起,加载出现异常!",
});
},
});
}
2021-12-15 15:46:04 +08:00
addList("onlineAddons");
2021-10-12 16:46:49 +08:00
2021-12-15 15:46:04 +08:00
//头工具栏事件
table.on("toolbar(addons-list)", function (obj) {
var checkStatus = table.checkStatus(obj.config.id);
switch (obj.event) {
case "installed":
addList("installed");
break;
case "onlineAddons":
addList("onlineAddons");
break;
}
});
//监听工具条
table.on("tool(addons-list)", function (obj) {
2020-10-19 17:23:55 +08:00
var data = obj.data;
2022-11-25 22:44:04 +08:00
var event = obj.event;
var url = $(this).data('url')
2022-11-25 22:44:04 +08:00
//安装插件
if (event === "install") {
var index = layer.load(1);
$.post(url, { name: data.name, version: data.version }, function (res) {
if (res.code == 0) {
notify.success(res.msg, "topRight");
} else {
notify.error(res.msg, "topRight");
2021-12-15 15:46:04 +08:00
}
2022-11-25 22:44:04 +08:00
layer.close(index);
2021-12-15 15:46:04 +08:00
});
2022-11-25 22:44:04 +08:00
}
// 启用禁用
if(event == 'status') {
notify.confirm("确认框", "vcenter", function(){
$.post(url,{ name: data.name },function(res){
2021-12-15 15:46:04 +08:00
if (res.code == 0) {
2022-11-25 22:44:04 +08:00
notify.success(res.msg, "topRight");
2021-12-15 15:46:04 +08:00
} else {
2022-11-25 22:44:04 +08:00
notify.error(res.msg, "topRight");
2021-12-15 15:46:04 +08:00
}
2022-11-25 22:44:04 +08:00
table.reloadData("addons-list",{},'deep');
// addList("installed");
});
});
2022-11-25 22:44:04 +08:00
}
// 卸载插件
if (event === "uninstall") {
notify.confirm("确认框", "vcenter",function() {
var index = layer.load(1);
$.post(url, { name: data.name }, function (res) {
2021-12-15 15:46:04 +08:00
if (res.code == 0) {
2022-11-25 22:44:04 +08:00
notify.success(res.msg, "topRight");
2021-12-15 15:46:04 +08:00
} else {
2022-11-25 22:44:04 +08:00
notify.error(res.msg, "topRight");
2021-12-15 15:46:04 +08:00
}
2022-11-25 22:44:04 +08:00
});
table.reload("addons-list");
layer.close(index);
2021-12-15 15:46:04 +08:00
});
2022-11-25 22:44:04 +08:00
}
2022-09-23 11:03:10 +08:00
2022-11-25 22:44:04 +08:00
// 配置插件
if (event === "config") {
2021-12-15 15:46:04 +08:00
layer.open({
type: 2,
2022-11-25 22:44:04 +08:00
title: '配置插件',
content: url + "?name=" + data.name,
2021-12-15 15:46:04 +08:00
maxmin: true,
area: ["780px", "90%"],
btn: ["确定", "取消"],
yes: function (index, layero) {
var iframeWindow = window["layui-layer-iframe" + index],
2022-11-25 22:44:04 +08:00
submitID = "LAY-addons-config-submit",
submit = layero.find("iframe").contents().find("#" + submitID);
2021-12-15 15:46:04 +08:00
//监听提交
iframeWindow.layui.form.on(
2022-11-25 22:44:04 +08:00
"submit(" + submitID + ")",
function (data) {
var field = data.field; //获取提交的字段
$.ajax({
type: "post",
url: addonsConfig,
data: field,
daType: "json",
success: function (res) {
if (res.code == 0) {
notify.success(res.msg, "topRight");
} else {
notify.error(res.msg, "topRight");
}
},
});
layer.close(index); //关闭弹层
}
);
submit.trigger("click");
},
success: function (layero, index) {
var forms = layero.find("iframe").contents().find(".layui-form");
var button = forms.find("button");
//事件委托
forms.on("click", "button", function (data) {
var even = this.getAttribute("lay-event");
var names = this.dataset.name;
if (even == "addInput") {
var html = '<div class="layui-form-item">\n' +
'<label class="layui-form-label"></label>\n' +
'<div class="layui-input-inline">\n' +
' <input type="text" name="'+ names +'[key][]" value="" placeholder="key" autocomplete="off" class="layui-input input-double-width">\n' +
'</div>\n' +
'<div class="layui-input-inline">\n' +
' <input type="text" name="'+ names +'[value][]" value="" placeholder="value" autocomplete="off" class="layui-input input-double-width">\n' +
'</div>\n' +
'<button data-name="'+ names +'" type="button" class="layui-btn layui-btn-danger layui-btn-sm removeInupt" lay-event="removeInupt">\n' +
' <i class="layui-icon"></i>\n' +
'</button>\n' +
'</div>';
$(this).parent().parent().append(html);
} else {
$(this).parent().remove();
}
});
},
});
}
if (event === "edit") {
var tr = $(obj.tr);
layer.open({
type: 2,
title: "编辑插件",
content: addonsEdit + "?id=" + data.id,
maxmin: true,
area: ["400px", "620px"],
btn: ["确定", "取消"],
yes: function (index, layero) {
var iframeWindow = window["layui-layer-iframe" + index],
submitID = "LAY-addons-submit",
submit = layero
.find("iframe")
.contents()
.find("#" + submitID);
//监听提交
iframeWindow.layui.form.on(
2021-12-15 15:46:04 +08:00
"submit(" + submitID + ")",
function (data) {
var field = data.field; //获取提交的字段
2022-11-25 22:44:04 +08:00
//提交 Ajax 成功后,静态更新表格中的数据
2021-12-15 15:46:04 +08:00
$.ajax({
type: "post",
2022-11-25 22:44:04 +08:00
url: addonsEdit,
2021-12-15 15:46:04 +08:00
data: field,
daType: "json",
success: function (res) {
if (res.code == 0) {
layer.msg(res.msg, { icon: 6, time: 2000 });
} else {
layer.open({
tiele: "修改失败",
content: res.msg,
icon: 5,
anim: 6,
});
}
},
});
2022-11-25 22:44:04 +08:00
table.reload("addons-list"); //数据刷新
2021-12-15 15:46:04 +08:00
layer.close(index); //关闭弹层
}
2022-11-25 22:44:04 +08:00
);
submit.trigger("click");
},
success: function (layero, index) {},
});
}
2020-10-19 17:23:55 +08:00
});
2021-12-15 15:46:04 +08:00
exports("addons", {});
});