初始上传

This commit is contained in:
2026-04-04 17:27:12 +08:00
parent 4d80d28eb4
commit b7e11774ee
11191 changed files with 1588469 additions and 0 deletions

View File

@@ -0,0 +1,328 @@
<style>
.coupon-box .layui-form{
padding: 0!important;
}
.layui-layer-page .layui-layer-content{
overflow: auto !important;
}
.del-btn {
cursor: pointer;
}
.level-equity .layui-input {
display: inline-block;
}
.gods-box table:first-of-type{
margin-bottom: 0;
}
.gods-box table:last-of-type{
margin-top: 0;
display: block;
max-height: 323px;
overflow: auto;
}
.coupon-box .single-filter-box{
padding-top: 0;
}
.coupon-box .select-coupon-btn{
margin-top: 10px;
}
.layui-layer-page .layui-layer-content{
overflow-y: scroll!important;
}
.num-name{display: inline-block}
</style>
<div class="layui-form">
<div class="layui-card card-common card-brief">
<div class="layui-card-header">
<span class="card-title">活动设置</span>
</div>
<div class="layui-card-body">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动名称:</label>
<div class="layui-input-block">
<input type="text" name="recommend_name" lay-verify="required|len" class="layui-input len-long" autocomplete="off" maxlength="40">
</div>
<div class="word-aux">
<p>活动名称最多为25个字符</p>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动时间:</label>
<div class="layui-inline">
<div class="layui-input-inline len-mid">
<input type="text" class="layui-input" name="start_time" lay-verify="required" id="start_time" autocomplete="off" readonly>
<i class=" iconrili iconfont calendar"></i>
</div>
<span class="layui-form-mid">-</span>
<div class="layui-input-inline len-mid end-time">
<input type="text" class="layui-input" name="end_time" lay-verify="required|time" id="end_time" autocomplete="off" readonly>
<i class=" iconrili iconfont calendar"></i>
</div>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">活动说明:</label>
<div class="layui-input-block">
<textarea class="layui-textarea len-long" name="remark" maxlength="150"></textarea>
</div>
</div>
</div>
</div>
<div class="layui-card card-common card-brief">
<div class="layui-card-header">
<span class="card-title">规则设置</span>
</div>
<div class="layui-card-body reward-wrap">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>邀请人可得奖励:</label>
<div class="layui-input-block">
<input type="checkbox" name="type" value="point" title="积分" lay-skin="primary" lay-filter="type" lay-verify="type" checked>
<input type="checkbox" name="type" value="balance" title="余额" lay-skin="primary" lay-filter="type" lay-verify="type">
<input type="checkbox" name="type" value="coupon" title="优惠券" lay-skin="primary" lay-filter="type" lay-verify="type">
</div>
</div>
<div class="point-wrap">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>奖励积分:</label>
<div class="layui-input-block">
<input name="point" value="0" type="number" lay-verify="required|mum" class="layui-input len-short">
</div>
</div>
</div>
<div class="balance-wrap layui-hide">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>奖励红包:</label>
<div class="layui-input-block len-long">
<input name="balance" value="0" type="number" lay-verify="" class="layui-input len-short" onchange="detectionNumType(this,'positiveNumber')">
</div>
</div>
<div class="word-aux"><p>红包为储值余额,仅在消费时可用</p></div>
</div>
<div class="coupon-wrap layui-hide">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>奖励优惠券:</label>
<div class="layui-input-block">
<div id="coupon_list"></div>
<div class="word-aux text-color" style="margin-left: 0">
<p>活动优惠券发放,不受优惠券自身数量和领取数量的限制</p>
</div>
<button class="layui-btn" id="select_coupon">选择优惠券</button>
</div>
</div>
</div>
<div class="max-fetch-wrap">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>邀请奖励上限:</label>
<div class="layui-input-block">
<input name="max_fetch" value="0" type="number" class="layui-input len-short num-name">
<div class="word-aux text-color" style="margin-left: 0">
<p>默认0为不限制</p>
</div>
</div>
</div>
</div>
<div class="form-row">
<button class="layui-btn" lay-submit lay-filter="save">保存</button>
<button class="layui-btn layui-btn-primary" onclick="back()">返回</button>
</div>
</div>
</div>
</div>
<script type="text/javascript" src="STATIC_JS/coupon_select.js"></script>
<script>
var coupon_id = [], addCoupon,minDate,
currentDate = new Date(); //当前时间;
var coupon_select = new CouponSelect({
tableElem:'#coupon_list',
selectElem:'#select_coupon',
})
layui.use(['form', 'laytpl', 'laydate'], function() {
var form = layui.form,
laytpl = layui.laytpl,
laydate = layui.laydate,
repeat_flag = false; //防重复标识
form.render();
currentDate.setDate(currentDate.getDate() + 30); //当前时间+30之后的时间戳
// 开始时间
laydate.render({
elem: '#start_time' ,//指定元素
type: 'datetime',
value: new Date(),
done: function(value){
minDate = value;
reRender();
}
});
//结束时间
laydate.render({
elem: '#end_time' ,//指定元素
type: 'datetime',
value: new Date(currentDate)
});
/**
* 重新渲染结束时间
* */
function reRender(){
$("#end_time").remove();
$(".end-time").html('<input type="text" id="end_time" name="end_time" placeholder="请输入结束时间" lay-verify="required|time" class="layui-input len-mid" autocomplete="off"><i class=" iconrili iconfont calendar"></i>');
laydate.render({
elem: '#end_time',
type: 'datetime',
min: minDate
});
}
form.on('checkbox(type)', function(data) {
$('[name="type"]').each(function(){
var type = $(this).val();
if ($(this).is(':checked')) {
$('.reward-wrap .' + type + '-wrap').removeClass('layui-hide');
if (type == 'point' || type == 'coupon') {
$('.reward-wrap .' + type + '-wrap [lay-verify]').attr('lay-verify', 'required|mum');
}
if (type == 'balance') {
$('.reward-wrap .' + type + '-wrap [lay-verify]').attr('lay-verify', 'required|float');
}
} else {
$('.reward-wrap .' + type + '-wrap').addClass('layui-hide');
$('.reward-wrap .' + type + '-wrap [lay-verify]').attr('lay-verify', '');
}
})
})
/**
* 监听保存
*/
form.on('submit(save)', function(data) {
let coupon_selected_ids = coupon_select.getSelectedData().selectedIds;
var type = [];
$('.reward-wrap [name="type"]:checked').each(function(){
type.push($(this).val());
})
if ($.inArray('coupon', type) != -1 && coupon_selected_ids.length == 0) {
layer.msg('请选择优惠券', {icon: 5});
return;
}
if(data.field.max_fetch == ''){
layer.msg('请输入邀请奖励上限', {icon: 5});
return;
}else if (data.field.max_fetch < 0){
layer.msg('请输入大于或等于0的整数', {icon: 5});
return;
}
data.field.type = type.toString();
data.field.coupon = coupon_selected_ids.toString();
if (repeat_flag) return false;
repeat_flag = true;
$.ajax({
url: ns.url("memberrecommend://shop/memberrecommend/add"),
data: data.field,
dataType: 'JSON', //服务器返回json格式数据
type: 'POST', //http请求类型
success: function(res) {
repeat_flag = false;
if (res.code == 0) {
layer.confirm('添加成功', {
title:'操作提示',
btn: ['返回列表', '继续添加'],
closeBtn: 0,
yes: function(index, layero){
location.hash = ns.hash("memberrecommend://shop/memberrecommend/lists")
layer.close(index);
},
btn2: function(index, layero) {
listenerHash(); // 刷新页面
layer.close(index);
}
});
}else{
layer.msg(res.message);
}
}
});
});
/**
* 表单验证
*/
form.verify({
type: function(){
if ($('.reward-wrap [name="type"]:checked').length == 0) {
return '请选择邀请人可得奖励';
}
},
mum: function(value, item){
let reg = ns.getRegexp('>0num');
if (!reg.test(value)) {
return '请输入正整数';
}
},
float: function(value, item){
let reg = ns.getRegexp('>0float2');
if (!reg.test(value)) {
return '请输入大于0的数字最多保留两位小数';
}
}
});
});
function back(){
location.hash = ns.hash("memberrecommend://shop/memberrecommend/lists");
}
//检测数据类型
function detectionNumType(el,type){
var value = $(el).val();
//大于零 且 不是小数
if (value < 0 && type == 'integral')
$(el).val(0);
else if(type == 'integral')
$(el).val(Math.round(value));
//大于1 且 不是小数
if (value < 1 && type == 'positiveInteger'){
$(el).val(1);
} else if (type == 'positiveInteger'){
var val = Math.round(value);
if(Object.is(val,NaN)){
$(el).val(1);
}else{
$(el).val(val);
}
}
//大于零可以是小数
if (type == 'positiveNumber'){
value = parseFloat(value).toFixed(2);
if (value < 0)
$(el).val(0);
else
$(el).val(value);
}
}
</script>

View File

@@ -0,0 +1,140 @@
<link rel="stylesheet" href="STATIC_CSS/promotion_detail.css">
<div class="layui-card card-common card-brief">
<div class="layui-card-header">
<span class="card-title">基本信息</span>
</div>
<div class="layui-card-body">
<div class="promotion-view">
<div class="promotion-view-item">
<label>活动名称:</label>
<span>{$info.recommend_name}</span>
</div>
<div class="promotion-view-item">
<label>活动状态:</label>
<span>{$info.status_name}</span>
</div>
<div class="promotion-view-item">
<label>开始时间:</label>
<span>{:date('Y-m-d H:i:s',$info.start_time)}</span>
</div>
<div class="promotion-view-item">
<label>结束时间:</label>
<span>{:date('Y-m-d H:i:s',$info.end_time)}</span>
</div>
<div class="promotion-view-item">
<label>添加时间:</label>
<span>{:date('Y-m-d H:i:s',$info.create_time)}</span>
</div>
{if in_array('point', $info['type'])}
<div class="promotion-view-item">
<label>奖励积分:</label>
<span>{$info.point}</span>
</div>
{/if}
{if in_array('balance', $info['type'])}
<div class="layui-form-item">
<label>奖励红包:</label>
<span>{$info.balance}</span>
</div>
{/if}
</div>
{if !empty($info.remark)}
<div class="promotion-view">
<div class="promotion-view-item-line">
<label class="promotion-view-item-custom-label">活动说明:</label>
<div class="promotion-view-item-custom-box">{$info.remark}</div>
</div>
</div>
{/if}
</div>
</div>
{if in_array('coupon', $info['type']) && !empty($info['coupon_list'])}
<div class="layui-card card-common card-brief">
<div class="layui-card-header">
<span class="card-title">奖励优惠券</span>
</div>
<div class="layui-card-body">
<div class='promotion-view-list'>
<table id="promotion_list"></table>
</div>
</div>
</div>
{/if}
<script type='text/html' id="promotion_list_item_box_html">
<div class="promotion-list-item-title">
<div class="promotion-list-item-title-icon">
{{# if(d.image != ''){ }}
<img src="{{ ns.img(d.image) }}">
{{# }else{ }}
<img src="__ROOT__/public/uniapp/game/coupon.png">
{{# } }}
</div>
<p class="promotion-list-item-title-name multi-line-hiding">{{ d.coupon_name }}</p>
</div>
</script>
<script>
var promotion_list = {:json_encode($info['coupon_list'] ?? [], JSON_UNESCAPED_UNICODE)};
layui.use('table', function() {
new Table({
elem: '#promotion_list',
cols: [
[{
title: '优惠券名称',
width: '30%',
unresize: 'false',
templet: '#promotion_list_item_box_html'
}, {
title: '类型',
templet: function(data) {
return data.type == 'reward' ? '满减': '折扣';
}
}, {
title: '优惠金额/折扣',
templet: function(data) {
return data.type == 'reward' ? data.money : data.discount;
}
}, {
title: '适用商品',
templet: function (data) {
return data.goods_type_name;
}
}, {
field: 'max_fetch',
title: '领取人限制',
}, {
field: 'price',
title: '已领取/发放数',
templet: function(data) {
return data.count == -1 ? data.lead_count+'/不限量': data.lead_count+'/'+data.count;
}
}, {
field: 'stock',
title: '结束时间',
unresize: 'false',
width:'20%',
templet: function(data) {
var str = '';
switch(data.validity_type) {
case 0:
str = ns.time_to_date(data.end_time);
break;
case 1:
str = '领取之日起' + data.fixed_term + '天有效';
break;
default:
str = '长期有效';
break;
}
return str;
}
}]
],
data: promotion_list
});
});
</script>

View File

@@ -0,0 +1,284 @@
<style>
.coupon-box .layui-form{
padding: 0!important;
}
.layui-layer-page .layui-layer-content{
overflow: auto !important;
}
.del-btn {
cursor: pointer;
}
.level-equity .layui-input {
display: inline-block;
}
.gods-box table:first-of-type{
margin-bottom: 0;
}
.gods-box table:last-of-type{
margin-top: 0;
display: block;
max-height: 323px;
overflow: auto;
}
.coupon-box .single-filter-box{
padding-top: 0;
}
.coupon-box .select-coupon-btn{
margin-top: 10px;
}
.layui-layer-page .layui-layer-content{
overflow-y: scroll!important;
}
</style>
<div class="layui-form">
<div class="layui-card card-common card-brief">
<div class="layui-card-header">
<span class="card-title">活动设置</span>
</div>
<div class="layui-card-body">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动名称:</label>
<div class="layui-input-block">
<input name="recommend_name" value="{$recommend_info.recommend_name}" type="text" lay-verify="required" class="layui-input len-long">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>开始时间:</label>
<div class="layui-inline">
<div class="layui-input-inline len-mid">
<input type="text" {if condition="$recommend_info.status == 1"}disabled {/if} value="{:date('Y-m-d H:i:s', $recommend_info.start_time)}" class="layui-input" name="start_time" lay-verify="required" id="start_time" autocomplete="off" readonly>
<i class=" iconrili iconfont calendar"></i>
</div>
<span class="layui-form-mid">-</span>
<div class="layui-input-inline len-mid end-time">
<input type="text" {if condition="$recommend_info.status == 1"}disabled {/if} value="{:date('Y-m-d H:i:s', $recommend_info.end_time)}" class="layui-input" name="end_time" lay-verify="required|times" id="end_time" autocomplete="off" readonly>
<i class=" iconrili iconfont calendar"></i>
</div>
</div>
{if condition="$recommend_info.status == 1"}
<div class="word-aux">
<p>活动进行中时间不可更改</p>
</div>
{/if}
</div>
<div class="layui-form-item">
<label class="layui-form-label">活动说明:</label>
<div class="layui-input-block">
<textarea class="layui-textarea len-long" name="remark" maxlength="150">{$recommend_info.remark}</textarea>
</div>
</div>
</div>
</div>
<div class="layui-card card-common card-brief">
<div class="layui-card-header">
<span class="card-title">规则设置</span>
</div>
<div class="layui-card-body reward-wrap">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>邀请人可得奖励:</label>
<div class="layui-input-block">
<input type="checkbox" name="type" value="point" title="积分" lay-skin="primary" lay-filter="type" lay-verify="type" {if in_array('point', $recommend_info['type']) }checked{/if}>
<input type="checkbox" name="type" value="balance" title="余额" lay-skin="primary" lay-filter="type" lay-verify="type" {if in_array('balance', $recommend_info['type']) }checked{/if}>
<input type="checkbox" name="type" value="coupon" title="优惠券" lay-skin="primary" lay-filter="type" lay-verify="type" {if in_array('coupon', $recommend_info['type']) }checked{/if}>
</div>
</div>
<div class="point-wrap {if !in_array('point', $recommend_info['type']) }layui-hide{/if}">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>奖励积分:</label>
<div class="layui-input-block">
<input name="point" value="{$recommend_info.point}" type="number" lay-verify="{if in_array('point', $recommend_info['type']) }required|num{/if}" class="layui-input len-short">
</div>
</div>
</div>
<div class="balance-wrap {if !in_array('balance', $recommend_info['type']) }layui-hide{/if}">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>奖励红包:</label>
<div class="layui-input-block len-long">
<input name="balance" value="{$recommend_info.balance}" type="number" lay-verify="{if in_array('balance', $recommend_info['type']) }required|float{/if}" class="layui-input len-short">
</div>
</div>
<div class="word-aux"><p>红包为储值余额,仅在消费时可用</p></div>
</div>
<div class="coupon-wrap {if !in_array('coupon', $recommend_info['type']) }layui-hide{/if}">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>奖励优惠券:</label>
<div class="layui-input-block">
<div id="coupon_list"></div>
<div class="word-aux text-color" style="margin-left: 0">
<p>活动优惠券发放,不受优惠券自身数量和领取数量的限制</p>
</div>
<button class="layui-btn" id="select_coupon">选择优惠券</button>
</div>
</div>
</div>
<div class="max-fetch-wrap">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>邀请奖励上限:</label>
<div class="layui-input-block">
<input name="max_fetch" value="{$recommend_info.max_fetch}" type="number" class="layui-input len-short">
<div class="word-aux text-color" style="margin-left: 0">
<p>默认0为不限制</p>
</div>
</div>
</div>
</div>
<input type="hidden" name="recommend_id" value="{$recommend_info.recommend_id}">
<div class="form-row">
<button class="layui-btn" lay-submit lay-filter="save">保存</button>
<button class="layui-btn layui-btn-primary" onclick="back()">返回</button>
</div>
</div>
</div>
</div>
<script type="text/javascript" src="STATIC_JS/coupon_select.js"></script>
<script>
var coupon_id = [], addCoupon,
currentDate = new Date(); //当前时间;
var coupon_select = new CouponSelect({
tableElem:'#coupon_list',
selectElem:'#select_coupon',
selectedIds:'{$recommend_info.coupon}'
})
layui.use(['form', 'laytpl', 'laydate'], function() {
var form = layui.form,
laytpl = layui.laytpl,
laydate = layui.laydate,
repeat_flag = false; //防重复标识
form.render();
currentDate.setDate(currentDate.getDate() + 30); //当前时间+30之后的时间戳
laydate.render({
elem: '#start_time',
type: 'datetime'
});
laydate.render({
elem: '#end_time',
type: 'datetime'
});
form.on('checkbox(type)', function(data) {
$('[name="type"]').each(function(){
var type = $(this).val();
if ($(this).is(':checked')) {
$('.reward-wrap .' + type + '-wrap').removeClass('layui-hide');
if (type == 'point' || type == 'coupon') {
$('.reward-wrap .' + type + '-wrap [lay-verify]').attr('lay-verify', 'required|mum');
}
if (type == 'balance') {
$('.reward-wrap .' + type + '-wrap [lay-verify]').attr('lay-verify', 'required|float');
}
} else {
$('.reward-wrap .' + type + '-wrap').addClass('layui-hide');
$('.reward-wrap .' + type + '-wrap [lay-verify]').attr('lay-verify', '');
}
})
})
/**
* 监听保存
*/
form.on('submit(save)', function(data) {
let coupon_selected_ids = coupon_select.getSelectedData().selectedIds;
var type = [];
$('.reward-wrap [name="type"]:checked').each(function(){
type.push($(this).val());
})
if ($.inArray('coupon', type) != -1 && coupon_selected_ids.length == 0) {
layer.msg('请选择优惠券', {icon: 5});
return;
}
if(data.field.max_fetch == ''){
layer.msg('请输入邀请奖励上限', {icon: 5});
return;
}else if (data.field.max_fetch < 0){
layer.msg('请输入大于或等于0的整数', {icon: 5});
return;
}
data.field.type = type.toString();
data.field.coupon = coupon_selected_ids.toString();
if (repeat_flag) return false;
repeat_flag = true;
$.ajax({
url: ns.url("memberrecommend://shop/memberrecommend/edit"),
data: data.field,
dataType: 'JSON', //服务器返回json格式数据
type: 'POST', //http请求类型
success: function(res) {
repeat_flag = false;
if (res.code == 0) {
layer.confirm('编辑成功', {
title:'操作提示',
btn: ['返回列表', '继续编辑'],
closeBtn: 0,
yes: function(index, layero){
location.hash = ns.hash("memberrecommend://shop/memberrecommend/lists")
layer.close(index);
},
btn2: function(index, layero) {
layer.close(index);
}
});
}else{
layer.msg(res.message);
}
}
});
});
/**
* 表单验证
*/
form.verify({
type: function(){
if ($('.reward-wrap [name="type"]:checked').length == 0) {
return '请选择邀请人可得奖励';
}
},
mum: function(value, item){
if (isNaN(parseInt(value))) {
return '请输入大于0的数字支持小数点后两位';
}
value = parseInt(value);
if (/^\d{0,10}$/.test(value) === false || value <= 0) {
return '请输入大于0的整数';
}
},
float: function(value, item){
if (isNaN(parseFloat(value))) {
return '请输入大于0的数字支持小数点后两位';
}
value = parseFloat(value);
if (/^\d{0,10}$/.test(value) === false || value <= 0) {
return '请输入大于0的数字支持小数点后两位';
}
}
});
});
function back(){
location.hash = ns.hash("memberrecommend://shop/memberrecommend/lists");
}
</script>

View File

@@ -0,0 +1,253 @@
<style>
.layui-layout-admin .layui-form-item .layui-input-inline{background-color: #fff;}
.layui-layout-admin .table-tab .layui-tab-title{margin-bottom: 15px;}
</style>
<!-- 搜索框 -->
<div class="single-filter-box">
<button class="layui-btn" onclick="add()">添加活动</button>
</div>
<div class="screen layui-collapse" lay-filter="selection_panel">
<div class="layui-colla-item">
<form class="layui-colla-content layui-form layui-show">
<div class="layui-form-item">
<div class="layui-inline">
<label class="layui-form-label">活动名称:</label>
<div class="layui-input-inline">
<input type="text" name="recommend_name" placeholder="请输入活动名称" autocomplete="off" class="layui-input">
</div>
</div>
<div class="layui-inline">
<label class="layui-form-label">活动时间:</label>
<div class="layui-input-inline">
<input type="text" class="layui-input" name="start_time" placeholder="开始时间" id="start_time" readonly>
<i class=" iconrili iconfont calendar"></i>
</div>
<div class="layui-form-mid">-</div>
<div class="layui-input-inline">
<input type="text" class="layui-input" name="end_time" placeholder="结束时间" id="end_time" readonly>
<i class=" iconrili iconfont calendar"></i>
</div>
</div>
</div>
<div class="form-row">
<button type="button" class="layui-btn" lay-filter="search" lay-submit>筛选</button>
<button type="reset" class="layui-btn layui-btn-primary">重置</button>
</div>
</form>
</div>
</div>
<div class="layui-tab table-tab" lay-filter="recommend_tab">
<ul class="layui-tab-title">
<li class="layui-this" lay-id="">所有活动</li>
<li lay-id="1">进行中</li>
<li lay-id="2">已结束</li>
<li lay-id="-1">已关闭</li>
<li lay-id="0">未开始</li>
</ul>
<div class="layui-tab-content">
<!-- 列表 -->
<table id="recommend_list" lay-filter="recommend_list"></table>
</div>
</div>
<!-- 操作 -->
<script type="text/html" id="operation">
<div class="table-btn">
<a class="layui-btn" lay-event="receive">领取记录</a>
<a class="layui-btn" lay-event="detail">详情</a>
{{# if(d.status == 0) { }}
<a class="layui-btn" lay-event="edit">编辑</a>
<a class="layui-btn" lay-event="delete">删除</a>
{{# }else if(d.status == 1) { }}
<a class="layui-btn" lay-event="close">关闭</a>
{{# }else if(d.status == 2 || d.status == -1) { }}
<a class="layui-btn" lay-event="delete">删除</a>
{{# } }}
</div>
</script>
<!-- 时间 -->
<script id="time" type="text/html">
<div class="layui-elip">开始{{ns.time_to_date(d.start_time)}}</div>
<div class="layui-elip">结束{{ns.time_to_date(d.end_time)}}</div>
</script>
<!-- 状态 -->
<script type="text/html" id="status">
{foreach $recommend_status_arr as $recommend_status_k => $recommend_status_v}
{{# if(d.status == {$recommend_status_k}){ }}
{$recommend_status_v}
{{# } }}
{/foreach}
</script>
<script>
layui.use(['form','element','laydate'], function() {
var table,
form = layui.form,
element = layui.element,
laydate = layui.laydate,
repeat_flag = false; //防重复标识
form.render();
element.on('tab(recommend_tab)', function(){
table.reload({
page: {
curr: 1
},
where: {
'status':this.getAttribute('lay-id')
}
});
});
table = new Table({
elem: '#recommend_list',
url: ns.url("memberrecommend://shop/memberrecommend/lists"),
cols: [
[{
field: 'recommend_name',
title: '活动名称',
unresize: 'false',
width: '25%'
}, {
title: '活动时间',
unresize: 'false',
width: '21%',
templet: '#time'
}, {
field: 'status',
title: '状态',
unresize: 'false',
width: '13%',
templet: '#status'
}, {
field: 'count',
title: '邀请人数',
unresize: 'false',
}, {
title: '操作',
toolbar: '#operation',
unresize: 'false',
align:'right'
}]
]
});
/**
* 监听工具栏操作
*/
table.tool(function(obj) {
var data = obj.data;
switch (obj.event) {
case 'edit': //编辑
location.hash = ns.hash("memberrecommend://shop/memberrecommend/edit", {"recommend_id": data.recommend_id});
break;
case 'detail': //详情
location.hash = ns.hash("memberrecommend://shop/memberrecommend/detail", {"recommend_id": data.recommend_id});
break;
case 'delete': //删除
deleteRecommend(data.recommend_id);
break;
case 'close': //关闭
close(data.recommend_id);
break;
case 'receive': //关闭
location.hash = ns.hash("memberrecommend://shop/memberrecommend/receive", {"recommend_id": data.recommend_id});
break;
}
});
//开始时间
laydate.render({
elem: '#start_time', //指定元素
type: 'datetime'
});
//结束时间
laydate.render({
elem: '#end_time', //指定元素
type: 'datetime'
});
/**
* 删除
*/
function deleteRecommend(recommend_id) {
if (repeat_flag) return false;
repeat_flag = true;
layer.confirm('确定要删除该活动吗?', function(index) {
layer.close(index);
$.ajax({
url: ns.url("memberrecommend://shop/memberrecommend/delete"),
data: {
recommend_id
},
dataType: 'JSON',
type: 'POST',
success: function(res) {
layer.msg(res.message);
repeat_flag = false;
if (res.code == 0) {
table.reload({
page: {
curr: 1
},
});
}
}
});
}, function () {
layer.close();
repeat_flag = false;
});
}
/**
* 关闭
*/
function close(recommend_id) {
if (repeat_flag) return false;
repeat_flag = true;
layer.confirm('确定关闭该活动吗?', function(index) {
layer.close(index);
$.ajax({
url: ns.url("memberrecommend://shop/memberrecommend/close"),
data: {
recommend_id
},
dataType: 'JSON',
type: 'POST',
success: function(res) {
layer.msg(res.message);
repeat_flag = false;
if (res.code == 0) {
table.reload();
}
}
});
});
}
/**
* 搜索功能
*/
form.on('submit(search)', function(data) {
table.reload({
page: {
curr: 1
},
where: data.field
});
});
});
function add() {
location.hash = ns.hash("memberrecommend://shop/memberrecommend/add");
}
</script>

View File

@@ -0,0 +1,102 @@
<style>
.layui-layer-page .layui-layer-content { padding: 20px 30px; }
.layui-form-item{ margin-bottom: 0px; }
.form-row { margin: 0px !important; display: inline-block }
.screen.layui-collapse { margin-top: 10px }
</style>
<div class="screen layui-collapse" lay-filter="selection_panel">
<div class="layui-colla-item">
<div class="layui-colla-content layui-form layui-show">
<div class="layui-form-item">
<div class="layui-inline">
<label class="layui-form-label">邀请人:</label>
<div class="layui-input-inline">
<input type="text" name="recommend_name" placeholder="请输入邀请人" autocomplete="off" class="layui-input">
</div>
<div class="form-row">
<button class="layui-btn" lay-submit lay-filter="search">筛选</button>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="layui-tab table-tab">
<div class="layui-tab-content">
<!-- 列表 -->
<table id="receive_list" lay-filter="receive_list"></table>
</div>
</div>
<!-- 优惠券列表 -->
<script type="text/html" id="coupon_list">
{{# layui.each(d.coupon_list, function(index, item){ }}
<a href="{{ ns.href('coupon://shop/coupon/detail?coupon_type_id=' + item.coupon_type_id ) }}" target="_blank">{{ item.coupon_name }}</a>
{{# }); }}
</script>
<input id="recommend_id" type="hidden" value="{$recommend_id}" />
<script>
layui.use(['form'], function() {
var table,
form = layui.form,
recommend_id = $('#recommend_id').val();
table = new Table({
elem: '#receive_list',
url: ns.url("memberrecommend://shop/memberrecommend/receive"),
where: {
"recommend_id": recommend_id
},
cols: [
[{
field: 'member_nickname',
title: '邀请人',
unresize: 'false',
width: '10%'
}, {
field: 'source_member_nickname',
title: '被邀请人',
unresize: 'false',
width: '10%'
}, {
field: 'point',
title: '奖励积分',
unresize: 'false',
width: '12.5%'
}, {
field: 'balance',
title: '奖励余额',
unresize: 'false',
width: '12.5%'
}, {
title: '奖励优惠券',
unresize: 'false',
width: '20%',
templet:"#coupon_list"
}, {
field: 'create_time',
title: '注册时间',
unresize: 'false',
width: '20%',
templet: function(data) {
return ns.time_to_date(data.create_time);
}
}]
],
});
// 搜索
form.on('submit(search)', function(data) {
table.reload({
page: {
curr: 1
},
where: data.field
});
});
});
</script>