初始上传
This commit is contained in:
205
addon/bale/shop/controller/Bale.php
Executable file
205
addon/bale/shop/controller/Bale.php
Executable 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;
|
||||
}
|
||||
}
|
||||
}
|
||||
283
addon/bale/shop/view/bale/add.html
Executable file
283
addon/bale/shop/view/bale/add.html
Executable 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>
|
||||
84
addon/bale/shop/view/bale/detail.html
Executable file
84
addon/bale/shop/view/bale/detail.html
Executable 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>
|
||||
298
addon/bale/shop/view/bale/edit.html
Executable file
298
addon/bale/shop/view/bale/edit.html
Executable 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>
|
||||
359
addon/bale/shop/view/bale/lists.html
Executable file
359
addon/bale/shop/view/bale/lists.html
Executable 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>
|
||||
Reference in New Issue
Block a user