381 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			HTML
		
	
	
			
		
		
	
	
			381 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			HTML
		
	
	
| {layout name="layout1" /}
 | ||
| <style>
 | ||
|     .layui-border-box {
 | ||
|         margin-left: 40px;
 | ||
|         margin-right: 40px;
 | ||
| 
 | ||
|     }
 | ||
| 
 | ||
|     .record {
 | ||
|         display: none;
 | ||
|         margin-top: 20px;
 | ||
|     }
 | ||
| </style>
 | ||
| 
 | ||
| <div class="wrapper">
 | ||
|     <div class="layui-form">
 | ||
|         <div class="layui-card">
 | ||
|             <div class="layui-card-body">
 | ||
|                 <div class="layui-collapse like-layui-collapse" lay-accordion="" style="border:1px dashed #c4c4c4">
 | ||
|                     <div class="layui-colla-item">
 | ||
|                         <h2 class="layui-colla-title like-layui-colla-title" style="background-color: #fff">操作提示</h2>
 | ||
|                         <div class="layui-colla-content layui-show">
 | ||
|                             <p>*用户每天签到一次可获得每天签到奖励,包括积分和成长值。</p>
 | ||
|                             <p>*点击新增连续签到奖励可以设置满足连续签到天数时的额外奖励,连续天数规则不能重复。</p>
 | ||
|                             <p>*用户签到中断会重新计算连续天数;超过设置的最大连续签到奖励天数后,也会重新计算连续天数,循环发放连续奖励。</p>
 | ||
|                         </div>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|             <div class="layui-tab layui-tab-card" lay-filter="tab-all">
 | ||
|                 <ul class="layui-tab-title">
 | ||
|                     <li data-type=1 class="layui-this">签到设置</li>
 | ||
|                     <li data-type=2>签到记录</li>
 | ||
|                 </ul>
 | ||
|                 <div class="layui-card-header"></div>
 | ||
|                 <div class="layui-form-item record">
 | ||
|                     <div class="layui-inline">
 | ||
|                         <label class="layui-form-label">会员信息:</label>
 | ||
|                         <div class="layui-input-inline">
 | ||
|                             <select name="type" id="type">
 | ||
|                                 <option value=""></option>
 | ||
|                                 <option value="sn">会员编号</option>
 | ||
|                                 <option value="nickname">会员昵称</option>
 | ||
|                                 <option value="mobile">手机号码</option>
 | ||
|                             </select>
 | ||
|                         </div>
 | ||
|                         <div class="layui-input-inline">
 | ||
|                             <input type="text" name="keyword" id="keyword" placeholder="请输入关键词" autocomplete="off"
 | ||
|                                    class="layui-input">
 | ||
|                         </div>
 | ||
|                         <div class="layui-inline">
 | ||
|                             <button class="layui-btn layui-btn-sm  {$view_theme_color}"lay-submit lay-filter="record-search">查询</button>
 | ||
|                             <button class="layui-btn layui-btn-sm layui-btn-primary " lay-submit lay-filter="record-clear-search">清空查询</button>
 | ||
|                         </div>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
|                 <!--每天签到奖励-->
 | ||
|                 <div class="layui-form-item sigh">
 | ||
|                     <label class="layui-form-label " style="margin-left: 20px;width: 100px">每天签到奖励:</label>
 | ||
|                     <div class="layui-input-inline " style="margin-right: 0px;width: 110px">
 | ||
|                         <input type="checkbox" name="integral_status" title="赠送积分"  min="0" lay-skin="primary" {if
 | ||
|                                condition="$config['dailySign']['integral_status'] eq 1" }checked{/if}>
 | ||
|                     </div>
 | ||
|                     <div class="layui-input-inline">
 | ||
|                         <input type="number" name="integral" value="{$config.dailySign.integral}" lay-verType="tips" placeholder="请输入积分" autocomplete="off" class="layui-input">
 | ||
|                     </div>
 | ||
|                     <div class="layui-input-inline">
 | ||
|                         <label class="layui-form-mid">积分</label>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
| 
 | ||
|                 <div class="layui-form-item sigh">
 | ||
|                     <label class="layui-form-label" style="margin-left: 20px;width: 100px"></label>
 | ||
|                     <div class="layui-input-inline" style="margin-right: 0px;width: 110px">
 | ||
|                         <input type="checkbox" name="growth_status" title="赠送成长值" min="0" lay-skin="primary"
 | ||
|                                {if condition="$config['dailySign']['growth_status'] eq 1" }checked{/if}>
 | ||
|                     </div>
 | ||
| 
 | ||
|                     <div class="layui-input-inline">
 | ||
|                         <input type="number" name="growth" value="{$config.dailySign.growth}" lay-vertype="tips" placeholder="请输入成长值" autocomplete="off" class="layui-input">
 | ||
|                     </div>
 | ||
|                     <div class="layui-input-inline">
 | ||
|                         <label class="layui-form-mid">成长值</label>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
| 
 | ||
|                 <div class="layui-form-item sigh">
 | ||
|                     <div class="layui-inline">
 | ||
|                         <label class="layui-form-label" style="margin-left: 20px;width: 100px">连续签到奖励:</label>
 | ||
|                         <div class=" layui-form-mid layui-word-aux">连续签到奖励断签后会重新计算连续签到天数,达到连续天数后即可获得连续奖励</div>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
|                 <!--新增连续签到奖励-->
 | ||
|                 <div class="layui-form-item sigh">
 | ||
|                     <div class="layui-inline " style="margin-left: 15px;width: 100px">
 | ||
|                         <button class="layui-btn layui-btn-sm layEvent {$view_theme_color}" lay-event="add">新增连续签到奖励</button>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
| 
 | ||
| 
 | ||
|                 <div class="layui-card-body" style="margin-top: -20px">
 | ||
|                     <div class="layui-card">
 | ||
|                         <table id="like-table-lists" class="layui-border-box" lay-filter="like-table-lists"></table>
 | ||
| 
 | ||
|                         <script type="text/html" id="status">
 | ||
|                             <input type="checkbox" lay-filter="switch-status" data-id={{d.id}} data-field='is_recommend'
 | ||
|                                    lay-skin="switch"
 | ||
|                                    lay-text="是|否" {{# if(d.is_recommend){ }} checked {{# } }}/>
 | ||
|                         </script>
 | ||
| 
 | ||
|                         <!--连续天数-->
 | ||
|                         <script type="text/html" id="daysTpl">
 | ||
|                             {{#  if( d.days == null || d.days == 0 || d.days == ''){ }}
 | ||
|                             ----
 | ||
|                             {{#  } else { }}
 | ||
|                             {{d.days}}天
 | ||
|                             {{#  } }}
 | ||
|                         </script>
 | ||
| 
 | ||
|                         <script type="text/html" id="table-operation">
 | ||
|                             <a class="layui-btn layui-btn-normal layui-btn-sm" lay-event="edit">编辑</a>
 | ||
|                             <a class="layui-btn layui-btn-danger layui-btn-sm" lay-event="del">删除</a>
 | ||
|                         </script>
 | ||
| 
 | ||
|                         <!--会员信息-->
 | ||
|                         <script type="text/html" id="user">
 | ||
|                             <img src="{{d.avatar}}" style="height:80px;width: 80px" class="image-show">
 | ||
|                             <div class="layui-input-inline" style="text-align: left">
 | ||
|                                 <p>会员编号:{{d.user_id}}</p>
 | ||
|                                 <p>昵称:{{d.nickname}}</p>
 | ||
|                                 <p>手机号:{{d.mobile}}</p>
 | ||
|                                 <p>性别:{{d.sex}}</p>
 | ||
|                                 <p>注册时间:{{d.create_time}}</p>
 | ||
|                             </div>
 | ||
|                         </script>
 | ||
| 
 | ||
|                         <!--签到奖励-->
 | ||
|                         <script type="text/html" id="integral">
 | ||
|                             赠送{{d.integral}}积分;赠送{{d.growth}}成长值
 | ||
|                         </script>
 | ||
| 
 | ||
|                         <!--连续奖励-->
 | ||
|                         <script type="text/html" id="continuous_integral">
 | ||
|                             赠送{{d.continuous_integral}}积分;赠送{{d.continuous_growth}}成长值
 | ||
|                         </script>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
|                 <!--签到规则说明-->
 | ||
|                 <div class="layui-form-item sigh">
 | ||
|                     <div class="layui-card">
 | ||
|                         <label class="layui-form-label" style="margin-left: 20px;width: 100px">签到规则说明:</label>
 | ||
|                         <div class="layui-input-inline" style="width: 500px">
 | ||
|                             <textarea name="instructions" id="instructions" placeholder="请输入签到规则说明"
 | ||
|                                       class="layui-textarea" style="width: 500px;height: 200px">{$config.instructions| default=''}</textarea>
 | ||
| 
 | ||
|                         </div>
 | ||
|                         <div class="layui-input-inline">
 | ||
|                             <button class="layui-btn layui-btn-primary " id="default">使用默认说明
 | ||
|                             </button>
 | ||
|                         </div>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
| 
 | ||
|                 <div class="layui-form-item sigh">
 | ||
|                     <label class="layui-form-label" style="width: 100px"></label>
 | ||
|                     <div class="layui-input-block" style="text-align: center; width: 950px;height: 60px">
 | ||
|                         <button class="layui-btn layui-btn-sm {$view_theme_color}" lay-submit lay-filter="formSign">
 | ||
|                             确认保存
 | ||
|                         </button>
 | ||
|                     </div>
 | ||
|                 </div>
 | ||
|             </div>
 | ||
|         </div>
 | ||
|     </div>
 | ||
| </div>
 | ||
| 
 | ||
| <script>
 | ||
|     layui.use(['table'], function () {
 | ||
|         var $ = layui.$
 | ||
|             , form = layui.form
 | ||
|             , table = layui.table
 | ||
|             , element = layui.element;
 | ||
| 
 | ||
|         //监听搜索
 | ||
|         form.on('submit(record-search)', function (data) {
 | ||
|             var field = data.field;
 | ||
|             //执行重载
 | ||
|             table.reload('like-table-lists', {
 | ||
|                 where: field,
 | ||
|                 page: {curr: 1}
 | ||
|             });
 | ||
|         });
 | ||
| 
 | ||
|         //清空记录查询
 | ||
|         form.on('submit(record-clear-search)', function () {
 | ||
|             $('#keyword').val('');
 | ||
|             $('#type').val('');
 | ||
|             form.render('select');
 | ||
|             table.reload('like-table-lists', {
 | ||
|                 where: [],
 | ||
|                 page: {curr: 1}
 | ||
|             });
 | ||
|         });
 | ||
| 
 | ||
|         //图片放大
 | ||
|         $(document).on('click', '.image-show', function () {
 | ||
|             var src = $(this).attr('src');
 | ||
|             like.showImg(src, 600);
 | ||
|         });
 | ||
| 
 | ||
|         getList(1);
 | ||
|         //切换列表
 | ||
|         element.on('tab(tab-all)', function (data) {
 | ||
|             var type = $(this).attr('data-type');
 | ||
|             if (type == 1) {
 | ||
|                 $('.sigh').show();
 | ||
|                 $('.record').hide();
 | ||
|             }
 | ||
| 
 | ||
|             if (type == 2) {
 | ||
|                 $('.sigh').hide();
 | ||
|                 $('.record').show();
 | ||
|             }
 | ||
|             getList(type);
 | ||
|         });
 | ||
| 
 | ||
|         //签到规则默认说明
 | ||
|         $('#default').click(function () {
 | ||
|             $('#instructions').val('1.每天签到可以获得每天签到奖励;\n' +
 | ||
|                 '2.每日最多可签到1次,断签则会重新计算连签天数,达到连续天数后即可获得连续奖励;\n' +
 | ||
|                 '3.活动以及奖励最终解释权归商家所有。')
 | ||
|         })
 | ||
| 
 | ||
| 
 | ||
|         //确定保存按钮
 | ||
|         form.on('submit(formSign)', function (data) {
 | ||
|             set(data, "{:url('sign_daily.SignDaily/signRule')}");
 | ||
|         });
 | ||
| 
 | ||
|         function set(data, url) {
 | ||
|             like.ajax({
 | ||
|                 url: url
 | ||
|                 , data: data.field
 | ||
|                 , type: "post",
 | ||
|                 success: function (res) {
 | ||
|                     if (res.code == 1) {
 | ||
|                         layui.layer.msg(res.msg, {
 | ||
|                             offset: '15px'
 | ||
|                             , icon: 1
 | ||
|                             , time: 1000
 | ||
|                         }, function () {
 | ||
|                             location.href = location.href;
 | ||
|                         });
 | ||
|                     }
 | ||
|                 }
 | ||
|             });
 | ||
|         }
 | ||
| 
 | ||
|         function getList(type) {
 | ||
|             var tablecols = [
 | ||
|                 {field: 'days', title: '连续天数', templet: '#daysTpl',width:300}
 | ||
|                 , {field: 'award_tips', title: '连续奖励',width:400}
 | ||
|                 , {title: '操作', align: 'center', fixed: 'right', toolbar: '#table-operation',width:350}
 | ||
|             ];
 | ||
|             var page = false;
 | ||
|             var url = '{:url("sign_daily.SignDaily/lists")}';
 | ||
| 
 | ||
|             if (type == 2) {
 | ||
|                 tablecols = [
 | ||
|                     {type:'numbers',title:'序号'}
 | ||
|                     , {field: 'user', title: '会员信息', align: 'center',templet:'#user',width:400}
 | ||
|                     , {field: 'days', title: '连续天数',width:100}
 | ||
|                     , {field: 'reward_tips', title: '签到奖励',templet:'#integral',width:250}
 | ||
|                     , {field: 'continuous_reward', title: '连续奖励',templet:'#continuous_integral',width:250}
 | ||
|                     , {fixed: 'right', field:'sign_time',title:'签到时间',width:250}
 | ||
|                 ];
 | ||
|                 page = true;
 | ||
|                 url = '{:url("sign_daily.SignDaily/record")}';
 | ||
|             }
 | ||
|             like.tableLists("#like-table-lists", url, tablecols, {}, page);
 | ||
|         }
 | ||
| 
 | ||
|         //事件
 | ||
|         var active = {
 | ||
|             add: function () {
 | ||
|                 layer.open({
 | ||
|                     type: 2
 | ||
|                     , title: '新增连续签到奖励'
 | ||
|                     , content: '{:url("sign_daily.SignDaily/add",["type"=>2])}'
 | ||
|                     , area: ['60%', '60%']
 | ||
|                     , btn: ['确定', '取消']
 | ||
|                     , yes: function (index, layero) {
 | ||
|                         var iframeWindow = window['layui-layer-iframe' + index]
 | ||
|                             , submitID = 'addSubmit'
 | ||
|                             , submit = layero.find('iframe').contents().find('#' + submitID);
 | ||
|                         //监听提交
 | ||
|                         iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
 | ||
|                             var field = data.field;
 | ||
|                             like.ajax({
 | ||
|                                 url: '{:url("sign_daily.SignDaily/add")}',
 | ||
|                                 data: field,
 | ||
|                                 type: "post",
 | ||
|                                 success: function (res) {
 | ||
|                                     if (res.code == 1) {
 | ||
|                                         layui.layer.msg(res.msg, {
 | ||
|                                             offset: '15px'
 | ||
|                                             , icon: 1
 | ||
|                                             , time: 1000
 | ||
|                                         });
 | ||
|                                         layer.close(index);
 | ||
|                                         table.reload('like-table-lists');
 | ||
|                                     }
 | ||
|                                 }
 | ||
|                             });
 | ||
|                         });
 | ||
|                         submit.trigger('click');
 | ||
|                     }
 | ||
|                 });
 | ||
|             },
 | ||
|             edit: function (obj) {
 | ||
|                 var id = obj.data.id;
 | ||
|                 layer.open({
 | ||
|                     type: 2
 | ||
|                     , title: '编辑连续签到奖励'
 | ||
|                     , content: '{:url("sign_daily.SignDaily/edit")}?id=' + id
 | ||
|                     , area: ['60%', '60%']
 | ||
|                     , btn: ['确定', '取消']
 | ||
|                     , yes: function (index, layero) {
 | ||
|                         var iframeWindow = window['layui-layer-iframe' + index]
 | ||
|                             , submitID = 'edit-sign_daily-submit'
 | ||
|                             , submit = layero.find('iframe').contents().find('#' + submitID);
 | ||
|                         //监听提交
 | ||
|                         iframeWindow.layui.form.on('submit(' + submitID + ')', function (data) {
 | ||
|                             var field = data.field;
 | ||
|                             like.ajax({
 | ||
|                                 url: '{:url("sign_daily.SignDaily/edit")}',
 | ||
|                                 data: field,
 | ||
|                                 type: "post",
 | ||
|                                 success: function (res) {
 | ||
|                                     if (res.code == 1) {
 | ||
|                                         layui.layer.msg(res.msg, {
 | ||
|                                             offset: '15px'
 | ||
|                                             , icon: 1
 | ||
|                                             , time: 1000
 | ||
|                                         });
 | ||
|                                         layer.close(index);
 | ||
|                                         table.reload('like-table-lists');
 | ||
|                                     }
 | ||
|                                 }
 | ||
|                             });
 | ||
|                         });
 | ||
|                         submit.trigger('click');
 | ||
|                     }
 | ||
|                 })
 | ||
|             },
 | ||
|             del:  function (obj) {
 | ||
|                 var id = obj.data.id;
 | ||
|                 var day = obj.data.days;
 | ||
|                 layer.confirm('确定移除连续签到奖励:' + '<span style="color: red">' + day + '天</span>', function (index) {
 | ||
|                     like.ajax({
 | ||
|                         url: '{:url("sign_daily.SignDaily/del")}',
 | ||
|                         data: {'id': id},
 | ||
|                         type: "post",
 | ||
|                         success: function (res) {
 | ||
|                             if (res.code == 1) {
 | ||
|                                 obj.del();
 | ||
|                                 layui.layer.msg(res.msg, {
 | ||
|                                     offset: '15px'
 | ||
|                                     , icon: 1
 | ||
|                                     , time: 1000
 | ||
|                                 });
 | ||
|                                 layer.close(index);
 | ||
|                             }
 | ||
|                         },
 | ||
|                     });
 | ||
|                 });
 | ||
|             }
 | ||
|         }
 | ||
|         like.eventClick(active);
 | ||
|     });
 | ||
| </script> |