ruankao/app/admin/view/yunzer/configlist.php
2025-07-14 14:55:25 +08:00

307 lines
7.3 KiB
PHP

{include file="public/header" /}
<style>
.config-container {
padding: 20px;
background-color: #fff;
border-radius: 8px;
/* box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08); */
}
.config-header {
display: flex;
align-items: center;
margin-bottom: 30px;
padding-bottom: 15px;
border-bottom: 1px solid #eee;
}
.config-header span {
font-size: 18px;
color: #2c3e50;
font-weight: 500;
margin-right: 20px;
}
.config-header a {
text-decoration: none;
}
.config-header a span {
padding: 6px 15px;
background: #f8f9fa;
border-radius: 4px;
color: #606266;
font-size: 14px;
transition: all 0.3s;
}
.config-header a span:hover {
background: #e9ecef;
color: #409EFF;
}
.action-buttons {
display: flex;
gap: 8px;
margin-bottom: 20px;
}
.layui-btn {
border-radius: 4px;
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
transition: all 0.3s;
height: 32px;
line-height: 32px;
padding: 0 16px;
}
.layui-btn:hover {
transform: translateY(-1px);
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}
.layui-btn .layui-icon {
margin-right: 4px;
font-size: 14px;
}
.layui-table {
margin: 15px 0;
border-radius: 4px;
overflow: hidden;
}
.layui-table thead tr {
background-color: #fafafa;
}
.layui-table tbody tr:hover {
background-color: #f5f7fa;
}
.layui-table-cell {
height: 40px;
line-height: 40px;
}
.layui-badge {
padding: 4px 8px;
border-radius: 3px;
font-weight: 500;
height: auto;
}
.layui-badge.layui-bg-green {
background-color: #67C23A !important;
}
.layui-badge.layui-bg-gray {
background-color: #909399 !important;
}
.layui-layer {
border-radius: 8px;
overflow: hidden;
}
.layui-textarea {
width: 80% !important;
}
</style>
<div class="config-container">
<div class="config-header">
<span>站点管理</span>
<!-- <a href="{$config['admin_route']}Yunzer/configvalue">
<span>站点配置</span>
</a> -->
</div>
<div class="layui-card-body" style="padding: 0;">
<div class="action-buttons">
<button type="button" class="layui-btn layui-btn-normal" id="btn-add">
<i class="layui-icon layui-icon-add-1"></i>添加
</button>
<button type="button" class="layui-btn layui-btn-normal" id="btn-edit">
<i class="layui-icon layui-icon-edit"></i>修改
</button>
<button type="button" class="layui-btn layui-btn-danger" id="btn-del">
<i class="layui-icon layui-icon-delete"></i>删除
</button>
</div>
<table class="layui-table" id="lists" lay-filter="lists"></table>
</div>
</div>
<script type="text/javascript">
layui.use(['layer', 'table', 'element'], function () {
var table = layui.table;
var layer = layui.layer;
var element = layui.element;
var $ = layui.jquery;
// 初始化表格
function initTable() {
table.render({
elem: '#lists',
method: 'post',
url: "{$config['admin_route']}yunzer/configlist",
title: '配置列表',
page: true,
skin: 'line',
even: true,
size: 'lg',
cols: [[
{ type: 'radio', fixed: 'left', width: 50 },
{ field: 'config_id', width: 80, title: 'ID', sort: true, align: 'center' },
{ field: 'config_sort', width: 120, title: '排序', sort: true, align: 'center' },
{ field: 'config_name', width: 150, title: '关键词' },
{ field: 'config_info', width: 150, title: '作用' },
{ field: 'config_desc', minWidth: 300, title: '说明' },
{
field: 'config_status', width: 100, title: '状态', align: 'center', templet: function (res) {
if (res.config_status == 1) {
return '<span class="layui-badge layui-bg-green">开启</span>';
} else {
return '<span class="layui-badge layui-bg-gray">关闭</span>';
}
}
}
]],
limit: 15,
limits: [15, 30, 50, 100],
height: 'full-180'
});
}
// 加载表格数据
initTable();
// 行点击事件
table.on('row(lists)', function (obj) {
obj.tr.addClass('layui-table-click').siblings().removeClass('layui-table-click');
obj.tr.find("div.layui-unselect.layui-form-radio")[0].click();
});
// 添加按钮事件
$('#btn-add').on('click', function () {
layer.open({
title: '<i class="layui-icon layui-icon-add-1"></i> 添加配置',
type: 2,
content: '{$config["admin_route"]}yunzer/configadd',
maxmin: true,
area: ['700px', '550px'],
skin: 'layui-layer-molv',
btn: ['确定', '取消'],
yes: function (index, layero) {
var form = layero.find('iframe')[0].contentWindow;
var button = {
config_name: form.config_name.value,
config_info: form.config_info.value,
config_type: form.config_type.value,
config_desc: form.config_desc.value,
config_sort: form.config_sort.value,
config_status: form.config_status.value
};
var loadIndex = layer.load(1, {
shade: [0.1, '#fff']
});
$.post('{$config["admin_route"]}yunzer/configadd', button, function (res) {
layer.close(loadIndex);
if (res.code > 0) {
layer.msg(res.msg, { icon: 2, time: 2000 });
} else {
layer.msg(res.msg, { icon: 1, time: 1000 });
initTable();
layer.close(index);
}
}, 'json');
}
});
});
// 编辑按钮事件
$('#btn-edit').on('click', function () {
var checkStatus = table.checkStatus('lists');
var data = checkStatus.data;
if (data.length === 0) {
layer.msg('请选择一条数据进行编辑', { icon: 0 });
return;
}
layer.open({
title: '<i class="layui-icon layui-icon-edit"></i> 修改配置',
type: 2,
content: '{$config["admin_route"]}yunzer/configedit?config_id=' + data[0].config_id,
maxmin: true,
area: ['700px', '550px'],
skin: 'layui-layer-molv',
btn: ['确定', '取消'],
yes: function (index, layero) {
var form = layero.find('iframe')[0].contentWindow;
var button = {
config_id: data[0].config_id,
config_name: form.config_name.value,
config_info: form.config_info.value,
config_type: form.config_type.value,
config_desc: form.config_desc.value,
config_sort: form.config_sort.value,
config_status: form.config_status.value
};
var loadIndex = layer.load(1, {
shade: [0.1, '#fff']
});
$.post('{$config["admin_route"]}yunzer/configedit', button, function (res) {
layer.close(loadIndex);
if (res.code > 0) {
layer.msg(res.msg, { icon: 2, time: 2000 });
} else {
layer.msg(res.msg, { icon: 1, time: 1000 });
initTable();
layer.close(index);
}
}, 'json');
}
});
});
// 删除按钮事件
$('#btn-del').on('click', function () {
var checkStatus = table.checkStatus('lists');
var data = checkStatus.data;
if (data.length === 0) {
layer.msg('请选择一条数据进行删除', { icon: 0 });
return;
}
layer.confirm('确定要删除该配置吗?', {
icon: 3,
title: '删除确认',
skin: 'layui-layer-molv',
btn: ['确定', '取消']
}, function () {
var loadIndex = layer.load(1, {
shade: [0.1, '#fff']
});
$.post('{$config["admin_route"]}yunzer/configdel', { 'config_id': data[0].config_id }, function (res) {
layer.close(loadIndex);
if (res.code > 0) {
layer.msg(res.msg, { icon: 2, time: 2000 });
} else {
layer.msg(res.msg, { icon: 1, time: 1000 });
initTable();
}
}, 'json');
});
});
});
</script>
{include file="public/tail" /}