| <div class="layui-fluid layui-anim febs-anim" id="febs-activity" lay-title="活动列表"> | 
|     <div class="layui-row febs-container"> | 
|         <div class="layui-col-md12"> | 
|             <div class="layui-card"> | 
|                 <div class="layui-card-body febs-table-full"> | 
|                     <form class="layui-form layui-table-form" lay-filter="activity-table-form"> | 
|                         <div class="layui-row"> | 
|                             <div class="layui-col-md10"> | 
|                                 <div class="layui-form-item"> | 
|                                     <div class="layui-inline"> | 
|                                         <label class="layui-form-label layui-form-label-sm">活动名称</label> | 
|                                         <div class="layui-input-inline"> | 
|                                             <input type="text" placeholder="活动名称" name="name" autocomplete="off" class="layui-input"> | 
|                                         </div> | 
|                                     </div> | 
|                                     <div class="layui-inline"> | 
|                                         <label class="layui-form-label layui-form-label-sm">分类</label> | 
|                                         <div class="layui-input-inline"> | 
|                                             <select name="categoryId" class="group-type"> | 
|                                                 <option value="">请选择</option> | 
|                                             </select> | 
|                                         </div> | 
|                                     </div> | 
|                                     <div class="layui-inline"> | 
|                                         <label class="layui-form-label layui-form-label-sm">状态</label> | 
|                                         <div class="layui-input-inline"> | 
|                                             <select name="state"> | 
|                                                 <option value="">请选择</option> | 
|                                                 <option value="0">未开启</option> | 
|                                                 <option value="1">已开启</option> | 
|                                                 <option value="2">已结束</option> | 
|                                             </select> | 
|                                         </div> | 
|                                     </div> | 
|                                 </div> | 
|                             </div> | 
|                             <div class="layui-col-md2 layui-col-sm12 layui-col-xs12 table-action-area"> | 
|                                 <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain table-action" id="query"> | 
|                                     <i class="layui-icon"></i> | 
|                                 </div> | 
|                                 <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="reset"> | 
|                                     <i class="layui-icon"></i> | 
|                                 </div> | 
|                             </div> | 
|                         </div> | 
|                     </form> | 
|                     <table lay-filter="activityTable" lay-data="{id: 'activityTable'}"></table> | 
|                 </div> | 
|             </div> | 
|         </div> | 
|     </div> | 
| </div> | 
| <!-- 表格操作栏 start --> | 
| <script type="text/html" id="user-option"> | 
|     <span shiro:lacksPermission="list:view,add:add,votesActivityUpdate:update"> | 
|         <span class="layui-badge-dot febs-bg-orange"></span> 无权限 | 
|     </span> | 
|     <a lay-event="edit" shiro:hasPermission="votesActivityUpdate:update"><i | 
|             class="layui-icon febs-edit-area febs-blue"></i></a> | 
| </script> | 
| <script type="text/html" id="activityStateSwitch"> | 
|     {{# if(d.state === 1) { }} | 
|     <input type="checkbox" value={{d.id}} lay-text="开启|关闭" checked lay-skin="switch" lay-filter="activityStateSwitch"> | 
|     {{# } else { }} | 
|     <input type="checkbox" value={{d.id}} lay-text="开启|关闭" lay-skin="switch" lay-filter="activityStateSwitch"> | 
|     {{# } }} | 
| </script> | 
|   | 
| <script type="text/html" id="activityToolbar"> | 
|     <div class="layui-btn-container"> | 
|         <button class="layui-btn layui-btn-normal layui-btn-sm" type="button" shiro:hasPermission="add:add" lay-event="activityAdd">新增活动</button> | 
|     </div> | 
| </script> | 
|   | 
| <script type="text/html" id="activityOption"> | 
|     <button class="layui-btn layui-btn-normal layui-btn-sm" type="button" shiro:hasPermission="votesActivityUpdate:update" lay-event="activityUpdateEvent">编辑</button> | 
|     <button class="layui-btn layui-btn-danger layui-btn-sm" type="button" shiro:hasPermission="votesActivityUpdate:update" lay-event="activityDeleteEvent">删除</button> | 
| </script> | 
|   | 
| <style> | 
|     .layui-form-onswitch { | 
|         background-color: #5FB878 !important; | 
|     } | 
| </style> | 
| <!-- 表格操作栏 end --> | 
| <script data-th-inline="none" type="text/javascript"> | 
|     // 引入组件并初始化 | 
|     layui.use([ 'jquery', 'form', 'table', 'febs'], function () { | 
|         var $ = layui.jquery, | 
|             febs = layui.febs, | 
|             form = layui.form, | 
|             table = layui.table, | 
|             $view = $('#febs-activity'), | 
|             $query = $view.find('#query'), | 
|             $reset = $view.find('#reset'), | 
|             $searchForm = $view.find('form'), | 
|             sortObject = {field: 'phone', type: null}, | 
|             tableIns; | 
|   | 
|         form.render(); | 
|         //(下拉框) | 
|         $.get(ctx + 'admin/happyActivity/allGroup', function (res) { | 
|             var data = res.data; | 
|             for (let k in data) | 
|             { | 
|                 $(".group-type").append("<option value='" + data[k].id + "'>" + data[k].name + "</option>"); | 
|             } | 
|             layui.use('form', function () { | 
|                 var form = layui.form; | 
|                 form.render(); | 
|             }); | 
|         }); | 
|   | 
|         // 表格初始化 | 
|         initActivityTable(); | 
|   | 
|         // 初始化表格操作栏各个按钮功能 | 
|         table.on('tool(activityTable)', function (obj) { | 
|             console.log("触发事件:", obj.event); // 调试信息 | 
|             var data = obj.data, | 
|                 layEvent = obj.event; | 
|   | 
|             if (layEvent === 'activityDeleteEvent') { | 
|                 febs.modal.confirm('删除', '确认删除该活动?', function () { | 
|                     delAct(data.id); | 
|                 }); | 
|             } | 
|             if (layEvent === 'seeImgThumb') { | 
|                 var t = $view.find('#seeImgThumb'+data.id+''); | 
|                 //页面层 | 
|                 layer.open({ | 
|                     type: 1, | 
|                     title: "图片", | 
|                     skin: 'layui-layer-rim', //加上边框 | 
|                     area: ['100%', '100%'], //宽高 | 
|                     shadeClose: true, //开启遮罩关闭 | 
|                     end: function (index, layero) { | 
|                         return false; | 
|                     }, | 
|                     content: '<div style="text-align:center"><img src="' + $(t).attr('src') + '" /></div>' | 
|                 }); | 
|             } | 
|             if (layEvent === 'activityUpdateEvent') { | 
|                 febs.modal.open('编辑','modules/votesActivity/votesActivityUpdate/' + data.id, { | 
|                     btn: ['提交', '取消'], | 
|                     area: ['100%', '100%'], | 
|                     yes: function (index, layero) { | 
|                         $('#febs-activity-discount').find('#submit').trigger('click'); | 
|                     }, | 
|                     btn2: function () { | 
|                         layer.closeAll(); | 
|                     } | 
|                 }); | 
|             } | 
|         }); | 
|   | 
|         form.on('switch(activityStateSwitch)', function (data) { | 
|             if (data.elem.checked) { | 
|                 changeState(data.value,1); | 
|             } else { | 
|                 changeState(data.value,0); | 
|             } | 
|         }) | 
|         function changeState(id,state) { | 
|             febs.get(ctx + 'admin/happyActivity/changeState/' + id+'/' + state, null, function (data) { | 
|                 febs.alert.success(data.message); | 
|                 $query.click(); | 
|             }); | 
|         } | 
|         function delAct(id) { | 
|             febs.get(ctx + 'admin/happyActivity/delActivity/' + id, null, function (data) { | 
|                 febs.alert.success(data.message); | 
|                 $query.click(); | 
|             }); | 
|         } | 
|   | 
|         // 初始化表格操作栏各个按钮功能 | 
|         table.on('toolbar(activityTable)', function (obj) { | 
|             let data = obj.data, | 
|                 layEvent = obj.event; | 
|             console.log("触发事件:", obj.event); // 调试信息 | 
|             if(layEvent === 'activityAdd'){ | 
|                 febs.modal.open('新增活动', 'modules/votesActivity/add/', { | 
|                     btn: ['提交', '取消'], | 
|                     area:['100%','100%'], | 
|                     yes: function (index, layero) { | 
|                         $('#febs-activity-add').find('#submit').trigger('click'); | 
|                     }, | 
|                     btn2: function () { | 
|                         layer.closeAll(); | 
|                     } | 
|                 }); | 
|             } | 
|         }); | 
|   | 
|         function initActivityTable() { | 
|             tableIns = febs.table.init({ | 
|                 elem: $view.find('table'), | 
|                 id: 'activityTable', | 
|                 url: ctx + 'admin/happyActivity/list', | 
|                 toolbar:"#activityToolbar", | 
|                 defaultToolbar:[], | 
|                 cols: [[ | 
|   | 
|                     {type: 'numbers', title: '', width: 80}, | 
|                     {title: '操作', toolbar: '#activityOption', minWidth: 200, align: 'center'}, | 
|                     {field: 'name', title: '名称', minWidth: 150,align:'left'}, | 
|                     {field: 'categoryName', title: '分类', minWidth: 150,align:'left'}, | 
|                     { | 
|                         field: 'indexImg', | 
|                         title: '封面', | 
|                         templet: function (d) { | 
|                             return '<a lay-event="seeImgThumb">' + | 
|                                 '<img id="seeImgThumb' + d.id + '" src="' + d.indexImg + | 
|                                 '" alt="图片" style="width: 50px; height: 50px; object-fit: cover; border-radius: 5px; cursor: pointer;">' + | 
|                                 '</a>'; | 
|                         }, | 
|                         minWidth: 150, | 
|                         align: 'center' | 
|                     }, | 
|                     {field: 'startTime', title: '开始时间', minWidth: 200,align:'left'}, | 
|                     {field: 'endTime', title: '结束时间', minWidth: 200,align:'left'}, | 
|                     {field: 'state', title: '状态', templet: '#activityStateSwitch', minWidth: 130,align:'center'} | 
|                 ]] | 
|             }); | 
|         } | 
|   | 
|   | 
|         // 查询按钮 | 
|         $query.on('click', function () { | 
|             var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type}); | 
|             tableIns.reload({where: params, page: {curr: 1}}); | 
|         }); | 
|   | 
|         // 刷新按钮 | 
|         $reset.on('click', function () { | 
|             $searchForm[0].reset(); | 
|             sortObject.type = 'null'; | 
|             tableIns.reload({where: getQueryParams(), page: {curr: 1}, initSort: sortObject}); | 
|         }); | 
|         // 获取查询参数 | 
|         function getQueryParams() { | 
|             return { | 
|                 name: $searchForm.find('input[name="name"]').val().trim(), | 
|                 state: $searchForm.find("select[name='state']").val(), | 
|                 categoryId: $searchForm.find("select[name='categoryId']").val(), | 
|             }; | 
|         } | 
|   | 
|     }) | 
| </script> |