初始上传
This commit is contained in:
147
addon/bundling/shop/controller/Bundling.php
Executable file
147
addon/bundling/shop/controller/Bundling.php
Executable file
@@ -0,0 +1,147 @@
|
||||
<?php
|
||||
/**
|
||||
* Niushop商城系统 - 团队十年电商经验汇集巨献!
|
||||
* =========================================================
|
||||
* Copy right 2019-2029 杭州牛之云科技有限公司, 保留所有权利。
|
||||
* ----------------------------------------------
|
||||
* 官方网址: https://www.niushop.com
|
||||
* =========================================================
|
||||
*/
|
||||
|
||||
namespace addon\bundling\shop\controller;
|
||||
|
||||
use app\shop\controller\BaseShop;
|
||||
use addon\bundling\model\Bundling as BundlingModel;
|
||||
|
||||
/**
|
||||
* 优惠套餐
|
||||
* @author Administrator
|
||||
*
|
||||
*/
|
||||
class Bundling extends BaseShop
|
||||
{
|
||||
/**
|
||||
* 添加优惠套餐
|
||||
*/
|
||||
public function add()
|
||||
{
|
||||
if (request()->isJson()) {
|
||||
$data = [
|
||||
'site_id' => $this->site_id,
|
||||
'bl_name' => input('bl_name', ''),//组合名称
|
||||
'bl_price' => input('bl_price', ''),//商品组合价格
|
||||
'shipping_fee_type' => input('shipping_fee_type', ''),//运费承担方式 1卖家承担运费 2买家承担运费
|
||||
'status' => input('status', ''),//是否上下架
|
||||
];
|
||||
$sku_ids = input('sku_ids', '');
|
||||
$bundling_model = new BundlingModel();
|
||||
$res = $bundling_model->addBundling($data, $sku_ids);
|
||||
return $res;
|
||||
} else {
|
||||
return $this->fetch('bundling/add');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 编辑优惠套餐
|
||||
*/
|
||||
public function edit()
|
||||
{
|
||||
$bl_id = input('bl_id', 0);
|
||||
$bundling_model = new BundlingModel();
|
||||
if (request()->isJson()) {
|
||||
$data = [
|
||||
'bl_name' => input('bl_name', ''),//组合名称
|
||||
'bl_price' => input('bl_price', ''),//商品组合价格
|
||||
'shipping_fee_type' => input('shipping_fee_type', ''),//运费承担方式 1卖家承担运费 2买家承担运费
|
||||
'status' => input('status', ''),//最大领取数量
|
||||
];
|
||||
$sku_ids = input('sku_ids', '');
|
||||
$condition = array (
|
||||
['bl_id', '=', $bl_id ],
|
||||
['site_id', '=', $this->site_id ]
|
||||
);
|
||||
$res = $bundling_model->editBundling($data, $sku_ids, $condition);
|
||||
return $res;
|
||||
} else {
|
||||
$condition = [ [ 'bl_id', '=', $bl_id ], [ 'site_id', '=', $this->site_id ] ];
|
||||
$info_result = $bundling_model->getBundlingDetail($condition);
|
||||
$info = $info_result['data'];
|
||||
if (empty($info)) $this->error('未获取到活动数据', href_url('bundling://shop/bundling/lists'));
|
||||
$this->assign('info', $info);
|
||||
$this->assign('bl_id', $bl_id);
|
||||
return $this->fetch('bundling/edit');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 优惠套餐详情
|
||||
*/
|
||||
public function detail()
|
||||
{
|
||||
$bundling_id = input('bl_id', '');
|
||||
$bundling_model = new BundlingModel();
|
||||
$condition = [ [ 'bl_id', '=', $bundling_id ], [ 'site_id', '=', $this->site_id ] ];
|
||||
$info = $bundling_model->getBundlingDetail($condition)[ 'data' ] ?? [];
|
||||
if (empty($info)) $this->error('未获取到活动数据', href_url('bundling://shop/bundling/lists'));
|
||||
$this->assign('info', $info);
|
||||
return $this->fetch('bundling/detail');
|
||||
}
|
||||
|
||||
/**
|
||||
* 优惠套餐列表
|
||||
*/
|
||||
public function lists()
|
||||
{
|
||||
if (request()->isJson()) {
|
||||
$page = input('page', 1);
|
||||
$page_size = input('page_size', PAGE_LIST_ROWS);
|
||||
$bl_name = input('bl_name', '');
|
||||
$status = input('status', '');
|
||||
|
||||
$condition = [];
|
||||
if ($status !== '') {
|
||||
$condition[] = [ 'status', '=', $status ];
|
||||
}
|
||||
$condition[] = [ 'site_id', '=', $this->site_id ];
|
||||
$condition[] = [ 'bl_name', 'like', '%' . $bl_name . '%' ];
|
||||
$order = 'update_time desc';
|
||||
$field = '*';
|
||||
|
||||
$bundling_model = new BundlingModel();
|
||||
$res = $bundling_model->getBundlingPageList($condition, $page, $page_size, $order, $field);
|
||||
return $res;
|
||||
} else {
|
||||
return $this->fetch('bundling/lists');
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除优惠套餐
|
||||
*/
|
||||
public function delete()
|
||||
{
|
||||
if (request()->isJson()) {
|
||||
$bl_id = input('bl_id', 0);
|
||||
$bundling_model = new BundlingModel();
|
||||
$res = $bundling_model->deleteBundling($bl_id, $this->site_id);
|
||||
return $res;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除优惠套餐
|
||||
*/
|
||||
public function deleteAll()
|
||||
{
|
||||
if (request()->isJson()) {
|
||||
$bl_id = input('bl_id', 0);
|
||||
$bundling_model = new BundlingModel();
|
||||
foreach ($bl_id as $k => $v){
|
||||
$res = $bundling_model->deleteBundling($v, $this->site_id);
|
||||
}
|
||||
return $res;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
316
addon/bundling/shop/view/bundling/add.html
Executable file
316
addon/bundling/shop/view/bundling/add.html
Executable file
@@ -0,0 +1,316 @@
|
||||
<style>
|
||||
#goods thead th{ background-color: #f7f7f7;}
|
||||
/* 优惠商品 */
|
||||
.goods-title{display: flex;align-items: center;}
|
||||
.goods-title .goods-img{display: flex;align-items: center;justify-content: center;width: 55px;height: 55px;margin-right: 5px;}
|
||||
.goods-title .goods-img img{max-height: 100%;max-width: 100%;}
|
||||
.goods-title .goods-name{flex: 1;line-height: 1.6;}
|
||||
.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="bl_name" lay-verify="required" autocomplete="off" class="layui-input len-long" maxlength="40">
|
||||
</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 class="layui-table" id="goods" lay-skin="line" lay-size="lg">
|
||||
<colgroup>
|
||||
<col width="45%">
|
||||
<col width="20%">
|
||||
<col width="20%">
|
||||
<col width="15%">
|
||||
</colgroup>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>商品名称</th>
|
||||
<th>价格</th>
|
||||
<th>库存</th>
|
||||
<th class="operation">操作</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr class="goods-empty">
|
||||
<td colspan="4">
|
||||
<div>未添加商品</div>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<button class="layui-btn" onclick="selectGoods()">选择商品</button> <span class="goods_num">已选商品(<span id="goods_num" class="text-color">0</span>)</span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">优惠套餐价格:</label>
|
||||
<div class="layui-input-block">
|
||||
<div class="layui-input-inline">
|
||||
<input type="number" name="bl_price" autocomplete="off" class="layui-input combined-price len-short" value="0.00" step="1" min="0.00" >
|
||||
</div>
|
||||
<span class="layui-form-mid">元</span>
|
||||
</div>
|
||||
<div class="word-aux">
|
||||
<p>价格不能小于0,可保留两位小数</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">原价:</label>
|
||||
<div class="layui-input-block">
|
||||
<p class="input-text"><span class="original-price">0.00</span>元</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">节省价:</label>
|
||||
<div class="layui-input-block">
|
||||
<p class="input-text"><span class="save-prices">0.00</span>元</p>
|
||||
</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="1" title="卖家承担运费" checked>
|
||||
<input type="radio" name="shipping_fee_type" value="2" title="买家承担运费(快递)">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">是否上下架:</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="checkbox" name="status" lay-filter="isOpen" value="1" lay-skin="switch" checked />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-row">
|
||||
<button class="layui-btn" lay-submit lay-filter="save">保存</button>
|
||||
<button class="layui-btn layui-btn-primary" onclick="backBundlingList()">返回</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script>
|
||||
var form, selectGoodsSkuId = [];
|
||||
layui.use("form", function() {
|
||||
form = layui.form;
|
||||
var repeat_flag = false; //防重复标识
|
||||
|
||||
/**
|
||||
* 监听提交
|
||||
*/
|
||||
form.on('submit(save)', function(data) {
|
||||
|
||||
var num = $("#goods").find("tbody tr").length;
|
||||
var combinedPrice = $('.combined-price').val(),
|
||||
originalPrice = Number($(".original-price").text());
|
||||
if (num < 2) { //判断提交时商品数量是否在2-6之间
|
||||
layer.msg("商品数不可小于2个!", {
|
||||
icon: 5
|
||||
});
|
||||
return;
|
||||
}
|
||||
|
||||
if (data.field.status == undefined) {
|
||||
data.field.status = 0;
|
||||
}
|
||||
|
||||
if(combinedPrice > originalPrice){
|
||||
layer.msg("组合套餐价格不能高于原价");
|
||||
$(".save-prices").text(0).focus();
|
||||
return false
|
||||
}
|
||||
|
||||
data.field.sku_ids = selectGoodsSkuId.toString();
|
||||
|
||||
if (repeat_flag) return;
|
||||
repeat_flag = true;
|
||||
|
||||
$.ajax({
|
||||
type: 'POST',
|
||||
dataType: 'JSON',
|
||||
url: ns.url("bundling://shop/bundling/add"),
|
||||
data: data.field,
|
||||
async: false,
|
||||
success: function(res) {
|
||||
repeat_flag = false;
|
||||
if (res.code == 0) {
|
||||
layer.confirm('添加成功', {
|
||||
title: '操作提示',
|
||||
btn: ['返回列表', '继续添加'],
|
||||
closeBtn: 0,
|
||||
yes: function(index, layero) {
|
||||
location.hash = ns.hash("bundling://shop/bundling/lists");
|
||||
layer.close(index);
|
||||
},
|
||||
btn2: function(index, layero) {
|
||||
listenerHash(); // 刷新页面
|
||||
layer.close(index);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
layer.msg(res.message);
|
||||
}
|
||||
}
|
||||
})
|
||||
});
|
||||
|
||||
form.verify({
|
||||
flo: function(value) {
|
||||
if (value == '') {
|
||||
return;
|
||||
}
|
||||
var reg = /^(0|[1-9]\d*)(\s|$|\.\d{1,2}\b)/;
|
||||
if (!reg.test(value)) {
|
||||
return '价格不能小于0,可保留两位小数!'
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
/**
|
||||
* 添加商品
|
||||
*/
|
||||
function selectGoods() {
|
||||
goodsSelect(function (data) {
|
||||
selectGoodsSkuId = [];
|
||||
var html = '';
|
||||
if(Object.values(data).length > 0){
|
||||
for (var key in data) {
|
||||
for (var sku in data[key].selected_sku_list) {
|
||||
var item = data[key].selected_sku_list[sku];
|
||||
html += `<tr data-sku_id="${item.sku_id}">`;
|
||||
html += `
|
||||
<td>
|
||||
<div class="goods-title">
|
||||
<div class="goods-img">
|
||||
<img layer-src src="${item.sku_image ? ns.img(item.sku_image) : ''}" alt="">
|
||||
</div>
|
||||
<p class="multi-line-hiding goods-name">${item.sku_name}</p>
|
||||
</div>
|
||||
</td>
|
||||
`;
|
||||
html += `<td class='price-one'>${item.price }</td>`;
|
||||
html += `<td>${item.stock}</td>`;
|
||||
html += `<td class='operation'> <div class='table-btn '><a href='javascript:;' class='layui-btn' onclick='deleteGoods(this)'>删除商品</a></div></td>`;
|
||||
html += `</tr>`;
|
||||
selectGoodsSkuId.push(item.sku_id);
|
||||
}
|
||||
}
|
||||
}else{
|
||||
html += `<tr class="goods-empty">
|
||||
<td colspan="4">
|
||||
<div>未添加商品</div>
|
||||
</td>
|
||||
</tr>`;
|
||||
}
|
||||
$("#goods tbody").html(html);
|
||||
$("#goods_num").text(selectGoodsSkuId.length);
|
||||
priceCount();
|
||||
}, selectGoodsSkuId, {mode: "sku", max_num: 0, min_num: 2});
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除商品
|
||||
*/
|
||||
function deleteGoods(data) {
|
||||
var obj = $(data).parent().parent().parent();
|
||||
$(obj).remove();
|
||||
priceCount(); //计算出当前总价格
|
||||
for (var i in selectGoodsSkuId) {
|
||||
if (selectGoodsSkuId[i] == Number($(obj).attr("data-sku_id"))) {
|
||||
selectGoodsSkuId.splice(i, 1);
|
||||
}
|
||||
}
|
||||
$("#goods_num").html(selectGoodsSkuId.length)
|
||||
|
||||
if(selectGoodsSkuId.length) $('.goods-empty').hide();
|
||||
else $('.goods-empty').show();
|
||||
}
|
||||
|
||||
/**
|
||||
* 计算总价
|
||||
*/
|
||||
function priceCount() {
|
||||
var price_count = 0;
|
||||
$("#goods").find("tbody td.price-one").each(function(i) {
|
||||
var price_one = Number($(this).text());
|
||||
price_count += price_one;
|
||||
});
|
||||
$(".original-price").text(price_count.toFixed(2));
|
||||
$(".save-prices").text(0);
|
||||
$(".combined-price").val(price_count.toFixed(2));
|
||||
|
||||
if (price_count == 0) {
|
||||
$('.goods-empty').show();
|
||||
}
|
||||
}
|
||||
|
||||
$("#bl_price").blur(function() {
|
||||
var bl_price = $(this).val();
|
||||
|
||||
if (bl_price < 0) {
|
||||
layer.msg("价格不能小于0,可保留两位小数");
|
||||
}else{
|
||||
var originalPrice = Number($(".original-price").text());
|
||||
if (bl_price > originalPrice) {
|
||||
$(this).val(originalPrice);
|
||||
layer.msg("优惠套餐价格不能高于原价");
|
||||
$(".save-prices").text(0);
|
||||
} else {
|
||||
var num = accSub(originalPrice, bl_price);
|
||||
$(".save-prices").text(num);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
/**
|
||||
* 计算组合套餐价格、原价、节省价
|
||||
*/
|
||||
// $(".combined-price").blur(function() {
|
||||
// var combinedPrice = $(this).val(),
|
||||
// originalPrice = Number($(".original-price").text());
|
||||
|
||||
// if (combinedPrice > originalPrice) {
|
||||
// $(this).val(originalPrice);
|
||||
// layer.msg("优惠套餐价格不能高于原价");
|
||||
// $(".save-prices").text(0);
|
||||
// } else {
|
||||
// var num = accSub(originalPrice, combinedPrice);
|
||||
// $(".save-prices").text(num);
|
||||
// }
|
||||
// });
|
||||
|
||||
// 两个浮点数相减
|
||||
function accSub(num1, num2){
|
||||
var r1, r2, m;
|
||||
|
||||
try{
|
||||
r1 = num1.toString().split(".")[1].length;
|
||||
}catch(e){
|
||||
r1 = 0;
|
||||
}
|
||||
|
||||
try{
|
||||
r2 = num2.toString().split(".")[1].length;
|
||||
}catch(e){
|
||||
r2 = 0;
|
||||
}
|
||||
|
||||
m = Math.pow(10, Math.max(r1, r2));
|
||||
n = (r1 >= r2) ? r1 : r2;
|
||||
return (Math.round(num1 * m - num2 * m) / m).toFixed(2);
|
||||
}
|
||||
|
||||
//返回按钮
|
||||
function backBundlingList() {
|
||||
location.hash = ns.hash("bundling://shop/bundling/lists");
|
||||
}
|
||||
</script>
|
||||
83
addon/bundling/shop/view/bundling/detail.html
Executable file
83
addon/bundling/shop/view/bundling/detail.html
Executable file
@@ -0,0 +1,83 @@
|
||||
<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.bl_name}</span>
|
||||
</div>
|
||||
<div class="promotion-view-item">
|
||||
<label>活动状态:</label>
|
||||
<span>{$info.status == 1 ? '开启' : '关闭'}</span>
|
||||
</div>
|
||||
<div class="promotion-view-item">
|
||||
<label>套餐价格:</label>
|
||||
<span>¥{$info.bl_price}</span>
|
||||
</div>
|
||||
<div class="promotion-view-item">
|
||||
<label>原价:</label>
|
||||
<span>¥{$info.goods_money}</span>
|
||||
</div>
|
||||
<div class="promotion-view-item">
|
||||
<label>节省价:</label>
|
||||
<span>¥{$info.goods_money - $info.bl_price}</span>
|
||||
</div>
|
||||
<div class="promotion-view-item">
|
||||
<label>运费承担:</label>
|
||||
<span>{$info.shipping_fee_type == 1 ? '卖家承担运费' : '买家承担运费(快递)'}</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 list = {:json_encode($info.bundling_goods, JSON_UNESCAPED_UNICODE)};
|
||||
layui.use('form', function() {
|
||||
new Table({
|
||||
elem: '#promotion_list',
|
||||
cols: [
|
||||
[{
|
||||
field: 'sku_name',
|
||||
title: '商品名称',
|
||||
width: '40%',
|
||||
unresize: 'false',
|
||||
templet: "#promotion_list_item_box_html"
|
||||
}, {
|
||||
field: 'price',
|
||||
title: '商品价格',
|
||||
unresize: 'false',
|
||||
width: '30%',
|
||||
}, {
|
||||
field: 'stock',
|
||||
title: '库存',
|
||||
unresize: 'false',
|
||||
width: '10%',
|
||||
}]
|
||||
],
|
||||
data: list
|
||||
});
|
||||
});
|
||||
</script>
|
||||
357
addon/bundling/shop/view/bundling/edit.html
Executable file
357
addon/bundling/shop/view/bundling/edit.html
Executable file
@@ -0,0 +1,357 @@
|
||||
<style>
|
||||
#goods thead th{ background-color: #f7f7f7;}
|
||||
/* 优惠商品 */
|
||||
.goods-empty { width: 100%; display: flex; justify-content: center; align-items: center; }
|
||||
.goods-title{display: flex;align-items: center;}
|
||||
.goods-title .goods-img{display: flex;align-items: center;justify-content: center;width: 55px;height: 55px;margin-right: 5px;}
|
||||
.goods-title .goods-img img{max-height: 100%;max-width: 100%;}
|
||||
.goods-title .goods-name{flex: 1;line-height: 1.6;}
|
||||
.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="bl_name" value="{$info.bl_name}" lay-verify="required" autocomplete="off" placeholder="请输入活动名称" class="layui-input len-long" maxlength="40">
|
||||
</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 class="layui-table" id="goods" lay-skin="line" lay-size="lg">
|
||||
<colgroup>
|
||||
<col width="45%">
|
||||
<col width="20%">
|
||||
<col width="20%">
|
||||
<col width="15%">
|
||||
</colgroup>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>商品名称</th>
|
||||
<th>价格</th>
|
||||
<th>库存</th>
|
||||
<th class="operation">操作</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
{if condition="$info.bundling_goods"}
|
||||
{foreach name=$info.bundling_goods as $k => $v}
|
||||
<tr data-sku_id="{$v.sku_id}">
|
||||
<td>
|
||||
<div class="goods-title">
|
||||
<div class="goods-img">
|
||||
{if condition="$v.sku_image"}
|
||||
<img layer-src src="{:img($v.sku_image)}" alt="">
|
||||
{else/}
|
||||
<img layer-src src="" alt="">
|
||||
{/if}
|
||||
</div>
|
||||
<p class="multi-line-hiding goods-name">{$v.sku_name}</p>
|
||||
</div>
|
||||
</td>
|
||||
<td class="price-one">{$v.price}</td>
|
||||
<td>{$v.stock}</td>
|
||||
<td class="operation">
|
||||
<div class="table-btn">
|
||||
<a href="javascript:;" class="layui-btn" onclick="deleteGoods(this)">删除商品</a>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
{/foreach}
|
||||
{/if}
|
||||
<tr class="goods-empty" {notempty name="$info.bundling_goods"}style="display:none;"{/notempty}>
|
||||
<td colspan="4">
|
||||
<div>未添加商品</div>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<button class="layui-btn" onclick="selectGoods()">选择商品</button> <span class="goods_num">已选商品(<span id="goods_num" class="text-color">{$info.bundling_goods_count}</span>)</span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">套餐价格:</label>
|
||||
<div class="layui-input-block form-row">
|
||||
<div class="layui-input-inline">
|
||||
<input type="number" name="bl_price" lay-verify="flo" value="{$info.bl_price}" autocomplete="off" class="layui-input combined-price" min="0.00">
|
||||
</div>
|
||||
<span class="layui-form-mid">元</span>
|
||||
</div>
|
||||
<div class="word-aux">
|
||||
<p>价格不能小于0,可保留两位小数</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">原价:</label>
|
||||
<div class="layui-input-block">
|
||||
<p class="input-text"><span class="original-price">{$info.goods_money}</span>元</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">节省价:</label>
|
||||
<div class="layui-input-block">
|
||||
<p class="input-text"><span class="save-prices"></span>元</p>
|
||||
</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="1" title="卖家承担运费" {$info.shipping_fee_type == 1 ? 'checked' : ''}>
|
||||
<input type="radio" name="shipping_fee_type" value="2" title="买家承担运费(快递)" {$info.shipping_fee_type == 2 ? 'checked' : ''}>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">是否上下架:</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="checkbox" name="status" lay-filter="isOpen" value="1" lay-skin="switch" {if $info.status==1}checked{/if} />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-row">
|
||||
<button class="layui-btn" lay-submit lay-filter="save">保存</button>
|
||||
<button class="layui-btn layui-btn-primary" onclick="backBundlingList()">返回</button>
|
||||
</div>
|
||||
|
||||
<input type="hidden" name="bl_id" value="{$bl_id}" />
|
||||
</div>
|
||||
|
||||
<script>
|
||||
var priceAll = $(".original-price").text();
|
||||
var priceBl = $("input[name=bl_price]").val();
|
||||
$(".save-prices").text((parseFloat(priceAll) - parseFloat(priceBl)).toFixed(2)); //优惠价
|
||||
var table, form, selectGoodsSkuId = [];
|
||||
|
||||
$("#goods").find("tbody tr").each(function (i) {
|
||||
var id = $(this).attr("data-sku_id");
|
||||
if(id) selectGoodsSkuId.push(parseInt(id));
|
||||
});
|
||||
|
||||
layui.use(['form'], function() {
|
||||
form = layui.form;
|
||||
var repeat_flag = false; //防重复标识
|
||||
|
||||
table = new Table({
|
||||
elem: '#goods_list',
|
||||
url: ns.url("bundling://shop/bundling/lists"),
|
||||
cols: [
|
||||
[{
|
||||
unresize: 'false',
|
||||
width: '8%',
|
||||
templet: '#checkbox'
|
||||
}, {
|
||||
title: '商品',
|
||||
unresize: 'false',
|
||||
width: '37%',
|
||||
templet: '#goodIntro'
|
||||
}, {
|
||||
field: 'stock',
|
||||
title: '商品库存',
|
||||
unresize: 'false',
|
||||
width: '15%'
|
||||
}, {
|
||||
field: 'goods_class_name',
|
||||
title: '商品类型',
|
||||
unresize: 'false',
|
||||
width: '12%'
|
||||
}, {
|
||||
field: 'goods_state_name',
|
||||
title: '状态',
|
||||
unresize: 'false',
|
||||
width: '8%'
|
||||
}, {
|
||||
field: 'create_time',
|
||||
title: '创建时间',
|
||||
unresize: 'false',
|
||||
width: '20%',
|
||||
align: 'right',
|
||||
templet: function (data) {
|
||||
return ns.time_to_date(data.create_time);
|
||||
}
|
||||
}]
|
||||
]
|
||||
});
|
||||
|
||||
/**
|
||||
* 监听提交
|
||||
*/
|
||||
form.on('submit(save)', function(data) {
|
||||
var num = $("#goods").find("tbody tr").length;
|
||||
var combinedPrice = $('.combined-price').val(),
|
||||
originalPrice = Number($(".original-price").text());
|
||||
if (num < 2) {
|
||||
layer.msg("商品数不可小于2个!");
|
||||
return;
|
||||
}
|
||||
|
||||
if (data.field.status == undefined) {
|
||||
data.field.status = 0;
|
||||
}
|
||||
|
||||
if(combinedPrice > originalPrice){
|
||||
layer.msg("组合套餐价格不能高于原价");
|
||||
$(".save-prices").text(0).focus();
|
||||
return false
|
||||
}
|
||||
|
||||
var selectGoodsSkuId = []; //商品id
|
||||
$("#goods").find("tbody tr").each(function (i) {
|
||||
var id = $(this).attr("data-sku_id");
|
||||
if(id) selectGoodsSkuId.push(parseInt(id));
|
||||
});
|
||||
|
||||
data.field.sku_ids = selectGoodsSkuId.toString();
|
||||
|
||||
if(repeat_flag) return;
|
||||
repeat_flag = true;
|
||||
|
||||
$.ajax({
|
||||
url: ns.url("bundling://shop/bundling/edit"),
|
||||
data: data.field,
|
||||
dataType: 'JSON',
|
||||
type: 'POST',
|
||||
success: function(res) {
|
||||
repeat_flag = false;
|
||||
|
||||
if (res.code == 0) {
|
||||
layer.confirm('编辑成功', {
|
||||
title:'操作提示',
|
||||
btn: ['返回列表', '继续编辑'],
|
||||
yes: function(index, layero) {
|
||||
location.hash = ns.hash("bundling://shop/bundling/lists");
|
||||
layer.close(index);
|
||||
},
|
||||
btn2: function(index, layero) {
|
||||
layer.close(index);
|
||||
}
|
||||
});
|
||||
}else{
|
||||
layer.msg(res.message);
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
form.verify({
|
||||
flo: function (value) {
|
||||
if (value == '') {
|
||||
return;
|
||||
}
|
||||
var reg = /^(0|[1-9]\d*)(\s|$|\.\d{1,2}\b)/;
|
||||
if (!reg.test(value)) {
|
||||
return '价格不能小于0,可保留两位小数!'
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
/**
|
||||
* 添加商品
|
||||
*/
|
||||
function selectGoods() {
|
||||
goodsSelect(function (data) {
|
||||
selectGoodsSkuId = [];
|
||||
var html = '';
|
||||
if(Object.values(data).length > 0){
|
||||
for (var key in data) {
|
||||
for (var sku in data[key].selected_sku_list) {
|
||||
var item = data[key].selected_sku_list[sku];
|
||||
html += `<tr data-sku_id="${item.sku_id}">`;
|
||||
html += `
|
||||
<td>
|
||||
<div class="goods-title">
|
||||
<div class="goods-img">
|
||||
<img layer-src src="${item.sku_image ? ns.img(item.sku_image) : ''}" alt="">
|
||||
</div>
|
||||
<p class="multi-line-hiding goods-name">${item.sku_name}</p>
|
||||
</div>
|
||||
</td>
|
||||
`;
|
||||
html += `<td class='price-one'>${item.price }</td>`;
|
||||
html += `<td>${item.stock}</td>`;
|
||||
html += `<td class='operation'> <div class='table-btn '><a href='javascript:;' class='layui-btn' onclick='deleteGoods(this)'>删除商品</a></div></td>`;
|
||||
html += `</tr>`;
|
||||
selectGoodsSkuId.push(item.sku_id);
|
||||
}
|
||||
}
|
||||
}else{
|
||||
html += `<tr class="goods-empty">
|
||||
<td colspan="4">
|
||||
<div>未添加商品</div>
|
||||
</td>
|
||||
</tr>`;
|
||||
}
|
||||
$("#goods tbody").html(html);
|
||||
$("#goods_num").text(selectGoodsSkuId.length);
|
||||
priceCount();
|
||||
}, selectGoodsSkuId, {mode: "sku", max_num: 0, min_num: 2});
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除商品
|
||||
*/
|
||||
function deleteGoods(data){
|
||||
var obj = $(data).parent().parent().parent();
|
||||
$(obj).remove();
|
||||
priceCount(); //计算出当前总价格
|
||||
for (var i in selectGoodsSkuId){
|
||||
if(selectGoodsSkuId[i] == Number($(obj).attr("data-sku_id"))){
|
||||
selectGoodsSkuId.splice(i,1);
|
||||
}
|
||||
}
|
||||
$("#goods_num").html(selectGoodsSkuId.length)
|
||||
|
||||
if(selectGoodsSkuId.length) $('.goods-empty').hide();
|
||||
else $('.goods-empty').show();
|
||||
}
|
||||
|
||||
/**
|
||||
* 计算总价
|
||||
*/
|
||||
function priceCount() {
|
||||
var price_count = 0;
|
||||
$("#goods").find("tbody td.price-one").each(function (i) {
|
||||
var price_one = Number($(this).text());
|
||||
price_count += price_one;
|
||||
});
|
||||
|
||||
$(".original-price").text(price_count.toFixed(2));
|
||||
$(".save-prices").text(0);
|
||||
$(".combined-price").val(price_count.toFixed(2));
|
||||
|
||||
if (price_count == 0) {
|
||||
$('.goods-empty').show();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 计算组合套餐价格、原价、节省价
|
||||
*/
|
||||
// $(".combined-price").blur(function () {
|
||||
// var combinedPrice = $(this).val(),
|
||||
// originalPrice = Number($(".original-price").text());
|
||||
|
||||
// if(combinedPrice > originalPrice){
|
||||
// $(this).val(originalPrice);
|
||||
// layer.msg("组合套餐价格不能高于原价");
|
||||
// $(".save-prices").text(0);
|
||||
|
||||
// return false
|
||||
// }else{
|
||||
// $(".save-prices").text((originalPrice - combinedPrice).toFixed(2));
|
||||
// }
|
||||
// });
|
||||
|
||||
function backBundlingList() {
|
||||
location.hash = ns.hash("bundling://shop/bundling/lists");
|
||||
}
|
||||
</script>
|
||||
265
addon/bundling/shop/view/bundling/lists.html
Executable file
265
addon/bundling/shop/view/bundling/lists.html
Executable file
@@ -0,0 +1,265 @@
|
||||
<style>
|
||||
.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="bl_name" placeholder="请输入套餐名称" autocomplete="off" class="layui-input">
|
||||
</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="1">已上架</li>
|
||||
<li lay-id="0">已下架</li>
|
||||
</ul>
|
||||
<div class="layui-tab-content">
|
||||
<!-- 列表 -->
|
||||
<table id="activity_list" lay-filter="activity_list"></table>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 状态 -->
|
||||
<script type="text/html" id="status">
|
||||
{{ d.status == 0 ? '已下架' : '已上架' }}
|
||||
</script>
|
||||
|
||||
<!-- 批量操作 -->
|
||||
<script type="text/html" id="toolbarAction">
|
||||
<button class="layui-btn layui-btn-primary" lay-event="delete">批量删除</button>
|
||||
</script>
|
||||
|
||||
<!-- 操作 -->
|
||||
<script type="text/html" id="operation">
|
||||
<div class="table-btn">
|
||||
<a class="layui-btn" lay-event="detail">详情</a>
|
||||
<a class="layui-btn" lay-event="edit">编辑</a>
|
||||
<a class="layui-btn" lay-event="del">删除</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>
|
||||
layui.use(['form','element','laydate'], function() {
|
||||
var table,
|
||||
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("bundling://shop/bundling/lists"),
|
||||
cols: [
|
||||
[{
|
||||
type: 'checkbox',
|
||||
width: '3%',
|
||||
}, {
|
||||
field: 'bl_name',
|
||||
title: '套餐名称',
|
||||
unresize: 'false',
|
||||
width: '22%'
|
||||
}, {
|
||||
field: 'bl_price',
|
||||
title: '套餐价',
|
||||
unresize: 'false',
|
||||
width: '12%',
|
||||
align: 'right',
|
||||
templet: function(data) {
|
||||
return '¥'+ data.bl_price;
|
||||
}
|
||||
}, {
|
||||
field: 'goods_money',
|
||||
title: '市场价',
|
||||
unresize: 'false',
|
||||
width: '12%',
|
||||
align: 'right',
|
||||
templet: function(data) {
|
||||
return '¥'+ data.goods_money;
|
||||
}
|
||||
}, {
|
||||
unresize: 'false',
|
||||
width: '6%',
|
||||
}, {
|
||||
title: '状态',
|
||||
unresize: 'false',
|
||||
width: '12%',
|
||||
templet: '#status'
|
||||
}, {
|
||||
field: 'update_time',
|
||||
title: '创建时间',
|
||||
unresize: 'false',
|
||||
width: '17%',
|
||||
templet: function(data) {
|
||||
return ns.time_to_date(data.update_time);
|
||||
}
|
||||
}, {
|
||||
title: '操作',
|
||||
toolbar: '#operation',
|
||||
unresize: 'false',
|
||||
align : 'right'
|
||||
}]
|
||||
],
|
||||
toolbar: '#toolbarAction'
|
||||
});
|
||||
|
||||
/**
|
||||
* 监听工具栏操作
|
||||
*/
|
||||
table.tool(function(obj) {
|
||||
var data = obj.data;
|
||||
switch (obj.event) {
|
||||
case 'detail': //详情
|
||||
location.hash = ns.hash("bundling://shop/bundling/detail", {"bl_id": data.bl_id});
|
||||
break;
|
||||
case 'edit': //编辑
|
||||
location.hash = ns.hash("bundling://shop/bundling/edit", {"bl_id": data.bl_id});
|
||||
break;
|
||||
case 'del': //删除
|
||||
deleteBund(data.bl_id);
|
||||
break;
|
||||
}
|
||||
});
|
||||
|
||||
// 监听工具栏操作
|
||||
table.toolbar(function (obj) {
|
||||
var data = obj.data;
|
||||
if(data.length <= 0) return;
|
||||
var bundlingIdAll = [];
|
||||
for (var i in data){
|
||||
bundlingIdAll.push(data[i].bl_id);
|
||||
}
|
||||
|
||||
switch (obj.event) {
|
||||
case 'delete':
|
||||
deleteBundlingAll(bundlingIdAll)
|
||||
break;
|
||||
}
|
||||
})
|
||||
|
||||
function deleteBundlingAll(data){
|
||||
layer.confirm('确定要删除组合套餐吗?', function(index) {
|
||||
if (repeat_flag) return false;
|
||||
repeat_flag = true;
|
||||
layer.close(index);
|
||||
$.ajax({
|
||||
url: ns.url("bundling://shop/bundling/deleteAll"),
|
||||
data: {
|
||||
"bl_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;
|
||||
});
|
||||
}
|
||||
|
||||
//开始时间
|
||||
laydate.render({
|
||||
elem: '#start_time', //指定元素
|
||||
type: 'datetime'
|
||||
});
|
||||
//结束时间
|
||||
laydate.render({
|
||||
elem: '#end_time', //指定元素
|
||||
type: 'datetime'
|
||||
});
|
||||
|
||||
/**
|
||||
* 删除
|
||||
*/
|
||||
function deleteBund(id) {
|
||||
layer.confirm('确定要删除该组合套餐吗?', function(index) {
|
||||
if (repeat_flag) return false;
|
||||
repeat_flag = true;
|
||||
layer.close(index);
|
||||
$.ajax({
|
||||
url: ns.url("bundling://shop/bundling/delete"),
|
||||
data: {
|
||||
"bl_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 add() {
|
||||
location.hash = ns.hash("bundling://shop/bundling/add");
|
||||
}
|
||||
</script>
|
||||
Reference in New Issue
Block a user