初始上传

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,205 @@
<?php
/**
* Niushop商城系统 - 团队十年电商经验汇集巨献!
* =========================================================
* Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
* ----------------------------------------------
* 官方网址: https://www.niushop.com
* 这不是一个自由软件!您只能在不用于商业目的的前提下对程序代码进行修改和使用。
* 任何企业和个人不允许对程序代码以任何形式任何目的再发布。
* =========================================================
*/
namespace addon\bale\shop\controller;
use app\shop\controller\BaseShop;
use addon\bale\model\Bale as BaleModel;
/**
* 打包一口价
* @author Administrator
*
*/
class Bale extends BaseShop
{
/**
* 活动列表
* @return array|mixed
*/
public function lists()
{
if (request()->isJson()) {
$page = input('page', 1);
$page_size = input('page_size', PAGE_LIST_ROWS);
$status = input('status', '');
$name = input('name', '');
$condition = [
[ 'site_id', '=', $this->site_id ]
];
if ($status !== '') {
$condition[] = [ 'status', '=', $status ];
}
if (!empty($name)) {
$condition[] = [ 'name', 'like', '%' . $name . '%' ];
}
$start_time = input('start_time', '');
$end_time = input('end_time', '');
if ($start_time && !$end_time) {
$condition[] = [ 'end_time', '>=', date_to_time($start_time) ];
} elseif (!$start_time && $end_time) {
$condition[] = [ 'start_time', '<=', date_to_time($end_time) ];
} elseif ($start_time && $end_time) {
$start_timestamp = date_to_time($start_time);
$end_timestamp = date_to_time($end_time);
$sql = "start_time between {$start_timestamp} and {$end_timestamp}";
$sql .= " or end_time between {$start_timestamp} and {$end_timestamp}";
$sql .= " or (start_time <= {$start_timestamp} and end_time >= {$end_timestamp})";
$condition[] = [ '', 'exp', \think\facade\Db::raw($sql) ];
}
$bale = new BaleModel();
$list = $bale->getBalePageList($condition, $page, $page_size);
return $list;
} else {
return $this->fetch('bale/lists');
}
}
/**
* 添加活动
* @return mixed
*/
public function add()
{
if (request()->isJson()) {
$bale = new BaleModel();
$res = $bale->addBale([
'site_id' => $this->site_id,
'name' => input('name', ''),
'num' => input('num', 0),
'price' => input('price', 0.00),
'goods_ids' => input('goods_ids', ''),
'sku_ids' => input('sku_ids', ''),
'start_time' => strtotime(input('start_time', 0)),
'end_time' => strtotime(input('end_time', 0)),
'shipping_fee_type' => input('shipping_fee_type', 0),
]);
return $res;
}
return $this->fetch('bale/add');
}
/**
* 编辑活动
* @return mixed
*/
public function edit()
{
$bale = new BaleModel();
if (request()->isJson()) {
$res = $bale->editBale([
'bale_id' => input('bale_id'),
'site_id' => $this->site_id,
'name' => input('name', ''),
'num' => input('num', 0),
'price' => input('price', 0.00),
'goods_ids' => input('goods_ids', ''),
'sku_ids' => input('sku_ids', ''),
'start_time' => strtotime(input('start_time', 0)),
'end_time' => strtotime(input('end_time', 0)),
'shipping_fee_type' => input('shipping_fee_type', 0),
]);
return $res;
}
$bale_id = input('bale_id', '');
$info = $bale->getEditBaleData($bale_id, $this->site_id);
if (empty($info[ 'data' ])) $this->error('未获取到活动信息');
$this->assign('bale_info', $info[ 'data' ]);
return $this->fetch('bale/edit');
}
/**
* 详情
*/
public function detail()
{
$bale_id = input('bale_id', '');
$bale = new BaleModel();
$info = $bale->getEditBaleData($bale_id, $this->site_id)[ 'data' ] ?? [];
if (empty($info)) $this->error('未获取到活动信息');
$this->assign('info', $info);
return $this->fetch('bale/detail');
}
/**
* 删除活动
* @return array
*/
public function delete()
{
if (request()->isJson()) {
$id = input('id', 0);
$bale = new BaleModel();
$res = $bale->deleteBale($id, $this->site_id);
return $res;
}
}
/**
* 商品推广
* return
*/
public function baleUrl()
{
$bale_id = input('bale_id', '');
$app_type = input('app_type', 'all');
$bale = new BaleModel();
$res = $bale->urlQrcode('/pages_promotion/bale/detail', [ 'id' => $bale_id ], 'bale', $app_type, $this->site_id);
return $res;
}
public function closeBale()
{
$bale_id = input('id', '');
$bale = new BaleModel();
$res = $bale->closeBale($bale_id);
return $res;
}
/**
* 删除活动(批量)
* @return array
*/
public function deleteAll()
{
if (request()->isJson()) {
$bale_id = input('bale_id', '');
$bale = new BaleModel();
foreach ($bale_id as $k => $v){
$res = $bale->deleteBale($v, $this->site_id);
}
return $res;
}
}
/**
* 关闭活动(批量)
* @return array
*/
public function closeBaleAll()
{
if (request()->isJson()) {
$bale_id = input('bale_id', '');
$bale = new BaleModel();
foreach ($bale_id as $k => $v){
$res = $bale->closeBale($v);
}
return $res;
}
}
}

View File

@@ -0,0 +1,283 @@
<style type="text/css">
.goods_num {padding-left: 20px;}
</style>
<div class="layui-form form-wrap">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动名称:</label>
<div class="layui-input-block">
<input type="text" name="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-input-block 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>
</div>
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>结束时间:</label>
<div class="layui-input-block 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 class="word-aux">
<p>结束时间不能小于开始时间,也不能小于当前时间</p>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动商品:</label>
<div class="layui-input-block">
<table id="selected_goods_list"></table>
<button class="layui-btn" onclick="addGoods()">选择商品</button>
<span class="goods_num">已选商品(<span id="goods_num" class="text-color">0</span></span>
<input type="hidden" name="sku_ids" lay-verify="goods_ids">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动规则:</label>
<div class="layui-input-block">
<div class="layui-input-inline len-short">
<input type="number" name="price" value="" placeholder="" autocomplete="off" class="layui-input len-short" lay-verify="price">
</div>
<div class="layui-form-mid">元 任选</div>
<div class="layui-input-inline len-short">
<input type="number" name="num" value="" placeholder="" autocomplete="off" class="layui-input len-short" lay-verify="num">
</div>
<div class="layui-form-mid"></div>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">运费承担:</label>
<div class="layui-input-block">
<input type="radio" name="shipping_fee_type" value="0" title="卖家承担运费" checked>
<input type="radio" name="shipping_fee_type" value="1" title="买家承担运费(快递)">
</div>
</div>
<div class="form-row">
<button class="layui-btn" lay-submit lay-filter="save">提交</button>
<button class="layui-btn layui-btn-primary" onclick="backBaleList()">返回</button>
</div>
</div>
<script type="text/javascript">
var sku_list = [], selectedGoodsId = [], sku_id = [], form, laydate, currentDate = new Date(), minDate = "", repeat_flag = false;
layui.use(['form', 'laydate', 'laytpl'], function() {
form = layui.form,
laydate = layui.laydate;
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">');
laydate.render({
elem: '#end_time',
type: 'datetime',
min: minDate
});
}
renderTable(sku_list); // 初始化表格
/**
* 表单验证
*/
form.verify({
len: function(value) {
if (value.length > 25) {
return "活动名称最多为25个字符!";
}
},
time: function(value) {
var now_time = (new Date()).getTime();
var start_time = (new Date($("#start_time").val())).getTime();
var end_time = (new Date(value)).getTime();
if (now_time > end_time) {
return '结束时间不能小于当前时间!'
}
if (start_time > end_time) {
return '结束时间不能小于开始时间!';
}
},
goods_ids: function(value){
if (!/[\S]+/.test(value)) {
return '请选择活动商品';
}
},
num: function(value) {
if (!/[\S]+/.test(value)) {
return '请输入商品件数';
}
if (value <= 0) {
return '商品件数不能小于等于0!';
}
},
price: function(value) {
if (!/[\S]+/.test(value)) {
return '请输入活动金额';
}
if (value <= 0) {
return '活动金额不能小于等于0!';
}
}
});
/**
* 监听提交
*/
form.on('submit(save)', function(data) {
if (repeat_flag) return;
repeat_flag = true;
data.field.goods_ids = [];
sku_list.forEach(function(item){
if (jQuery.inArray(item.goods_id, data.field.goods_ids) == -1) {
data.field.goods_ids.push(item.goods_id)
}
});
data.field.goods_ids = data.field.goods_ids.toString();
$.ajax({
type: 'POST',
url: ns.url("bale://shop/bale/add"),
data: data.field,
dataType: 'JSON',
success: function (res) {
repeat_flag = false;
if (res.code == 0) {
layer.confirm('添加成功', {
title:'操作提示',
btn: ['返回列表', '继续添加'],
closeBtn: 0,
yes: function(index, layero) {
location.hash = ns.hash("bale://shop/bale/lists")
layer.close(index);
},
btn2: function(index, layero) {
listenerHash(); // 刷新页面
layer.close(index);
}
});
} else {
layer.msg(res.message);
}
}
});
});
});
/**
* 添加商品
*/
function addGoods() {
goodsSelect(function (data) {
sku_id = [];
sku_list = [];
for (var key in data) {
for (var sku in data[key].selected_sku_list) {
var item = data[key].selected_sku_list[sku];
sku_id.push(item.sku_id);
sku_list.push(item);
}
}
renderTable(sku_list);
$("input[name='sku_ids']").val(sku_id.toString());
selectedGoodsId = sku_id;
$("#goods_num").html(sku_list.length)
}, selectedGoodsId, {mode: "sku", is_virtual: 0});
}
function delRow(obj,id) {
for (var i = 0; i < sku_list.length; i++){
if (sku_list[i].sku_id == parseInt(id)){
sku_list.splice(i,1);
}
}
$("#goods_num").html(sku_list.length);
//删除选中的id
selectedGoodsId.splice(selectedGoodsId.indexOf(id),1);
$("input[name='sku_ids']").val(selectedGoodsId.toString());
$(obj).parents("tr").remove();
}
function backBaleList() {
location.hash = ns.hash("bale://shop/bale/lists");
}
function renderTable(sku_list) {
//展示已知数据
table = new Table({
elem: '#selected_goods_list',
cols: [
[{
field: 'sku_name',
title: '商品名称',
unresize: 'false',
width: '50%'
}, {
field: 'price',
title: '商品价格(元)',
unresize: 'false',
align: 'right',
width: '20%',
templet: function(data) {
return '¥' + data.price;
}
}, {
field: 'stock',
title: '库存',
unresize: 'false',
align: 'center',
width: '20%'
}, {
title: '操作',
toolbar: '#operation',
unresize: 'false',
align:'right'
}],
],
data: sku_list,
});
}
</script>
<script type="text/html" id="operation">
<div class="table-btn">
<a class="layui-btn" onclick="delRow(this,{{d.sku_id}})">删除</a>
</div>
</script>

View File

@@ -0,0 +1,84 @@
<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.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>{$info.price} 元任选 {$info.num} 件</span>
</div>
<div class="promotion-view-item">
<label>运费承担:</label>
<span>{if $info.shipping_fee_type == 0} 卖家承担运费 {else /} 卖家承担运费 {/if}</span>
</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">
<div class='promotion-view-list'>
<table id="promotion_list"></table>
</div>
</div>
</div>
<script type='text/html' id="promotion_list_item_box_html">
<div class="promotion-list-item-title">
<div class="promotion-list-item-title-icon">
<img src="{{ ns.img(d.sku_image) }}" alt="">
</div>
<p class="promotion-list-item-title-name multi-line-hiding">{{ d.sku_name }}</p>
</div>
</script>
<script>
var promotion_list = {:json_encode($info.sku_list, JSON_UNESCAPED_UNICODE)};
new Table({
elem: '#promotion_list',
cols: [
[{
field: 'sku_name',
title: '商品名称',
unresize: 'false',
width: '60%',
templet:'#promotion_list_item_box_html',
}, {
field: 'price',
title: '商品价格(元)',
unresize: 'false',
align: 'right',
width: '20%',
templet: function(data) {
return '¥' + data.price;
}
}, {
field: 'stock',
title: '库存',
unresize: 'false',
align: 'center',
width: '20%'
}],
],
data: promotion_list,
});
</script>

View File

@@ -0,0 +1,298 @@
<style type="text/css">
.goods_num {padding-left: 20px;}
</style>
<div class="layui-form form-wrap">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动名称:</label>
<div class="layui-input-block">
<input type="text" name="name" lay-verify="required|len" class="layui-input len-long" autocomplete="off" value="{$bale_info.name}" 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-input-block len-mid">
<input type="text" class="layui-input" name="start_time" lay-verify="required" id="start_time" autocomplete="off" readonly value="{:date('Y-m-d H:i:s', $bale_info.start_time)}" {if condition="$bale_info.status == 1"}disabled {/if}>
<i class=" iconrili iconfont calendar"></i>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>结束时间:</label>
<div class="layui-input-block len-mid end_time">
<input type="text" class="layui-input" name="end_time" lay-verify="required|time" id="end_time" autocomplete="off" readonly value="{:date('Y-m-d H:i:s', $bale_info.end_time)}" >
<i class=" iconrili iconfont calendar"></i>
</div>
<div class="word-aux">
<p>结束时间不能小于开始时间,也不能小于当前时间</p>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动商品:</label>
<div class="layui-input-block">
<table id="selected_goods_list"></table>
<button class="layui-btn" onclick="addGoods()">选择商品</button> <span class="goods_num">已选商品(<span id="goods_num" class="text-color">{$bale_info.sku_list_count}</span></span>
<input type="hidden" name="sku_ids" lay-verify="goods_ids">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动规则:</label>
<div class="layui-input-block">
<div class="layui-input-inline len-short">
<input type="number" name="price" value="{$bale_info.price}" placeholder="" autocomplete="off" class="layui-input len-short" lay-verify="price">
</div>
<div class="layui-form-mid">元 任选</div>
<div class="layui-input-inline len-short">
<input type="number" name="num" value="{$bale_info.num}" placeholder="" autocomplete="off" class="layui-input len-short" lay-verify="num">
</div>
<div class="layui-form-mid"></div>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">运费承担:</label>
<div class="layui-input-block">
<input type="radio" name="shipping_fee_type" value="0" title="卖家承担运费" {$bale_info.shipping_fee_type == 0 ? 'checked' : ''}>
<input type="radio" name="shipping_fee_type" value="1" title="买家承担运费(快递)" {$bale_info.shipping_fee_type == 1 ? 'checked' : ''}>
</div>
</div>
<input type="hidden" name="bale_id" value="{$bale_info.bale_id}">
<div class="form-row">
<button class="layui-btn" lay-submit lay-filter="save">提交</button>
<button class="layui-btn layui-btn-primary" onclick="backBaleList()">返回</button>
</div>
</div>
<script type="text/javascript">
var selectedGoodsId = [], sku_id = [], form, laydate, currentDate = new Date(), minDate = "", repeat_flag = false;
var sku_list = {:json_encode($bale_info.sku_list, JSON_UNESCAPED_UNICODE)};
//初始化商品
$.each(sku_list, function(index, item) {
var id = item.goods_id;
var sku = item.sku_id;
selectedGoodsId.push(sku);
sku_id.push(sku);
});
$("input[name='sku_ids']").val(sku_id.toString());
renderTable(sku_list); // 初始化表格
layui.use(['form', 'laydate', 'laytpl'], function() {
form = layui.form,
laydate = layui.laydate;
form.render();
currentDate.setDate(currentDate.getDate() + 30); //当前时间+30之后的时间戳
// 开始时间
laydate.render({
elem: '#start_time' ,//指定元素
type: 'datetime',
});
//结束时间
laydate.render({
elem: '#end_time' ,//指定元素
type: 'datetime'
});
/**
* 重新渲染结束时间
* */
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">');
laydate.render({
elem: '#end_time',
type: 'datetime',
min: minDate
});
}
/**
* 表单验证
*/
form.verify({
len: function(value) {
if (value.length > 25) {
return "活动名称最多为25个字符!";
}
},
time: function(value) {
var now_time = (new Date()).getTime();
var start_time = (new Date($("#start_time").val())).getTime();
var end_time = (new Date(value)).getTime();
if (now_time > end_time) {
return '结束时间不能小于当前时间!'
}
if (start_time > end_time) {
return '结束时间不能小于开始时间!';
}
},
goods_ids: function(value){
if (!/[\S]+/.test(value)) {
return '请选择活动商品';
}
},
num: function(value) {
if (!/[\S]+/.test(value)) {
return '请输入商品件数';
}
if (value <= 0) {
return '商品件数不能小于等于0!';
}
},
price: function(value) {
if (!/[\S]+/.test(value)) {
return '请输入活动金额';
}
if (value <= 0) {
return '活动金额不能小于等于0!';
}
}
});
/**
* 监听提交
*/
form.on('submit(save)', function(data) {
if (repeat_flag) return;
repeat_flag = true;
data.field.goods_ids = [];
sku_list.forEach(function(item){
if (jQuery.inArray(item.goods_id, data.field.goods_ids) == -1) {
data.field.goods_ids.push(item.goods_id)
}
});
data.field.goods_ids = data.field.goods_ids.toString();
$.ajax({
type: 'POST',
url: ns.url("bale://shop/bale/edit"),
data: data.field,
dataType: 'JSON',
success: function (res) {
repeat_flag = false;
if (res.code == 0) {
layer.confirm('编辑成功', {
title:'操作提示',
btn: ['返回列表', '继续编辑'],
yes: function(index, layero) {
location.hash = ns.hash("bale://shop/bale/lists")
layer.close(index);
},
btn2: function(index, layero) {
layer.close(index);
}
});
} else {
layer.msg(res.message);
}
}
});
});
});
/**
* 添加商品
*/
function addGoods(){
goodsSelect(function (data) {
sku_id = [];
sku_list = [];
for (var key in data) {
for (var sku in data[key].selected_sku_list) {
var item = data[key].selected_sku_list[sku];
sku_id.push(item.sku_id);
sku_list.push(item);
}
}
renderTable(sku_list);
$("input[name='sku_ids']").val(sku_id.toString());
selectedGoodsId = sku_id;
$("#goods_num").html(sku_list.length)
}, selectedGoodsId, {mode: "sku", is_virtual: 0});
}
function delRow(obj,id) {
var i, j;
$.each(sku_list, function(index, item) {
var sku_id = item.sku_id;
if (id == sku_id) {
i = index;
}
});
sku_list.splice(i, 1);
renderTable(sku_list);
$.each(selectedGoodsId, function(index, item) {
if (id == item) {
j = index;
}
});
selectedGoodsId.splice(j, 1);
sku_id = selectedGoodsId;
$("#goods_num").html(sku_list.length);
$("input[name='sku_ids']").val(sku_id.toString());
}
function backBaleList() {
location.hash = ns.hash("bale://shop/bale/lists");
}
function renderTable(sku_list) {
//展示已知数据
table = new Table({
elem: '#selected_goods_list',
cols: [
[{
field: 'sku_name',
title: '商品名称',
unresize: 'false',
width: '50%'
}, {
field: 'price',
title: '商品价格(元)',
unresize: 'false',
align: 'right',
width: '20%',
templet: function(data) {
return '¥' + data.price;
}
}, {
field: 'stock',
title: '库存',
unresize: 'false',
align: 'center',
width: '20%'
}, {
title: '操作',
toolbar: '#operation',
unresize: 'false',
align:'right'
}],
],
data: sku_list,
});
}
</script>
<script type="text/html" id="operation">
<div class="table-btn">
<a class="layui-btn" onclick="delRow(this,{{d.sku_id}})">删除</a>
</div>
</script>

View File

@@ -0,0 +1,359 @@
<style>
.screen .layui-colla-content .goods-category-container .layui-input{width: 240px !important;}
.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="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="activity_tab">
<ul class="layui-tab-title">
<li class="layui-this" lay-id="">全部</li>
<li lay-id="0">未开始</li>
<li lay-id="1">进行中</li>
<li lay-id="2">已结束</li>
</ul>
<div class="layui-tab-content">
<!-- 列表 -->
<table id="activity_list" lay-filter="activity_list"></table>
</div>
</div>
<!--时间-->
<script type="text/html" id="time">
<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="toolbarAction">
<button class="layui-btn layui-btn-primary" lay-event="delete">批量删除</button>
<button class="layui-btn layui-btn-primary" lay-event="close">批量关闭</button>
</script>
<!-- 操作 -->
<script type="text/html" id="operation">
<div class="table-btn">
{{# if(d.status == 1){ }}
<a class="layui-btn text-color" lay-event="select">推广</a>
{{# } }}
<a class="layui-btn" lay-event="detail">详情</a>
<a class="layui-btn" lay-event="edit">编辑</a>
{{# if(d.status == 1){ }}
<a class="layui-btn" lay-event="cole">关闭</a>
{{# } }}
{{# if(d.status == 2){ }}
<a class="layui-btn" lay-event="del">删除</a>
{{# } }}
</div>
</script>
<!-- 推广 -->
{include file="app/shop/view/component/promote_show.html"}
<script>
layui.use(['form','laytpl','element','laydate'], function() {
var table,
laytpl = layui.laytpl,
form = layui.form,
laydate = layui.laydate,
element = layui.element,
repeat_flag = false; //防重复标识
form.render();
element.on('tab(activity_tab)', function () {
table.reload({
page: {
curr: 1
},
where: {
'status': this.getAttribute('lay-id')
}
});
});
table = new Table({
elem: '#activity_list',
url: ns.url("bale://shop/bale/lists"),
cols: [
[{
type: 'checkbox',
width: '3%',
},{
field: 'name',
title: '名称',
unresize: 'false',
width: '22%'
}, {
title: '活动规则',
unresize: 'false',
width: '12%',
templet: function (data) {
return data.price + '元' + data.num + '件';
}
}, {
title: '活动时间',
unresize: 'false',
width: '27%',
templet: '#time'
}, {
title: '状态',
unresize: 'false',
width: '10%',
templet: function (data) {
if (data.status == 0) {
return '未开始';
} else if (data.status == 1) {
return '进行中';
} else {
return '已结束';
}
}
}, {
field: 'update_time',
title: '创建时间',
unresize: 'false',
width: '17%',
templet: function (data) {
return ns.time_to_date(data.create_time);
}
}, {
title: '操作',
toolbar: '#operation',
unresize: 'false',
align: 'right'
}]
],
toolbar: '#toolbarAction'
});
// 监听工具栏操作
table.toolbar(function (obj) {
var data = obj.data;
if(data.length <= 0) return;
var baleIdAll = [];
for (var i in data){
baleIdAll.push(data[i].bale_id);
}
switch (obj.event) {
case 'delete':
deleteBaleAll(baleIdAll)
break;
case 'close':
closeBaleAll(baleIdAll)
break;
}
})
function deleteBaleAll(data){
layer.confirm('确定要删除活动吗?', function (index) {
if (repeat_flag) return false;
repeat_flag = true;
layer.close(index);
$.ajax({
url: ns.url("bale://shop/bale/deleteAll"),
data: {
"bale_id": data
},
dataType: 'JSON',
type: 'POST',
success: function (res) {
layer.msg(res.message);
repeat_flag = false;
table.reload({
page: {
curr: 1
},
});
}
});
}, function () {
layer.close();
repeat_flag = false;
});
}
function closeBaleAll(data){
layer.confirm('确定要关闭活动吗?', function (index) {
if (repeat_flag) return false;
repeat_flag = true;
layer.close(index);
$.ajax({
url: ns.url("bale://shop/bale/closeBaleAll"),
data: {
"bale_id": data
},
dataType: 'JSON',
type: 'POST',
success: function (res) {
layer.msg(res.message);
repeat_flag = false;
if (res.code == 0) {
table.reload();
}
}
});
}, function () {
layer.close();
repeat_flag = false;
});
}
/**
* 监听工具栏操作
*/
table.tool(function (obj) {
var data = obj.data;
switch (obj.event) {
case 'select': //推广
baleUrl(data);
break;
case 'detail': //详情
location.hash = ns.hash("bale://shop/bale/detail", {"bale_id": data.bale_id});
break;
case 'edit': //编辑
location.hash = ns.hash("bale://shop/bale/edit", {"bale_id": data.bale_id});
break;
case 'cole':
coleBale(data.bale_id);
break;
case 'del': //删除
deleteBale(data.bale_id);
break;
}
});
//开始时间
laydate.render({
elem: '#start_time',//指定元素
type: 'datetime'
});
//结束时间
laydate.render({
elem: '#end_time', //指定元素
type: 'datetime'
});
/**
* 删除
*/
function deleteBale(id) {
layer.confirm('确定要删除该活动吗?', function (index) {
if (repeat_flag) return false;
repeat_flag = true;
layer.close(index);
$.ajax({
url: ns.url("bale://shop/bale/delete"),
data: {
"id": 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;
});
}
/**
* 搜索功能
*/
form.on('submit(search)', function (data) {
table.reload({
page: {
curr: 1
},
where: data.field
});
});
function baleUrl(data){
new PromoteShow({
url:ns.url("bale://shop/bale/baleUrl"),
param:{bale_id:data.bale_id},
})
}
function coleBale(id) {
layer.confirm('确定要关闭该活动吗?', function (index) {
if (repeat_flag) return false;
repeat_flag = true;
layer.close(index);
$.ajax({
url: ns.url("bale://shop/bale/closeBale"),
data: {
"id": id
},
dataType: 'JSON',
type: 'POST',
success: function (res) {
layer.msg(res.message);
repeat_flag = false;
if (res.code == 0) {
table.reload();
}
}
});
}, function () {
layer.close();
repeat_flag = false;
});
}
});
function add() {
location.hash = ns.hash("bale://shop/bale/add");
}
</script>