初始上传
This commit is contained in:
246
addon/live/shop/view/goods/add.html
Executable file
246
addon/live/shop/view/goods/add.html
Executable file
@@ -0,0 +1,246 @@
|
||||
<style type="text/css">
|
||||
.price-wrap{display: flex;top: 4px;position: relative;}
|
||||
.price-wrap > span {display: inline-block;margin: 0 5px;}
|
||||
.price-wrap > span.sepa{margin: 0 20px;}
|
||||
</style>
|
||||
|
||||
<div class="layui-form form-wrap">
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label"></label>
|
||||
<div class="layui-input-block">
|
||||
<button class="layui-btn" onclick="addGoods()">选择商品</button>
|
||||
</div>
|
||||
</div>
|
||||
<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|name" class="layui-input ns-len-mid" autocomplete="off" maxlength="14">
|
||||
</div>
|
||||
<div class="word-aux">
|
||||
<!-- <p>商品名称必须为3-14个字符</p> -->
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label"><span class="required">*</span>商品封面:</label>
|
||||
<div class="layui-input-block">
|
||||
<div class="upload-img-block">
|
||||
<div class="upload-img-box ">
|
||||
<div class="upload-default" id="ImgUpload">
|
||||
<div class="upload">
|
||||
<i class="iconfont iconshangchuan"></i>
|
||||
<p>选择商品</p>
|
||||
</div>
|
||||
</div>
|
||||
<div class="operation">
|
||||
<div>
|
||||
<i title="图片预览" class="iconfont iconreview js-preview" style="margin-right: 20px;"></i>
|
||||
<i title="删除图片" class="layui-icon layui-icon-delete js-delete"></i>
|
||||
</div>
|
||||
<div class="replace_img js-replace">点击替换</div>
|
||||
</div>
|
||||
<input type="hidden" name="goods_pic" value="" lay-verify="goodsPic"/>
|
||||
</div>
|
||||
<!-- <p id="ImgUpload" class="no-replace">替换</p>
|
||||
<input type="hidden" name="goods_pic" value="" lay-verify="goodsPic"/>
|
||||
<i class="del">x</i> -->
|
||||
</div>
|
||||
</div>
|
||||
<div class="word-aux">
|
||||
<p>建议尺寸:200像素 * 200像素,图片大小不得超过80K</p>
|
||||
</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">
|
||||
<input type="radio" name="price_type" value="1" title="一口价" checked>
|
||||
</div>
|
||||
<div class="layui-input-inline price-wrap">
|
||||
<span>价格</span>
|
||||
<input class="layui-input len-short input-num" type="number" min="0" name="price" value="0.00" lay-verify="required|flnum">
|
||||
<span>元</span>
|
||||
</div>
|
||||
</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="radio" name="price_type" value="2" title="价格区间">
|
||||
</div>
|
||||
<div class="layui-input-inline price-wrap">
|
||||
<span>价格</span>
|
||||
<input class="layui-input len-short input-num" type="number" min="0" name="price" value="0.00" lay-verify="required|flnum">
|
||||
<span>元</span>
|
||||
<span class="sepa">-</span>
|
||||
<input class="layui-input len-short input-num" type="number" min="0" name="price2" value="0.00" lay-verify="required|flnum">
|
||||
<span>元</span>
|
||||
</div>
|
||||
</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="radio" name="price_type" value="3" title="显示折扣价">
|
||||
</div>
|
||||
<div class="layui-input-inline price-wrap">
|
||||
<span>原价</span>
|
||||
<input class="layui-input len-short input-num" type="number" min="0" name="price" value="0.00" lay-verify="required|flnum">
|
||||
<span>元</span>
|
||||
<span class="sepa"></span>
|
||||
<span>现价</span>
|
||||
<input class="layui-input len-short input-num" type="number" min="0" name="price2" value="0.00" lay-verify="required|flnum">
|
||||
<span>元</span>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label"><span class="required">*</span>商品链接:</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="url" lay-verify="required" class="layui-input len-mid" autocomplete="off">
|
||||
</div>
|
||||
<div class="word-aux">
|
||||
<p>请确保小程序页面路径可被访问,例如:pages/goods/detail?sku_id=sku_id</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="form-row">
|
||||
<button class="layui-btn" lay-submit lay-filter="save">添加</button>
|
||||
<button class="layui-btn layui-btn-primary" onclick="backLiveGoodsList()">返回</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script type="text/javascript">
|
||||
var form,repeat_flag=false;
|
||||
layui.use(['form'], function() {
|
||||
form = layui.form;
|
||||
form.render();
|
||||
|
||||
var upload = new Upload({
|
||||
elem: '#ImgUpload',
|
||||
multiple: true,
|
||||
});
|
||||
|
||||
/**
|
||||
* 表单验证
|
||||
*/
|
||||
form.verify({
|
||||
name: function(value){
|
||||
|
||||
if (value.length < 3 || value.length > 14) {
|
||||
return '商品名称必须为3-14个字符';
|
||||
}
|
||||
},
|
||||
goodsPic: function(value){
|
||||
var patt = /[\S]+/;
|
||||
if (!patt.test(value)) {
|
||||
return '请上传商品封面!';
|
||||
}
|
||||
},
|
||||
});
|
||||
|
||||
form.on('submit(save)', function(data){
|
||||
if (repeat_flag) return;
|
||||
repeat_flag = true;
|
||||
|
||||
if (data.field.price_type == 1) {
|
||||
data.field.price = parseFloat($('[name="price_type"][value="1"]').parents('.layui-input-block').find('[name="price"]').val());
|
||||
data.field.price2 = 0;
|
||||
if (data.field.price <= 0) {
|
||||
layer.msg('请输入商品价格', {icon: 5, shift: 6});
|
||||
return;
|
||||
}
|
||||
} else if (data.field.price_type == 2) {
|
||||
data.field.price = parseFloat($('[name="price_type"][value="2"]').parents('.layui-input-block').find('[name="price"]').val());
|
||||
data.field.price2 = parseFloat($('[name="price_type"][value="2"]').parents('.layui-input-block').find('[name="price2"]').val());
|
||||
if (data.field.price <= 0 || data.field.price2 <= 0) {
|
||||
layer.msg('请输入商品价格', {icon: 5, shift: 6});
|
||||
return;
|
||||
}
|
||||
} else if (data.field.price_type == 3) {
|
||||
data.field.price = parseFloat($('[name="price_type"][value="3"]').parents('.layui-input-block').find('[name="price"]').val());
|
||||
data.field.price2 = parseFloat($('[name="price_type"][value="3"]').parents('.layui-input-block').find('[name="price2"]').val());
|
||||
if (data.field.price <= 0) {
|
||||
layer.msg('请输入原价', {icon: 5, shift: 6});
|
||||
return;
|
||||
}
|
||||
if (data.field.price2 <= 0) {
|
||||
layer.msg('请输入现价', {icon: 5, shift: 6});
|
||||
return;
|
||||
}
|
||||
if (data.field.price2 >= data.field.price) {
|
||||
layer.msg('现价不能小于或等于原价', {icon: 5, shift: 6});
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
$.ajax({
|
||||
type: 'POST',
|
||||
url: ns.url("live://shop/goods/add"),
|
||||
data: data.field,
|
||||
dataType: 'JSON',
|
||||
success: function(res) {
|
||||
layer.msg(res.message);
|
||||
repeat_flag = false;
|
||||
if (res.code == 0) {
|
||||
location.hash = ns.hash("live://shop/goods/index");
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
function backLiveGoodsList() {
|
||||
location.hash = ns.hash("live://shop/goods/index");
|
||||
}
|
||||
|
||||
/**
|
||||
* 添加商品
|
||||
*/
|
||||
function addGoods() {
|
||||
goodsSelect(function (data) {
|
||||
if (Object.keys(data).length == 0) {
|
||||
|
||||
$('[name="name"]').val('');
|
||||
$("input[name='goods_pic']").val('');
|
||||
|
||||
$("#ImgUpload").html('<div class="upload"><i class="iconfont iconshangchuan"></i><p>选择商品</p></div>');
|
||||
$('#ImgUpload').parents('.upload-img-box').removeClass('hover');
|
||||
|
||||
$('[name="url"]').val('');
|
||||
$('[name="price_type"][value="1"]').prop('checked', true);
|
||||
$('[name="price_type"][value="1"]').parents('.layui-input-block').find('[name="price"]').val('0.00');
|
||||
return;
|
||||
}
|
||||
|
||||
data = data[Object.keys(data)[0]];
|
||||
var sku_id = data.sku_list[0].sku_id;
|
||||
var images = data.goods_image.split(',');
|
||||
|
||||
$('[name="name"]').val(data.goods_name);
|
||||
if (images[0] != undefined) {
|
||||
$("input[name='goods_pic']").val(imgHandle(images[0]));
|
||||
$("#ImgUpload").html("<div id='preview_imgUpload' class='preview_img'><img layer-src class='img_prev' src=" + ns.img(images[0]) + " ></div>");
|
||||
// $("#ImgUpload").html("<img src=" + ns.img(images[0]) + " >");
|
||||
// $("#ImgUpload").removeClass("no-replace").addClass("replace");
|
||||
loadImgMagnify();
|
||||
$('#ImgUpload').parents('.upload-img-box').addClass('hover')
|
||||
}
|
||||
$('[name="url"]').val('pages/goods/detail?sku_id=' + sku_id);
|
||||
$('[name="price_type"][value="1"]').prop('checked', true);
|
||||
$('[name="price_type"][value="1"]').parents('.layui-input-block').find('[name="price"]').val(data.price);
|
||||
form.render();
|
||||
}, [], {mode: "spu", max_num: 1});
|
||||
}
|
||||
|
||||
function imgHandle(src){
|
||||
var arr = src.split("."),
|
||||
suffix = arr[arr.length - 1];
|
||||
arr.pop();
|
||||
arr[arr.length - 1] = arr[arr.length - 1] + "_SMALL";
|
||||
arr.push(suffix);
|
||||
src = arr.join(".");
|
||||
return src;
|
||||
}
|
||||
</script>
|
||||
159
addon/live/shop/view/goods/index.html
Executable file
159
addon/live/shop/view/goods/index.html
Executable file
@@ -0,0 +1,159 @@
|
||||
<style>
|
||||
.progress-layer {width:400px;background:#fff;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:1px 1px 50px rgba(0,0,0,.3);padding:20px 20px;z-index:100;display:none;}
|
||||
.progress-layer h3 {line-height:1;margin-bottom:15px;text-align:center;font-size:14px;}
|
||||
.progress-layer .layui-progress-big,.progress-layer .layui-progress-big .layui-progress-bar {height:14px;line-height:14px;}
|
||||
.progress-layer .layui-progress-text {line-height:14px;}
|
||||
.goods-info {padding: 5px 0;align-items: center;flex-wrap:unset!important;}
|
||||
.goods-info .room-name {padding-left: 5px;line-height: 1}
|
||||
.goods-info img {width:50px;height: 50px;}
|
||||
.single-filter-box{justify-content: end}
|
||||
</style>
|
||||
|
||||
<div class="single-filter-box">
|
||||
<button class="layui-btn" onclick="sync()">同步商品库</button>
|
||||
<a href="{:href_url('live://shop/goods/add')}" class="layui-btn layui-btn-primary">添加商品</a>
|
||||
</div>
|
||||
|
||||
<table id="goods_list" lay-filter="goods_list"></table>
|
||||
|
||||
<!-- 直播间信息 -->
|
||||
<script type="text/html" id="goodsinfo">
|
||||
<div class="layui-table-cell goods-info">
|
||||
<img src="{{ ns.img(d.cover_img) }}">
|
||||
<span class="room-name" title="{{ d.name }}">{{ d.name }}</span>
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<!-- 操作 -->
|
||||
<script type="text/html" id="operation">
|
||||
<div class="table-btn">
|
||||
{{# if( (d.status == 2 || d.status == 3) && d.third_party_tag != 0 ){ }}
|
||||
<a class="layui-btn" lay-event="del">删除</a>
|
||||
{{# } }}
|
||||
</div>
|
||||
</script>
|
||||
|
||||
<div class="progress-layer">
|
||||
<h3>正在同步中...</h3>
|
||||
<div class="layui-progress layui-progress-big" lay-showPercent="true" lay-filter="progress">
|
||||
<div class="layui-progress-bar layui-bg-blue" lay-percent="0%"></div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script>
|
||||
var form,table,element,syncClick = false,delete_flag = false;
|
||||
layui.use(['form', 'element'], function() {
|
||||
form = layui.form;
|
||||
element = layui.element;
|
||||
|
||||
table = new Table({
|
||||
elem: '#goods_list',
|
||||
url: ns.url("live://shop/goods/index"),
|
||||
cols: [
|
||||
[{
|
||||
title: '商品信息',
|
||||
unresize: 'false',
|
||||
width: '30%',
|
||||
templet: "#goodsinfo"
|
||||
}, {
|
||||
title: '价格',
|
||||
unresize: 'false',
|
||||
width: '15%',
|
||||
field: 'price'
|
||||
}, {
|
||||
field: 'url',
|
||||
title: '商品链接',
|
||||
unresize: 'false',
|
||||
width: '30%'
|
||||
}, {
|
||||
field: 'status_name',
|
||||
title: '状态',
|
||||
unresize: 'false',
|
||||
width: '15%',
|
||||
}, {
|
||||
title: '操作',
|
||||
toolbar: '#operation',
|
||||
unresize: 'false',
|
||||
align:'right'
|
||||
}]
|
||||
]
|
||||
});
|
||||
|
||||
table.tool(function(obj) {
|
||||
var data = obj.data;
|
||||
switch (obj.event) {
|
||||
case 'del': //删除
|
||||
layer.confirm('确定要删除该商品吗?', function(index) {
|
||||
if (delete_flag) return false;
|
||||
delete_flag = true;
|
||||
layer.close(index);
|
||||
|
||||
$.ajax({
|
||||
url: ns.url("live://shop/goods/delete"),
|
||||
data: {
|
||||
id: data.id
|
||||
},
|
||||
dataType: 'JSON',
|
||||
type: 'POST',
|
||||
success: function(res) {
|
||||
layer.msg(res.message);
|
||||
delete_flag = false;
|
||||
|
||||
if (res.code == 0) {
|
||||
table.reload({
|
||||
page: {
|
||||
curr: 1
|
||||
},
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
}, function() {
|
||||
layer.close();
|
||||
delete_flag = false;
|
||||
});
|
||||
break;
|
||||
}
|
||||
})
|
||||
});
|
||||
|
||||
// 同步商品
|
||||
function sync(start){
|
||||
if (syncClick) return;
|
||||
syncClick = true;
|
||||
var start = start == undefined ? 0 : start;
|
||||
|
||||
$.ajax({
|
||||
url: ns.url("live://shop/goods/sync"),
|
||||
data: {
|
||||
start: 0,
|
||||
},
|
||||
dataType: 'JSON',
|
||||
type: 'POST',
|
||||
success: function(res) {
|
||||
syncClick = false;
|
||||
if (res.code == 0) {
|
||||
var data = res.data,
|
||||
next = parseInt(start) + 1;
|
||||
|
||||
if (next < data.total_page) {
|
||||
if (start == 0) {
|
||||
$(".progress-layer").fadeOut();
|
||||
}
|
||||
var progress = (next / data.total_page * 100).toFixed(2);
|
||||
element.progress('progress', progress + '%');
|
||||
// 拉取下一页
|
||||
sync(next);
|
||||
} else {
|
||||
if (!$(".progress-layer").is(':hidden')) $(".progress-layer").fadeOut();
|
||||
layer.closeAll();
|
||||
layer.msg('同步成功');
|
||||
table.reload();
|
||||
}
|
||||
} else {
|
||||
layer.msg(res.message);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
</script>
|
||||
Reference in New Issue
Block a user