TaoLer/app/admin/view/addon/addons/index.html

203 lines
6.7 KiB
HTML
Raw Normal View History

2023-03-16 22:40:15 +08:00
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
2023-03-16 22:42:05 +08:00
<title>插件管理</title>
2023-03-16 22:40:15 +08:00
<link rel="stylesheet" href="/static/component/pear/css/pear.css" />
</head>
2023-03-16 22:42:05 +08:00
<body class="pear-container">
2023-03-16 22:40:15 +08:00
<div class="layui-card">
<div class="layui-card-body">
<table id="addons-list" lay-filter="addons-list"></table>
</div>
</div>
2023-03-16 22:42:05 +08:00
<script type="text/html" id="toolbar">
<div class="layui-btn-group">
<button class="layui-btn layui-btn-sm" lay-event="allAddons">全部</button>
<button class="layui-btn layui-btn-sm" lay-event="freeAddons">免费</button>
<button class="layui-btn layui-btn-sm" lay-event="payAddons">付费</button>
<button class="layui-btn layui-btn-normal layui-btn-sm" lay-event="installed">已安装</button>
<button class="layui-btn layui-btn-danger layui-btn-sm" lay-event="add">离线安装</button>
</div>
</script>
<script type="text/html" id="addons-bar">
{{# if(d.have_newversion === 1){ }}
2023-05-05 12:06:07 +08:00
<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="install" data-url="{:url('addon.addons/upgrade')}" data-userlogin="{:url('addon.addons/userLogin')}" data-ispay="{:url('addon.addons/isPay')}"><i class="layui-icon layui-icon-upload-circle"></i>升级</a>
2023-03-16 22:42:05 +08:00
{{# } else { }}
{{# if(d.isInstall === 1) { }}
<a class="layui-btn layui-btn-normal layui-btn-xs" lay-event="config" data-url="{:url('addon.addons/config')}"><i class="layui-icon layui-icon-set"></i>设置</a>
{{# } else { }}
<a class="layui-btn layui-btn-xs" lay-event="install" data-url="{:url('addon.addons/install')}" data-userlogin="{:url('addon.addons/userLogin')}" data-ispay="{:url('addon.addons/isPay')}"><i class="layui-icon layui-icon-edit"></i>安装</a>
<select id="vers{{d.name}}" name="sss" class="layui-border" lay-ignore lay-filter="versSelect">
{{# d.vers.forEach(function(item, index){ }}
<option value="{{ item }}">{{ item }}</option>
{{# }); }}
</select>
{{# } }}
{{# } }}
</script>
<script type="text/html" id="buttonStatus">
<input type="checkbox" name="{{d.name}}" lay-skin="switch" lay-filter="addonsStatus" lay-text="启动|禁用" {{# if(d.status == 1){ }} checked {{# } }} data-url="{:url('addon.addons/check')}">
</script>
<script type="text/html" id="addons-installed-tool">
<a class="layui-btn layui-btn-normal layui-btn-xs" lay-event="config" data-url="{:url('addon.addons/config')}"><i class="layui-icon layui-icon-set"></i>设置</a>
<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="uninstall" data-url="{:url('addon.addons/uninstall')}"><i class="layui-icon layui-icon-delete"></i>卸载</a>
</script>
{include file="public/user_login" /}
<script src="/static/component/layui/layui.js"></script>
<script src="/static/component/pear/pear.js"></script>
<script>
var addonList = "{:url('addon.addons/getList')}";
layui.use(['addons','table','form','upload','toast'], function(){
var $ = layui.jquery
,table = layui.table
,form = layui.form
,upload = layui.upload;
var toast = layui.toast;
let LIST_URL = "{:url('addon.addons/list')}";
let cols = [[
{type: 'checkbox'},
{title: '序号', type: 'numbers'},
{field: 'title', title: '插件', width: 200},
{field: 'description', title: '简介', minWidth: 200},
{field: 'author', title: '作者', width: 100},
{field: 'price', title: '价格(元)', width: 85},
{field: 'downloads', title: '下载', width: 70},
{field: 'version', title: '版本', templet: '<div>{{d.version}} {{# if(d.have_newversion == 1){ }}<span class="layui-badge-dot"></span>{{# } }}</div>', width: 75},
{field: 'status', title: '在线', width: 70},
{title: '操作', width: 165, align: 'center', toolbar: '#addons-bar'}
]];
let col = [[
{type: 'numbers'},
{field: 'name', title: '插件', width: 120},
{field: 'title',title: '标题', width: 100},
{field: 'version', title: '版本'},
{field: 'author', title: '作者', width: 80},
{field: 'description', title: '简介', minWidth: 200},
{field: 'install', title: '安装', width: 100},
{field: 'ctime', title: '到期时间', width: 100},
{field: 'status', title: '状态', width: 95, templet: '#buttonStatus'},
{title: '操作', width: 160, 'align': 'center', toolbar: '#addons-installed-tool'}
]];
//渲染表格
var addonTable = table.render({
elem: "#addons-list",
toolbar: "#toolbar",
defaultToolbar: [],
url: LIST_URL,
cols: cols,
page: true,
2023-05-05 12:06:07 +08:00
limit: 15,
2023-03-16 22:42:05 +08:00
text: "对不起,加载出现异常!",
2023-03-16 22:40:15 +08:00
});
2023-03-16 22:42:05 +08:00
// table.on('tool(addons-list)',function(obj){
// console.log(obj)
// if (obj.event === 'remove') {
// window.remove(obj);
// } else if (obj.event === 'edit') {
// window.edit(obj);
// }
// })
table.on('toolbar(addons-list)', function(obj){
if(obj.event === 'installed'){
window.installed(obj.event);
} else if(obj.event === 'add'){
//window.add();
} else {
// all,free,pay
window.all(obj.event);
}
});
window.all = function (type) {
$.post(LIST_URL,{type: type}, function (res){
if(res.code === 0) {
// 重新渲染
table.reload('addons-list',{
url: LIST_URL,
where: {
type : type
},
cols: cols,
page: {
curr: 1 //重新从第 1 页开始
}
});
}
})
}
window.installed = function (type) {
$.get(LIST_URL,{type: type}, function (res){
if(res.code === 0) {
// 重新渲染
table.reload('addons-list',{
url: LIST_URL,
where: {
type : type
},
cols: col,
page: {
curr: 1 //重新从第 1 页开始
}
});
}
})
}
2023-03-16 22:40:15 +08:00
2023-03-16 22:42:05 +08:00
window.add = function(){
layer.open({
type: 2
,title: '添加插件'
,content: 'add.html'
,area: ['400px', '300px']
});
}
form.render('select'); // 渲染所在容器内的 select 元素
//监听版本选择
form.on('select(versSelect)', function(obj){
layer.tips(this.value + ' ' + this.name + ''+ obj.elem.checked, obj.othis);
});
// 启动禁用
form.on('switch(addonsStatus)', function(data){
var data = data.elem;
var url = $(this).data('url');
//执行帖子审核
$.post(url,{ name: data.name },function(res){
if(res.code === 0){
toast.success({title:"成功消息",message:res.msg,position: 'topRight'});
} else {
toast.error({title:"失败消息",message:res.msg,position: 'topRight'});
}
table.reloadData("addons-list",{},'deep');
});
return false;
});
});
</script>
</body>
2023-03-16 22:40:15 +08:00
</html>