343 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			343 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php /*a:2:{s:66:"E:\Demos\DemoOwns\PHP\yunzer\app\admin\view\yunzeradmin\banner.php";i:1747385326;s:61:"E:\Demos\DemoOwns\PHP\yunzer\app\admin\view\public\header.php";i:1746849526;}*/ ?>
 | ||
| <!DOCTYPE html>
 | ||
| <html>
 | ||
| 	<head>
 | ||
| 		<title><?php echo htmlentities((string) $config['admin_name']); ?></title>
 | ||
| 		<meta name="renderer" content="webkit">
 | ||
| 		<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
 | ||
| 		<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
 | ||
| 		<link rel="stylesheet" type="text/css" href="/static/layui/css/layui.css" media="all"/>
 | ||
| 		<link rel="stylesheet" type="text/css" href="/static/css/moban.css" media="all"/>
 | ||
| 		<link rel="stylesheet" type="text/css" href="/static/css/wangeditor.css" media="all"/>
 | ||
| 		<style type="text/css">
 | ||
| 			.header span{background:#009688;margin-left:30px;padding:10px;color:#ffffff;}
 | ||
| 			.header div{border-bottom:solid 2px #009688;margin-top: 8px;}
 | ||
| 			.header button{float:right;margin-top:-5px;}
 | ||
| 			.pagination {
 | ||
| 				display: inline-block;
 | ||
| 				padding-left: 0;
 | ||
| 				margin: 20px 0;
 | ||
| 				border-radius: 4px;
 | ||
| 			}
 | ||
| 			.pagination > li {
 | ||
| 				display: inline;
 | ||
| 			}
 | ||
| 			.pagination > li > a,
 | ||
| 			.pagination > li > span {
 | ||
| 				position: relative;
 | ||
| 				float: left;
 | ||
| 				padding: 6px 12px;
 | ||
| 				margin-left: -1px;
 | ||
| 				line-height: 1.42857143;
 | ||
| 				color: #337ab7;
 | ||
| 				text-decoration: none;
 | ||
| 				background-color: #fff;
 | ||
| 				border: 1px solid #ddd;
 | ||
| 			}
 | ||
| 			.pagination > li:first-child > a,
 | ||
| 			.pagination > li:first-child > span {
 | ||
| 				margin-left: 0;
 | ||
| 				border-top-left-radius: 4px;
 | ||
| 				border-bottom-left-radius: 4px;
 | ||
| 			}
 | ||
| 			.pagination > li:last-child > a,
 | ||
| 			.pagination > li:last-child > span {
 | ||
| 				border-top-right-radius: 4px;
 | ||
| 				border-bottom-right-radius: 4px;
 | ||
| 			}
 | ||
| 			.pagination > li > a:hover,
 | ||
| 			.pagination > li > span:hover,
 | ||
| 			.pagination > li > a:focus,
 | ||
| 			.pagination > li > span:focus {
 | ||
| 				z-index: 2;
 | ||
| 				color: #23527c;
 | ||
| 				background-color: #eee;
 | ||
| 				border-color: #ddd;
 | ||
| 			}
 | ||
| 			.pagination > .active > a,
 | ||
| 			.pagination > .active > span,
 | ||
| 			.pagination > .active > a:hover,
 | ||
| 			.pagination > .active > span:hover,
 | ||
| 			.pagination > .active > a:focus,
 | ||
| 			.pagination > .active > span:focus {
 | ||
| 				z-index: 3;
 | ||
| 				color: #fff;
 | ||
| 				cursor: default;
 | ||
| 				background-color: #337ab7;
 | ||
| 				border-color: #337ab7;
 | ||
| 			}
 | ||
| 			.pagination > .disabled > span,
 | ||
| 			.pagination > .disabled > span:hover,
 | ||
| 			.pagination > .disabled > span:focus,
 | ||
| 			.pagination > .disabled > a,
 | ||
| 			.pagination > .disabled > a:hover,
 | ||
| 			.pagination > .disabled > a:focus {
 | ||
| 				color: #777;
 | ||
| 				cursor: not-allowed;
 | ||
| 				background-color: #fff;
 | ||
| 				border-color: #ddd;
 | ||
| 			}
 | ||
| 			.close-img { background: url(/static/images/close_img.png); background-size: 20px 20px; width:20px; height: 20px; position: absolute; right: 5px; top: 5px; z-index: 2;}
 | ||
| 		</style>
 | ||
| 		<script type="text/javascript" src="/static/layui/layui.js"></script>
 | ||
| 		<script type="text/javascript">
 | ||
| 			layui.use(['layer','form','table','laydate','element','upload'],function(){
 | ||
| 				layer = layui.layer;		// layui 弹框
 | ||
| 				form = layui.form;			// layui form表单
 | ||
| 				table = layui.table;		// layui 表格
 | ||
| 				laydate = layui.laydate;	// layui 时间框
 | ||
| 				element = layui.element;	// layui element
 | ||
| 				upload = layui.upload;		// layui 上传
 | ||
| 				$ = layui.jquery;			// layui jquery
 | ||
| 			})
 | ||
| 		</script>
 | ||
| 	</head>
 | ||
| 	<body style="padding:10px; box-sizing: border-box;">
 | ||
| <!-- 主体内容 -->
 | ||
| <div class="config-container">
 | ||
|     <!-- 页面头部样式 -->
 | ||
|     <div class="config-header" style="display: flex;flex-direction: column;flex-wrap: wrap;align-items: flex-start;">
 | ||
|         <div class="maintitle">
 | ||
|             <i class="layui-icon layui-icon-picture"></i>
 | ||
|             <span>Banner管理</span>
 | ||
|         </div>
 | ||
|         <div style="display: flex;align-items: flex-start;flex-direction: column;gap: 15px;margin-bottom: 10px;">
 | ||
|             <div>
 | ||
|                 <button class="layui-btn layui-bg-blue" id="addBanner">
 | ||
|                     <i class="layui-icon layui-icon-add-1"></i>添加Banner
 | ||
|                 </button>
 | ||
|                 <button type="button" class="layui-btn layui-btn-primary layui-border-blue" onclick="refresh()">
 | ||
|                     <i class="layui-icon layui-icon-refresh"></i>刷新
 | ||
|                 </button>
 | ||
|             </div>
 | ||
|         </div>
 | ||
|     </div>
 | ||
| 
 | ||
|     <div class="layui-fluid">
 | ||
|         <div class="layui-card">
 | ||
|             <div class="layui-card-body">
 | ||
|                 <table id="bannerTable" lay-filter="bannerTable"></table>
 | ||
|             </div>
 | ||
|         </div>
 | ||
|     </div>
 | ||
| 
 | ||
|     <!-- Banner表单 -->
 | ||
|     <div id="bannerForm" style="display: none;">
 | ||
|         <form class="layui-form banner-form">
 | ||
|             <input type="hidden" name="id">
 | ||
|             <div class="layui-form-item">
 | ||
|                 <label class="layui-form-label">标题</label>
 | ||
|                 <div class="layui-input-block">
 | ||
|                     <input type="text" name="title" required lay-verify="required" placeholder="请输入标题"
 | ||
|                         class="layui-input">
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|             <div class="layui-form-item">
 | ||
|                 <label class="layui-form-label">图片</label>
 | ||
|                 <div class="layui-input-block">
 | ||
|                     <div class="layui-upload-drag" id="uploadImage">
 | ||
|                         <i class="layui-icon layui-icon-upload"></i>
 | ||
|                         <p>点击上传或拖拽图片至此处</p>
 | ||
|                         <div id="uploadPreview" style="display: none;">
 | ||
|                             <img src="" alt="Banner图片" class="banner-upload-preview">
 | ||
|                         </div>
 | ||
|                     </div>
 | ||
|                     <input type="hidden" name="image" id="imageInput">
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|             <div class="layui-form-item">
 | ||
|                 <label class="layui-form-label">链接</label>
 | ||
|                 <div class="layui-input-block">
 | ||
|                     <input type="text" name="url" placeholder="请输入链接地址" class="layui-input">
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|             <div class="layui-form-item">
 | ||
|                 <label class="layui-form-label">排序</label>
 | ||
|                 <div class="layui-input-block">
 | ||
|                     <input type="number" name="sort" value="0" class="layui-input" placeholder="数字越大越靠前">
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|             <div class="layui-form-item">
 | ||
|                 <label class="layui-form-label">状态</label>
 | ||
|                 <div class="layui-input-block">
 | ||
|                     <input type="radio" name="status" value="1" title="启用" checked>
 | ||
|                     <input type="radio" name="status" value="0" title="禁用">
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|             <div class="layui-form-item">
 | ||
|                 <div class="layui-input-block">
 | ||
|                     <button class="layui-btn" lay-submit lay-filter="saveBanner">保存</button>
 | ||
|                     <button type="reset" class="layui-btn layui-btn-primary">重置</button>
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|         </form>
 | ||
|     </div>
 | ||
| 
 | ||
| </div>
 | ||
| 
 | ||
| <script>
 | ||
|     layui.use(['table', 'form', 'upload', 'layer'], function () {
 | ||
|         var table = layui.table,
 | ||
|             form = layui.form,
 | ||
|             upload = layui.upload,
 | ||
|             layer = layui.layer;
 | ||
| 
 | ||
|         // 表格列配置
 | ||
|         var tableColumns = [[
 | ||
|             { field: 'id', title: 'ID', width: 80, align: 'center' },
 | ||
|             { field: 'title', title: '标题', align: 'center' },
 | ||
|             {
 | ||
|                 field: 'image', title: '图片', width: 180, align: 'center', templet: function (d) {
 | ||
|                     return '<img src="' + d.image + '" class="banner-preview-img" onclick="previewImage(\'' + d.image + '\')">';
 | ||
|                 }
 | ||
|             },
 | ||
|             { field: 'url', title: '链接', align: 'center', width: 300 },
 | ||
|             { field: 'sort', title: '排序', align: 'center', width: 100, sort: true },
 | ||
|             { field: 'create_time', title: '创建时间', align: 'center', width: 180, sort: true },
 | ||
|             {
 | ||
|                 title: '操作', align: 'center', width: 240, templet: function (d) {
 | ||
|                     return '<a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>' +
 | ||
|                         '<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>';
 | ||
|                 }
 | ||
|             }
 | ||
|         ]];
 | ||
| 
 | ||
|         // 初始化表格
 | ||
|         table.render({
 | ||
|             elem: '#bannerTable',
 | ||
|             url: '/admin/yunzeradmin/bannerlist',
 | ||
|             method: 'get',
 | ||
|             page: true,
 | ||
|             cols: tableColumns,
 | ||
|             limit: 10,
 | ||
|             limits: [10, 20, 30, 50],
 | ||
|             text: { none: '暂无相关数据' }
 | ||
|         });
 | ||
| 
 | ||
|         // 上传组件配置
 | ||
|         var uploadConfig = {
 | ||
|             elem: '#uploadImage',
 | ||
|             url: '/admin/upload/image',
 | ||
|             accept: 'images',
 | ||
|             acceptMime: 'image/*',
 | ||
|             done: function (res) {
 | ||
|                 if (res.code === 0) {
 | ||
|                     $('#uploadPreview').show().find('img').attr('src', res.data.url);
 | ||
|                     $('#imageInput').val(res.data.url);
 | ||
|                     layer.msg('上传成功');
 | ||
|                 } else {
 | ||
|                     layer.msg('上传失败');
 | ||
|                 }
 | ||
|             }
 | ||
|         };
 | ||
| 
 | ||
|         // 初始化上传组件
 | ||
|         upload.render(uploadConfig);
 | ||
| 
 | ||
|         // 监听表格工具条事件
 | ||
|         table.on('tool(bannerTable)', function (obj) {
 | ||
|             var data = obj.data;
 | ||
|             if (obj.event === 'edit') {
 | ||
|                 showBannerForm(data);
 | ||
|             } else if (obj.event === 'del') {
 | ||
|                 layer.confirm('确定删除此Banner?', function (index) {
 | ||
|                     deleteBanner(data.id, obj);
 | ||
|                     layer.close(index);
 | ||
|                 });
 | ||
|             }
 | ||
|         });
 | ||
| 
 | ||
|         // 添加Banner按钮点击事件
 | ||
|         $('#addBanner').on('click', function () {
 | ||
|             showBannerForm();
 | ||
|         });
 | ||
| 
 | ||
|         // 监听表单提交
 | ||
|         form.on('submit(saveBanner)', function (data) {
 | ||
|             var url = data.field.id ? '/admin/yunzeradmin/banneredit' : '/admin/yunzeradmin/banneradd';
 | ||
|             $.post(url, data.field, function (res) {
 | ||
|                 if (res.code === 0) {
 | ||
|                     layer.closeAll('page');
 | ||
|                     table.reload('bannerTable');
 | ||
|                     layer.msg('保存成功');
 | ||
|                 } else {
 | ||
|                     layer.msg(res.msg);
 | ||
|                 }
 | ||
|             });
 | ||
|             return false;
 | ||
|         });
 | ||
| 
 | ||
|         // 显示Banner表单
 | ||
|         function showBannerForm(data) {
 | ||
|             layer.open({
 | ||
|                 type: 1,
 | ||
|                 title: data ? '编辑Banner' : '添加Banner',
 | ||
|                 content: $('#bannerForm'),
 | ||
|                 area: ['800px', '600px'],
 | ||
|                 success: function (layero) {
 | ||
|                     form.render();
 | ||
|                     if (data) {
 | ||
|                         form.val('bannerForm', data);
 | ||
|                         if (data.image) {
 | ||
|                             $('#uploadPreview').show().find('img').attr('src', data.image);
 | ||
|                             $('#imageInput').val(data.image);
 | ||
|                         }
 | ||
|                     }
 | ||
|                 }
 | ||
|             });
 | ||
|         }
 | ||
| 
 | ||
|         // 删除Banner
 | ||
|         function deleteBanner(id, obj) {
 | ||
|             $.post('/admin/yunzeradmin/bannerdel', { id: id }, function (res) {
 | ||
|                 if (res.code === 0) {
 | ||
|                     obj.del();
 | ||
|                     layer.msg('删除成功');
 | ||
|                 } else {
 | ||
|                     layer.msg(res.msg);
 | ||
|                 }
 | ||
|             });
 | ||
|         }
 | ||
|     });
 | ||
| 
 | ||
|     // 预览图片
 | ||
|     function previewImage(url) {
 | ||
|         layer.photos({
 | ||
|             photos: {
 | ||
|                 "data": [{
 | ||
|                     "src": url
 | ||
|                 }]
 | ||
|             }
 | ||
|         });
 | ||
|     }
 | ||
| </script>
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| <!-- 页面样式 -->
 | ||
| <style>
 | ||
|     .layui-table-cell {
 | ||
|         height: 40px;
 | ||
|         line-height: 40px;
 | ||
|     }
 | ||
| 
 | ||
|     .layui-table-cell img {
 | ||
|         height: 36px;
 | ||
|         width: auto;
 | ||
|         max-width: 80px;
 | ||
|     }
 | ||
| 
 | ||
|     .banner-preview-img {
 | ||
|         max-width: 80px;
 | ||
|         cursor: pointer;
 | ||
|     }
 | ||
| 
 | ||
|     .banner-form {
 | ||
|         padding: 20px;
 | ||
|     }
 | ||
| 
 | ||
|     .banner-upload-preview {
 | ||
|         max-width: 100%;
 | ||
|         margin-top: 10px;
 | ||
|     }
 | ||
| </style>
 |