初始上传

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,95 @@
.layui-form-item .layui-input-inline.end-time {
float: none;
}
.layui-form-item .layui-input-inline.end-time {
float: none;
}
.time-label {
display: inline-block;
line-height: 30px;
height: 30px;
padding: 0 15px;
border-radius: 2px;
border: 1px solid #e9e9e9;
background: #f7f7f7;
font-size: 12px;
vertical-align: middle;
opacity: 1;
margin: 4px 8px 4px 0;
cursor: pointer;
position: relative;
}
.time-label span {
vertical-align: middle;
}
.time-label i {
font-size: 12px;
position: absolute;
top: -8px;
right: -8px;
width: 16px;
height: 16px;
line-height: 16px;
text-align: center;
color: #fff;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
border-radius: 10px;
background: rgba(0, 0, 0, 0.3);
}
.seckill-box .layui-table-col-special {
padding: 5px 0 !important;
}
.layui-table-body {
max-height: 480px !important;
}
.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;
}
.forbidden {
cursor: not-allowed;
background-color: #eee;
}
.form-wrap {
position: relative;
}
.layui-carousel {
position: absolute;
top: 15px;
left: 1325px;
background: #fff;
}
.goods_num {
padding-left: 20px;
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 116 KiB

View File

@@ -0,0 +1,650 @@
var selectedSkuId = [], sku_list = [], time_list = [], form, laydate, timeTable, minDate, currentDate = new Date(),
repeat_flag = false; //防重复标识;
layui.use(['form', 'laydate'], function () {
form = layui.form;
laydate = layui.laydate;
minDate = "";
form.render();
currentDate.setDate(currentDate.getDate() + 30);
if ($("input[name='id']").val()) {
time_list = JSON.parse($('input[name="time_list"]').val());
sku_list = JSON.parse($('input[name="sku_list"]').val());
laydate.render({
elem: '#start_time',
type: 'datetime',
done: function (value) {
minDate = value;
reRender();
}
});
laydate.render({
elem: '#end_time',
type: 'datetime'
});
} else {
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)
});
}
renderTimeTable();
initTimeList();
renderTable();
form.on('submit(save)', function (data) {
if (verify()) {
var goods_data = [];
if (data.field.id) {
for (var i in sku_list) {
if (sku_list[i]['is_select'] == 1) {
goods_data.push(sku_list[i]);
}
}
data.field.sku_list = goods_data;
} else {
for (var i in sku_list) {
var goods = {};
goods.goods_id = sku_list[i]['goods_id'];
if (goods_data.length == 0) {
goods_data.push(goods);
} else {
$.each(goods_data, function (index, event) {
if (goods_data.length == index + 1 && event.goods_id != goods.goods_id) {
goods_data.push(goods);
}
})
}
}
$.each(goods_data, function (i, e) {
goods_data[i]['sku_list'] = [];
$.each(sku_list, function (index, event) {
if (event.goods_id == e.goods_id) {
goods_data[i]['sku_list'].push(event);
}
})
});
data.field.goods_data = goods_data;
}
var goods_ids = [];
goods_data.forEach(function (item) {
goods_ids.push(item.goods_id);
});
data.field.goods_ids = goods_ids.toString();
if (repeat_flag) return;
repeat_flag = true;
$.ajax({
url: data.field.id ? ns.url("seckill://shop/seckill/updateGoods") : ns.url("seckill://shop/seckill/addGoods"),
data: data.field,
dataType: 'JSON',
type: 'POST',
success: function (res) {
repeat_flag = false;
if (res.code == 0) {
layer.confirm(data.field.id ? '编辑成功' : '添加成功', {
title: '操作提示',
btn: ['返回列表', data.field.id ? '继续操作' : '继续添加'],
closeBtn: 0,
yes: function (index, layero) {
location.hash = ns.hash("seckill://shop/seckill/goodslist")
layer.close(index);
},
btn2: function (index, layero) {
listenerHash(); // 刷新页面
layer.close(index);
}
});
} else {
layer.msg(res.message);
}
}
});
}
});
form.verify({
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();
var old_end_time = $("#old_end_time").val();
if (now_time > end_time) {
return '结束时间不能小于当前时间!'
}
if (start_time > end_time) {
return '结束时间不能小于开始时间!';
}
if (old_end_time && old_end_time > end_time) {
return '结束时间不能小于之前设置的结束时间!';
}
},
seckilltime: function (value, item) {
if (value == "" || value == 0) {
return '请选择时间段';
}
}
});
$("body").off("click", ".no-participation").on("click", ".no-participation", function () {
$(this).text("参与");
$(this).parents("tr").find("input").each(function (index, item) {
$(item).attr("readonly", true);
$(item).attr("disabled", true);
$(item).addClass("forbidden");
$(item).attr("lay-verify", "");
});
$(this).addClass("participation").removeClass("no-participation");
sku_list[$(this).parents("tr").attr("data-index")].is_select = 0;
});
$("body").off("click", ".participation").on("click", ".participation", function () {
$(this).text("不参与");
$(this).parents("tr").find("input").each(function (index, item) {
$(item).attr("readonly", false);
$(item).attr("disabled", false);
$(item).removeClass("forbidden");
});
$(this).removeClass("participation").addClass("no-participation");
sku_list[$(this).parents("tr").attr("data-index")].is_select = 1;
});
});
// 重新渲染结束时间
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
});
}
function verify() {
if ($('input[name="seckill_time_id"]').val() == '') {
layer.msg('请选择场次', {icon: 5, anim: 6});
return false;
}
if (sku_list.length == 0) {
layer.msg('请选择商品', {icon: 5, anim: 6});
return false;
}
for (var i in sku_list) {
if (sku_list[i]['max_buy'] < 0) {
layer.msg('商品限购不可小于0', {icon: 5, anim: 6});
return false;
}
if (sku_list[i]['seckill_price'] <= 0) {
layer.msg('秒杀价不可小于等于0', {icon: 5, anim: 6});
return false;
}
if (sku_list[i]['seckill_stock'] > sku_list[i]['stock']) {
layer.msg('秒杀库存不能大于商品库存', {icon: 5, anim: 6});
return false;
}
}
return true;
}
function delGoods(obj, id) {
var sku_ids = [];
for (let i = 0; i < sku_list.length; i++) {
if (sku_list[i].sku_id == parseInt(id)) {
sku_list.splice(i, 1);
}
}
for (let i = 0; i < sku_list.length; i++) {
sku_ids.push(sku_list[i].sku_id);
}
$(obj).parents("tr").remove();
$("#goods_num").html(sku_list.length);
selectedSkuId = sku_ids.toString();
}
// 表格渲染
function renderTable() {
//展示已知数据
table = new Table({
elem: '#selected_goods_list',
page: false,
limit: Number.MAX_VALUE,
cols: [
[
{
width: "3%",
type: 'checkbox',
unresize: 'false'
},
{
field: 'sku_name',
title: '商品名称',
width: '22%',
unresize: 'false',
templet: function (data) {
var html = '';
html += `
<div class="goods-title">
<div class="goods-img">
<img src="${ns.img(data.sku_image)}" alt="">
</div>
<p class="multi-line-hiding goods-name" data-goods_id="${data.goods_id}" data-sku_id="${data.sku_id}" title="${data.sku_name}">${data.sku_name}</p>
</div>
`;
return html;
}
}, {
field: 'price',
title: '原价',
unresize: 'false',
align: 'left',
width: '14%',
templet: function (data) {
return '<p class="line-hiding" title="' + data.price + '">¥<span>' + data.price + '</span></p>';
}
}, {
field: 'stock',
title: '库存',
unresize: 'false',
width: '9%',
templet: function (data) {
return '<p class="stock">' + data.stock + '</p>';
}
}, {
field: 'max_buy',
title: '<span>限购0为不限购</span>',
unresize: 'false',
width: '14%',
templet: '#maxBuy'
}, {
title: '<span title="秒杀价">秒杀价</span>',
unresize: 'false',
width: '15%',
templet: '#seckillPrice'
}, {
title: '<span title="秒杀库存">秒杀库存</span>',
unresize: 'false',
width: '12%',
templet: '#seckillStock'
}, {
title: '操作',
toolbar: '#operation',
unresize: 'false',
}]
],
data: sku_list,
toolbar: '#toolbarOperation'
});
table.toolbar(function (obj) {
if (obj.data.length < 1) {
layer.msg('请选择要操作的数据');
return;
}
switch (obj.event) {
case "seckill-purchase":
editInput(0, obj);
break;
case "seckill-price":
editInput(1, obj);
break;
case "seckill-stock":
editInput(2, obj);
break;
}
});
}
function editInput(textIndex = 0, data) {
var text = [{
name: '限购',
value: 'max_buy'
}, {
name: '秒杀价',
value: 'seckill_price'
}, {
name: '秒杀库存',
value: 'seckill_stock'
}];
console.log(text[textIndex].value)
if(text[textIndex].value == 'seckill_price'){
var html =`
<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="radio" name="seckill_type" value="1" class="seckill_type_input" onclick="switch_type(1)" title="固定价格" lay-filter="seckill_type" checked>
<input type="radio" name="seckill_type" value="2" class="seckill_type_input" onclick="switch_type(2)" title="打折" lay-filter="seckill_type">
<input type="radio" name="seckill_type" value="3" class="seckill_type_input" onclick="switch_type(3)" title="减价" lay-filter="seckill_type">
</div>
<label class="layui-form-label seckill-title"><span class="required">*</span>固定价格:</label>
<div class="layui-input-block">
<input type="text" name="bargain_edit_input" lay-verify="required" autocomplete="off" class="layui-input len-mid" placeholder="请输入固定价格">
</div>
<div class="word-aux seckill-word"></div>
</div>
</div>
`
}else{
var html =`<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>${text[textIndex].name}</label>
<div class="layui-input-block">
<input type="text" name="bargain_edit_input" lay-verify="required" autocomplete="off" class="layui-input len-mid" placeholder="请输入${text[textIndex].name}">
</div>
</div> `
}
layer.open({
type: 1,
title: "修改" + text[textIndex].name,
area: ['600px'],
btn: ["保存", "返回"],
content:html,
success:function(layero, index){
form.on('radio(seckill_type)', function(data){
switch_type(data.value)
});
form.render();
},
yes: function (index, layero) {
var val = $("input[name='bargain_edit_input']").val();
if (!val) {
layer.msg("请输入" + text[textIndex].name);
return false;
}
var type = $("input[name='seckill_type']:checked").val();
if(type == 1 && val<= 0){
layer.msg("固定价格需大于0")
return false;
}
if(type == 2 && (val <= 0 || val > 10)){
layer.msg("折扣率需大于0且小于等于10可保留两位小数")
return false;
}
if(type == 3 && val< 0){
layer.msg("减价金额需大于等于0")
return false;
}
var error_info = '';
data.data.forEach(function (item, index) {
sku_list.forEach(function (skuItem, skuIndex) {
if (item.sku_id == skuItem.sku_id) {
if(text[textIndex].value == 'seckill_price'){
var new_val = 0;
switch (type) {
case '1': //固定价格
new_val = val;
break;
case '2'://打折
new_val = (sku_list[skuIndex]['price'] * 0.1 * val).toFixed(2)
break;
case '3': //减价
new_val= (sku_list[skuIndex]['price'] -val).toFixed(2);
break;
}
if(new_val <=0){
console.log(sku_list[skuIndex])
error_info = sku_list[skuIndex]['sku_name']+'设置后秒杀价为0元,请检查';
return false;
}
sku_list[skuIndex][text[textIndex].value] = new_val;
}else{
sku_list[skuIndex][text[textIndex].value] = val;
}
}
})
});
if(error_info){
layer.msg(error_info)
return
}
renderTable();
layer.closeAll();
}
});
}
function switch_type(obj){
$(".seckill-word").text("")
switch (obj) {
case '1':
$(".seckill-title").html("<span class=\"required\">*</span>固定价格:")
$("input[name='bargain_edit_input']").attr("placeholder",'请输入固定价格')
break;
case '2':
$(".seckill-title").html("<span class=\"required\">*</span>折扣率:")
$("input[name='bargain_edit_input']").attr("placeholder",'请输入折扣率')
$(".seckill-word").text("折扣率需大于0且小于等于10可保留两位小数")
break;
case '3':
$(".seckill-title").html("<span class=\"required\">*</span>优惠金额:")
$("input[name='bargain_edit_input']").attr("placeholder",'请输入优惠金额')
break;
}
}
/* 商品 */
function addGoods() {
goodsSelect(function (data) {
sku_list = [];
var sku_ids = [];
for (var key in data) {
for (var sku in data[key].selected_sku_list) {
var item = data[key].selected_sku_list[sku];
item.seckill_price = item.price;
item.max_buy = 1;
item.seckill_stock = item.stock;
sku_ids.push(item.sku_id);
sku_list.push(item);
}
}
renderTable();
selectedSkuId = sku_ids;
$("#goods_num").html(sku_list.length)
}, selectedSkuId, {mode: "sku"});
}
function setGoodsSku(type, sku_id, obj) {
$.each(sku_list, function (i, e) {
if (sku_id == e.sku_id) {
sku_list[i][type] = $(obj).val();
}
})
}
function addSeckillTime() {
layer.open({
type: 1,
title: "场次选择",
area: ['900px', '620px'],
btn: ['保存', '返回'],
content: $('#seckillTime').html(),
success: function (layero) {
renderTimeTable();
},
yes: function (index, layero) {
var select_time_id = [];
time_list = [];
$('div[lay-id="seckill_time_list"] .time-select').each(function (i, e) {
if ($(e).is(":checked")) {
let time = {};
time.start_time = $(e).attr('data-time-start');
time.end_time = $(e).attr('data-time-end');
time.id = $(e).attr('data-time-id');
time.name = $(e).attr('data-name');
select_time_id.push($(e).attr('data-time-id'));
time_list.push(time);
}
});
$('input[name="seckill_time_id"]').val(select_time_id.toString());
refreshTimeList();
layer.closeAll();
}
});
}
function refreshTimeList() {
var html = '';
for (let i in time_list) {
let start_time = transformSeckillTime(time_list[i]['start_time']);
let end_time = transformSeckillTime(time_list[i]['end_time']);
let name = time_list[i]['name'];
let id = time_list[i]['id'];
html += `
<li class="time-label" title="${start_time} - ${end_time}">
<span>${name}</span>
<i class="layui-icon layui-icon-close" onclick="delTime(${id}, this)"></i>
</li>
`;
}
$('.time-label-list ul').html(html);
}
function transformSeckillTime(time) {
time = parseFloat(time);
var hour = parseInt(time / 3600);
var minute = parseInt((time % 3600) / 60);
var second = parseInt(time % 60);
if (hour < 10) hour = '0' + hour;
if (minute < 10) minute = '0' + minute;
if (second < 10) second = '0' + second;
return hour + ':' + minute + ':' + second;
}
function delTime(id, obj) {
time_list.splice(time_list.indexOf(id), 1);
let time = [];
for (let i in time_list) {
if (time_list[i]['id'] != id) {
time.push(time_list[i]['id']);
}
}
$('input[name="seckill_time_id"]').val(time.toString());
$(obj).parents('li').remove();
}
// 场次渲染
function renderTimeTable() {
$.ajax({
url: ns.url("seckill://shop/seckill/lists"),
dataType: 'JSON',
type: 'POST',
success: function (res) {
if (res.code < 0) {
layer.msg(res.message);
return false;
}
var time_data = res.data;
for (let i in time_data) {
time_data[i]['is_select'] = 0;
for (let j in time_list) {
if (time_list[j]['id'] == time_data[i]['id']) {
time_data[i]['is_select'] = 1;
}
}
}
timeTable = new Table({
elem: '#seckill_time_list',
page: false,
height: 380,
limit: Number.MAX_VALUE,
cols: [
[{
title: '<input type="checkbox" name="time_checkbox_all" lay-skin="primary" lay-filter="time_checkbox_all">',
unresize: 'false',
width: '10%',
templet: '#timecheckbox',
}, {
field: 'name',
title: '场次名称',
unresize: 'false',
align: 'left',
width: '30%'
}, {
field: 'seckill_start_time_show',
title: '开始时间',
unresize: 'false',
width: '25%'
}, {
field: 'seckill_end_time_show',
title: '结束时间',
unresize: 'false',
width: '25%'
}]
],
data: time_data
});
// 勾选商品
form.on('checkbox(time_checkbox_all)', function (data) {
var all_checked = data.elem.checked;
$("input[name='time_checkbox']").each(function () {
var checked = $(this).prop('checked');
if (all_checked != checked) {
$(this).next().click();
}
});
});
}
});
}
function initTimeList() {
var html = '';
for (let i in time_list) {
let start_time = transformSeckillTime(time_list[i]['seckill_start_time']);
let end_time = transformSeckillTime(time_list[i]['seckill_end_time']);
let name = time_list[i]['name'];
let id = time_list[i]['id'];
html += `
<li class="time-label" title="${start_time} - ${end_time}">
<span>${name}</span>
<i class="layui-icon layui-icon-close" onclick="delTime(${id}, this)"></i>
</li>
`;
}
$('.time-label-list ul').html(html);
}
function backSeckillGoodsList() {
location.hash = ns.hash("seckill://shop/seckill/goodslist");
}

View File

@@ -0,0 +1,126 @@
<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" id="name" name="name" lay-verify="required" autocomplete="off" class="layui-input len-long">
</div>
</div>
<div class="layui-form-item">
<div class="layui-inline">
<label class="layui-form-label"><span class="required">*</span>秒杀时间段:</label>
<div class="layui-inline">
<div class="layui-input-inline">
<input type="text" id="add_start_time" value="00:00:00" lay-verify="required" class="layui-input">
<i class=" iconrili iconfont calendar"></i>
</div>
<span class="layui-form-mid">-</span>
<div class="layui-input-inline">
<input type="text" id="add_end_time" value="00:00:00" lay-verify="required" class="layui-input">
<i class=" iconrili iconfont calendar"></i>
</div>
</div>
<div class="word-aux">
<p>每个场次的时间段不能重叠</p>
</div>
</div>
</div>
<div class="form-row">
<button class="layui-btn" lay-submit lay-filter="save">保存</button>
<button class="layui-btn layui-btn-primary" onclick="backSeckillList()">返回</button>
</div>
</div>
<script>
layui.use(['form','laydate'], function() {
var form = layui.form,
laydate = layui.laydate;
repeat_flag = false; //防重复标识
form.render();
// 表单提交监听
form.on('submit(save)', function(data) {
data.name = $('#name').val();
if (!data.name) {
layer.msg("秒杀场次名称不能为空");
return false;
}
if (!$('#add_start_time').val()) {
layer.msg("开始时间不能为空");
return false;
}
if (!$('#add_end_time').val()) {
layer.msg("结束时间不能为空");
return false;
}
if($('#add_end_time').val() <= $('#add_start_time').val()){
layer.msg("结束时间必须大于开始时间");
return false;
}
if (repeat_flag) return;
repeat_flag = true;
data.field.start_hour = $('#add_start_time').val().split(":")[0];
data.field.start_minute = $('#add_start_time').val().split(":")[1];
data.field.start_second = $('#add_start_time').val().split(":")[2];
data.field.end_hour = $('#add_end_time').val().split(":")[0];
data.field.end_minute = $('#add_end_time').val().split(":")[1];
data.field.end_second = $('#add_end_time').val().split(":")[2];
$.ajax({
url: ns.url("seckill://shop/seckill/add"),
data: data.field,
type: "post",
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("seckill://shop/seckill/lists");
layer.close(index);
},
btn2: function(index, layero) {
listenerHash(); // 刷新页面
layer.close(index);
}
});
}else{
layer.msg(res.message);
}
}
});
});
form.verify({
timeHour: function(value) {
if (!new RegExp("^0|[1-9]|1[0-9]|2[0-3]$").test(value)) {
return '时段范围为0-23且只能是整数';
}
},
timeMinSend: function(value) {
if (!new RegExp("^(?:0|[0-5][0-9]?)$").test(value)) {
return '分秒范围为0-59且只能是整数';
}
}
});
laydate.render({
elem: '#add_end_time',
type: 'time'
});
laydate.render({
elem: '#add_start_time',
type: 'time'
});
});
function backSeckillList() {
location.hash = ns.hash("seckill://shop/seckill/lists");
}
</script>

View File

@@ -0,0 +1,121 @@
<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" id="name" name="name" lay-verify="required" value="{$time_info.name}" autocomplete="off" class="layui-input len-long">
</div>
</div>
<div class="layui-form-item">
<div class="layui-inline">
<label class="layui-form-label"><span class="required">*</span>秒杀时间段:</label>
<div class="layui-inline">
<div class="layui-input-inline">
<input type="text" id="add_start_time" value="{$time_info.start_hour}:{$time_info.start_minute}:{$time_info.start_second}" lay-verify="required" class="layui-input">
<i class=" iconrili iconfont calendar"></i>
</div>
<span class="layui-form-mid">-</span>
<div class="layui-input-inline">
<input type="text" id="add_end_time" value="{$time_info.end_hour}:{$time_info.end_minute}:{$time_info.end_second}" lay-verify="required" class="layui-input">
<i class=" iconrili iconfont calendar"></i>
</div>
</div>
<div class="word-aux">
<p>每个场次的时间段不能重叠</p>
</div>
</div>
</div>
<div class="form-row">
<button class="layui-btn" lay-submit lay-filter="save">保存</button>
<button class="layui-btn layui-btn-primary" onclick="backSeckillList()">返回</button>
</div>
<input type="hidden" name="id" value="{$time_info.id}" />
</div>
<script>
layui.use(['form','laydate'], function() {
var form = layui.form,
laydate = layui.laydate;
repeat_flag = false; //防重复标识
form.render();
// 表单提交监听
form.on('submit(save)', function(data) {
if (repeat_flag) return;
repeat_flag = true;
data.field.name = $('#name').val();
if (!data.field.name) {
layer.msg("秒杀场次名称不能为空");
return false;
}
if (!$('#add_start_time').val()) {
layer.msg("开始时间不能为空");
return false;
}
if (!$('#add_end_time').val()) {
layer.msg("结束时间不能为空");
return false;
}
if($('#add_end_time').val() <= $('#add_start_time').val()){
layer.msg("结束时间必须大于开始时间");
return false;
}
data.field.start_hour = $('#add_start_time').val().split(":")[0];
data.field.start_minute = $('#add_start_time').val().split(":")[1];
data.field.start_second = $('#add_start_time').val().split(":")[2];
data.field.end_hour = $('#add_end_time').val().split(":")[0];
data.field.end_minute = $('#add_end_time').val().split(":")[1];
data.field.end_second = $('#add_end_time').val().split(":")[2];
$.ajax({
url: ns.url("seckill://shop/seckill/edit"),
data: data.field,
type: "post",
dataType: "JSON",
success: function(res) {
repeat_flag = false;
if (res.code == 0) {
layer.confirm('编辑成功', {
title: '操作提示',
btn: ['返回列表', '继续操作'],
yes: function(index, layero) {
location.hash = ns.hash("seckill://shop/seckill/lists");
layer.close(index);
},
btn2: function(index, layero) {
layer.close(index);
}
});
} else {
layer.msg(res.message);
}
}
});
});
form.verify({
timeHour: function(value) {
if (!new RegExp("^0|[1-9]|1[0-9]|2[0-3]$").test(value)) {
return '时段范围为0-23且只能是整数';
}
},
timeMinSend: function(value) {
if (!new RegExp("^(?:0|[0-5][0-9]?)$").test(value)) {
return '分秒范围为0-59且只能是整数';
}
}
});
laydate.render({
elem: '#add_end_time',
type: 'time'
});
laydate.render({
elem: '#add_start_time',
type: 'time'
});
});
function backSeckillList() {
location.hash = ns.hash("seckill://shop/seckill/lists");
}
</script>

View File

@@ -0,0 +1,186 @@
<link rel="stylesheet" type="text/css" href="SECKILL_CSS/goods.css"/>
<div class="layui-form form-wrap main-form">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>活动名称:</label>
<div class="layui-input-block">
<input type="text" name="seckill_name" value="{$seckill_info['seckill_name']??''}" lay-verify="required" placeholder="请输入活动名称" autocomplete="off" class="layui-input len-long" maxlength="40">
</div>
<div class="word-aux">
<p>活动名称将显示在列表中展示,方便商家管理使用</p>
</div>
</div>
<div class="layui-form-item layui-form-text">
<label class="layui-form-label">活动规则说明:</label>
<div class="layui-input-block">
<textarea name="remark" class="layui-textarea len-long" maxlength="300" placeholder="请输入活动规则说明">{$seckill_info['remark']??''}</textarea>
</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-inline">
<div class="layui-input-inline len-mid">
<input type="text" id="start_time" name="start_time" {notempty name="$seckill_info"}value="{:date('Y-m-d H:i:s', $seckill_info.start_time)}"{/notempty} lay-verify="required" autocomplete="off" class="layui-input" readonly>
<i class="iconrili iconfont calendar"></i>
</div>
<span class="layui-form-mid">-</span>
<div class="layui-input-inline len-mid end-time">
<input type="text" id="end_time" name="end_time" lay-verify="required|time" {notempty name="$seckill_info"}value="{:date('Y-m-d H:i:s', $seckill_info.end_time)}"{/notempty} autocomplete="off" class="layui-input" readonly>
<input type="hidden" value="{$seckill_info.end_time??''}" id="old_end_time">
<i class="iconrili iconfont calendar"></i>
</div>
</div>
<div class="word-aux">
<p>商品只会在活动时间段内的指定场次进行展示</p>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">排序:</label>
<div class="layui-input-block">
<input type="number" name="sort" value="{$seckill_info['sort']??''}" class="layui-input len-short" placeholder="0" autocomplete="off">
</div>
<div class="word-aux">商品默认排序号为0数字越大排序越靠前数字重复则最新添加的靠前。</div>
</div>
<div class="seckill-goods-list">
<div class="layui-form-item">
<label class="layui-form-label"><span class="required">*</span>参与场次:</label>
<div class="layui-input-block time-label-list">
<a href="javascript:addSeckillTime();" class="text-color js-add-time">选择场次</a>
<ul></ul>
</div>
</div>
</div>
<div class="layui-form-item goods_list">
<label class="layui-form-label"><span class="required">*</span>商品选择:</label>
<div class="layui-input-block">
<table id="selected_goods_list" lay-filter="selected_goods_list"></table>
{if empty($seckill_info) }
<button class="layui-btn" onclick="addGoods()">选择商品</button>
<span class="goods_num">已选商品(<span id="goods_num" class="text-color">0</span></span>
{/if}
</div>
</div>
<input type="hidden" name="id" value="{$seckill_info.id??''}">
<input type="hidden" name="seckill_time_id" value="{$seckill_info['seckill_time_id']??''}">
{notempty name="$time_list"}
<input type="hidden" name="time_list" value='{:json_encode($time_list, JSON_UNESCAPED_UNICODE)}'>
{/notempty}
{notempty name="$seckill_info"}
<input type="hidden" name="sku_list" value='{:json_encode($seckill_info.goods_sku, JSON_UNESCAPED_UNICODE)}'>
{/notempty}
<div class="form-row">
<button class="layui-btn" lay-submit lay-filter="save">保存</button>
<button class="layui-btn layui-btn-primary" onclick="backSeckillGoodsList()">返回</button>
</div>
</div>
<!-- 操作 -->
<script type="text/html" id="operation">
<div class="table-btn">
{if !empty($seckill_info) }
{{# if (d.is_select == 1){ }}
<a class="layui-btn no-participation">不参与</a>
{{# }else{ }}
<a class="layui-btn participation">参与</a>
{{# } }}
{else/}
<a class="layui-btn" onclick="delGoods(this,{{d.sku_id}})">删除</a>
{/if}
</div>
</script>
<!-- 价格设置 -->
<script type="text/html" id="seckillPrice">
{{# if (d.is_select == 1){ }}
<input type="number" class="layui-input len-input " value="{{d.seckill_price}}" onchange="setGoodsSku('seckill_price', {{d.sku_id}}, this)" min="0"/>
{{# }else{ }}
<input type="number" class="layui-input len-input" value="{{d.seckill_price}}" onchange="setGoodsSku('seckill_price', {{d.sku_id}}, this)" min="0"/>
{{# } }}
</script>
<script type="text/html" id="toolbarOperation">
<button class="layui-btn layui-btn-primary" lay-event="seckill-purchase">限购</button>
<button class="layui-btn layui-btn-primary" lay-event="seckill-price">秒杀价</button>
<button class="layui-btn layui-btn-primary" lay-event="seckill-stock">秒杀库存</button>
</script>
<!-- 库存设置 -->
<script type="text/html" id="seckillStock">
{{# if (d.is_select == 1){ }}
<input type="number" class="layui-input len-input seckill_stock" value="{{d.seckill_stock}}" onchange="setGoodsSku('seckill_stock', {{d.sku_id}}, this)" min="0.00"/>
{{# }else{ }}
<input type="number" class="layui-input len-input seckill_stock" value="{{d.seckill_stock}}" onchange="setGoodsSku('seckill_stock', {{d.sku_id}}, this)" min="0.00"/>
{{# } }}
</script>
<!-- 限购设置 -->
<script type="text/html" id="maxBuy">
{{# if (d.is_select == 1){ }}
<input type="number" class="layui-input len-input max_buy" value="{{d.max_buy}}" onchange="setGoodsSku('max_buy', {{d.sku_id}}, this)" min="0"/>
{{# }else{ }}
<input type="number" class="layui-input len-input max_buy" value="{{d.max_buy}}" onchange="setGoodsSku('max_buy', {{d.sku_id}}, this)" min="0"/>
{{# } }}
</script>
<!--选择场次弹出-->
<script type="text/html" id="seckillTime">
<div class="seckill-box">
<table id="seckill_time_list" lay-filter="seckill_time_list"></table>
</div>
</script>
<script type="text/html" id="timecheckbox">
{{# if (d.is_select == 1){ }}
<input type="checkbox" name="time_checkbox" data-name="{{d.name}}" data-time-start="{{d.seckill_start_time}}" checked data-time-end="{{d.seckill_end_time}}" data-time-id="{{d.id}}" class="time-select" lay-skin="primary" lay-filter="goods_checkbox">
{{# }else{ }}
<input type="checkbox" name="time_checkbox" data-name="{{d.name}}" data-time-start="{{d.seckill_start_time}}" data-time-end="{{d.seckill_end_time}}" data-time-id="{{d.id}}" class="time-select" lay-skin="primary" lay-filter="goods_checkbox">
{{# } }}
</script>
<!-- 添加场次 -->
<script type="text/html" id="addTime">
<div class="layui-form ">
<div class="layui-form-item len-mid">
<label class="layui-form-label"><span class="required">*</span></label>
<div class="layui-input-block">
{{# if(d.name){ }}
<input type="text" id="add_time_name" value="{{d.name}}" lay-verify="required" autocomplete="off" class="layui-input len-mid">
{{# }else{ }}
<input type="text" id="add_time_name" value="" lay-verify="required" autocomplete="off" class="layui-input len-mid">
{{# } }}
</div>
</div>
<div class="layui-form-item ">
<div class="layui-inline">
<label class="layui-form-label"><span class="required">*</span></label>
<div class="layui-inline">
<div class="layui-input-inline">
<input type="text" id="add_start_time" value="{{d.seckill_start_time_show ? d.seckill_start_time_show : ''}}" lay-verify="required" class="layui-input">
<i class=" iconrili iconfont calendar"></i>
</div>
<span class="layui-form-mid">-</span>
<div class="layui-input-inline">
<input type="text" id="add_end_time" value="{{d.seckill_end_time_show ? d.seckill_end_time_show :''}}" lay-verify="required" class="layui-input">
<i class=" iconrili iconfont calendar"></i>
</div>
</div>
</div>
</div>
</div>
</script>
<script src="SECKILL_JS/goods.js?time=20250103"></script>

View File

@@ -0,0 +1,652 @@
<style>
.contraction span{cursor: pointer;display: inline-block;width: 17px;height: 17px;text-align: center;line-height: 14px;user-select: none;}
.sku-list{overflow: hidden;padding: 0 45px;max-width: 100%;}
.sku-list li .img-wrap{vertical-align: middle;margin-right: 8px;width: 20%;height: 80px;text-align: center;line-height: 70px;}
.sku-list li .img-wrap img{max-width: 100%;max-height: 100%;}
.sku-list li .info-wrap span.sku-name{-webkit-line-clamp: 2;margin-bottom: 5px;}
.sku-list li .info-wrap span{display: -webkit-box;margin-bottom: 5px;overflow: hidden;text-overflow: ellipsis;white-space: normal;word-break: break-all;-webkit-box-orient: vertical;-webkit-line-clamp: 1;}
.sku-list li{float: left;display: flex;padding: 10px;margin-right: 10px;margin-bottom: 10px;border: 1px solid #EFEFEF;width: 294px;height: 180px;align-items: center;}
#time_label_dl span{margin: 3px 5px 3px 0;color: white;padding: 0 5px;border-radius: 5px;line-height: 25px;}
#time_label_dl{display: flex;flex-wrap: wrap;}
.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="clickAdd()">添加秒杀商品</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="goods_name" placeholder="请输入商品名称" autocomplete="off" class="layui-input">
</div>
</div>
<div class="layui-inline">
<label class="layui-form-label">参与场次:</label>
<div class="layui-input-inline">
<select name="seckill_time_id">
<option value="">全部</option>
{foreach $res as $k => $v}
<option value="{$v['id']}" {if $v['id'] == $seckill_time_id}selected{/if}>{$v['name']}</option>
{/foreach}
</select>
</div>
</div>
</div>
<div class="layui-form-item">
<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="bargain_tab">
<ul class="layui-tab-title">
<li class="layui-this" data-status="">全部</li>
<li data-status="0">未开始</li>
<li data-status="1">进行中</li>
<li data-status="2">已结束</li>
<li data-status="-1">已关闭</li>
</ul>
<div class="layui-tab-content">
<!-- 列表 -->
<table id="good_list" lay-filter="good_list"></table>
</div>
</div>
<!--价格-->
<script type="text/html" id="price">
<div class="layui-elip">{{d.seckill_price}}</div>
</script>
<!-- 推广 -->
{include file="app/shop/view/component/promote_show.html"}
<!--时间-->
<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="operation">
<div class="operation-wrap" data-seckill-id="{{d.id}}">
<div class="popup-qrcode-wrap" style="display: none"><img class="popup-qrcode-loadimg" src="__STATIC__/loading/loading.gif"/></div>
<div class="table-btn">
{{# if(d.status == 1){ }}
<a class="layui-btn text-color" lay-event="select">推广</a>
{{# } }}
<a class="layui-btn" lay-event="edit">编辑</a>
<a class="layui-btn" lay-event="delete">删除</a>
{{# if(d.status == 1){ }}
<a class="layui-btn" lay-event="close">关闭</a>
{{# } }}
</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="invalid">批量关闭</button>
</script>
<script type="text/html" id="goods_name">
<div class="table-title">
<div class="contraction" data-id="{{d.id}}" data-open="0">
<span>+</span>
</div>
<div class="title-pic">
{{# if(d.goods_image){ }}
<img layer-src="{{ns.img(d.goods_image.split(',')[0],'big')}}" src="{{ns.img(d.goods_image.split(',')[0],'small')}}" />
{{# } }}
</div>
<div class="title-content">
<a href="javascript:;" class="multi-line-hiding text-color-sub" title="{{d.goods_name}}">{{d.goods_name}}</a>
</div>
</div>
</script>
<script type="text/html" id="skuList">
<tr class="js-list-{{d.index}}" id="sku_img_{{d.index}}">
<td colspan="10">
<ul class="sku-list">
{{# for(var i=0; i<d.list.length; i++){ }}
<li>
<div class="img-wrap">
<img layer-src src="{{ns.img(d.list[i].sku_image)}}">
</div>
<div class="info-wrap">
<span class="sku-name" title="{{d.list[i].sku_name}}">{{d.list[i].sku_name}}</span>
<span class="price">商品价格{{d.list[i].price}}</span>
<span class="sale_num">秒杀价{{d.list[i].seckill_price}}</span>
<span class="price">库存{{d.list[i].stock}}</span>
</div>
</li>
{{# } }}
</ul>
</td>
</tr>
</script>
<!-- 场次 -->
<script id="time_label" type="text/html">
{{# if (d.time_list != []) { }}
<div id="time_label_dl">
{{# for (var index in d.time_list) { }}
{{'<span class="bg-color">' + d.time_list[index]['name'] + '</span>'}}
{{# } }}
</div>
{{# } }}
</script>
<script type="text/html" id="addTime">
<div class="layui-form">
<div class="layui-form-item len-mid">
<label class="layui-form-label"><span class="required">*</span></label>
<div class="layui-input-block">
{{# if(d.name){ }}
<input type="text" id="add_time_name" value="{{d.name}}" lay-verify="required" autocomplete="off" class="layui-input len-mid">
{{# }else{ }}
<input type="text" id="add_time_name" value="" lay-verify="required" autocomplete="off" class="layui-input len-mid">
{{# } }}
</div>
</div>
<div class="layui-form-item ">
<div class="layui-inline">
<label class="layui-form-label"><span class="required">*</span></label>
<div class="layui-inline">
<div class="layui-input-inline">
<input type="text" id="add_start_time" value="{{d.seckill_start_time_show}}" lay-verify="required" class="layui-input">
<i class=" iconrili iconfont calendar"></i>
</div>
<span class="layui-form-mid">-</span>
<div class="layui-input-inline">
<input type="text" id="add_end_time" value="{{d.seckill_end_time_show}}" lay-verify="required" class="layui-input">
<i class=" iconrili iconfont calendar"></i>
</div>
</div>
</div>
</div>
</div>
</script>
<!-- 编辑排序 -->
<script type="text/html" id="editSort">
<input name="sort" type="number" onchange="editSort({{d.id}}, this)" value="{{d.sort}}" class="layui-input edit-sort len-short">
</script>
<script>
var form, table, laytpl,
repeat_flag = false, //防重复标识
arr_id_good = [];
$("body").off("click", ".contraction").on("click", ".contraction", function() {
var seckill_id = $(this).attr("data-id");
var open = $(this).attr("data-open");
var tr = $(this).parent().parent().parent().parent();
var index = tr.attr("data-index");
if (open == 1) {
$(this).children("span").text("+");
$(".js-list-" + index).remove();
} else {
$(this).children("span").text("-");
$.ajax({
url: ns.url("seckill://shop/seckill/getSkuList"),
data: {
seckill_id: seckill_id
},
dataType: 'JSON',
type: 'POST',
async: false,
success: function(res) {
var sku_list = $("#skuList").html();
var data = {
list: res.data,
index: index
};
laytpl(sku_list).render(data, function(html) {
tr.after(html);
});
layer.photos({
photos: '.img-wrap',
anim: 5
});
}
});
}
$(this).attr("data-open", (open == 0 ? 1 : 0));
});
layui.use(['form', 'laytpl','laydate', 'element'], function() {
form = layui.form;
element = layui.element;
laytpl = layui.laytpl;
laydate = layui.laydate;
form.render();
element.on('tab(bargain_tab)', function(data) {
table.reload({
page: {
curr: 1
},
where: {
'status': this.getAttribute('data-status')
}
});
});
table = new Table({
elem: '#good_list',
url: '{:addon_url("seckill://shop/seckill/goodslist")}',
async: false,
parseData: function(res) {
arr_id_good = [];
for (var i in res.data.list) {
arr_id_good.push(res.data.list[i].sku_id);
}
return {
"code": res.code,
"msg": res.message,
"count": res.data.count,
"data": res.data.list,
};
},
where:{"seckill_time_id" : "{$seckill_time_id}"},
cols: [
[{
type: 'checkbox',
width: '3%',
},{
title: '商品',
unresize: 'false',
width: '18%',
templet: '#goods_name'
}, {
title: '秒杀时间',
unresize: 'false',
width: '16%',
templet: '#time'
}, {
title: '参与场次',
unresize: 'false',
align:"left",
width: '18%',
templet: '#time_label'
}, {
title: '秒杀价',
unresize: 'false',
width: '7%',
templet: '#price'
}, {
title: '库存',
unresize: 'false',
width: '6%',
field: 'goods_stock'
}, {
title: '销量',
unresize: 'false',
width: '6%',
field: 'sale_num'
}, {
field: 'sort',
unresize:'false',
title: `排序<i class="iconfont iconwenhao1 required growth" style="color:#000;" title="后台商品默认排序为排序号正序排列(即排序号越小越靠前),如果序号相同,那么按照添加顺序排列,越新添加的越靠前"></i>`,
width: '9%',
align: 'center',
templet: '#editSort',
sort: true
}, {
title: '状态',
unresize: 'false',
width: '10%',
templet: function (data) {
if(data.status == 1){
return '进行中'
}else if(data.status == 0){
return '未开始'
}else if(data.status == 2){
return '已过期'
}else if(data.status == -1){
return '已关闭(手动)'
}
}
}, {
title: '操作',
toolbar: '#operation',
unresize: 'false',
align:'right'
}]
],
toolbar: '#toolbarAction'
});
table.on("sort",function (obj) {
table.reload({
page: {
curr: 1
},
where: {
order:obj.field,
sort:obj.type
}
});
});
//开始时间
laydate.render({
elem: '#start_time', //指定元素
type: 'datetime'
});
//结束时间
laydate.render({
elem: '#end_time', //指定元素
type: 'datetime'
});
/**
* 搜索功能
*/
form.on('submit(search)', function(data) {
table.reload({
page: {
curr: 1
},
where: data.field
});
});
// 监听工具栏操作
table.toolbar(function (obj) {
var data = obj.data;
if(data.length <= 0) return;
var seckillIdAll = [];
for (var i in data){
seckillIdAll.push(data[i].id);
}
switch (obj.event) {
case 'delete':
deleteSeckillAll(seckillIdAll)
break;
case 'invalid':
closeSeckillAll(seckillIdAll)
break;
}
})
//批量删除
function deleteSeckillAll(data){
if (repeat_flag) return false;
repeat_flag = true;
layer.confirm('确定要删除商品吗?', function(index) {
layer.close(index);
$.ajax({
url: '{:addon_url("seckill://shop/seckill/deleteGoodsAll")}',
data: {
"seckill_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 closeSeckillAll(data)
{
if (repeat_flag) return false;
repeat_flag = true;
layer.confirm('确定要关闭商品吗?', function(index) {
layer.close(index);
$.ajax({
url: '{:addon_url("seckill://shop/seckill/closeSeckillAll")}',
data: {
"seckill_id": data
},
dataType: 'JSON',
type: 'POST',
success: function(res) {
layer.msg(res.message);
repeat_flag = false;
table.reload();
}
});
}, function() {
layer.close();
repeat_flag = false;
});
}
/**
* 监听工具栏操作
*/
table.tool(function(obj) {
var data = obj.data;
switch (obj.event) {
case 'delete': //查看
delSeckill(data.id);
break;
case 'edit': //查看
location.hash = ns.hash("seckill://shop/seckill/updateGoods?id=" + data.id);
break;
case 'select': //推广
seckillUrl(data);
break;
case 'close': //关闭
closeSeckill(data.id);
break;
}
});
/**
* 删除
*/
function delSeckill(seckill_id) {
if (repeat_flag) return false;
repeat_flag = true;
layer.confirm('确定要删除该商品吗?', function(index) {
layer.close(index);
$.ajax({
url: '{:addon_url("seckill://shop/seckill/deleteGoods")}',
data: {
"id": seckill_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 closeSeckill(seckill_id) {
if (repeat_flag) return false;
repeat_flag = true;
layer.confirm('确定要关闭该商品吗?', function(index) {
layer.close(index);
$.ajax({
url: '{:addon_url("seckill://shop/seckill/closeSeckill")}',
data: {
"seckill_id": seckill_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 seckillUrl(data){
new PromoteShow({
url:ns.url("seckill://shop/seckill/seckillUrl"),
param:{seckill_id:data.id},
})
}
});
function clickAdd() {
location.hash = ns.hash("seckill://shop/seckill/addGoods");
}
function clickAddTime() {
var data = {};
laytpl($('#addTime').html()).render(data, function(html) {
var index = layer.open({
type: 1,
title: "场次添加",
area: ['700px', '300px'],
btn: ['保存', '返回'],
content: html,
yes: function(index, layero) {
var data = {};
data.name = $('#add_time_name').val();
if (!data.name) {
layer.msg("秒杀场次名称不能为空");
return false;
}
if (!$('#add_start_time').val()) {
layer.msg("开始时间不能为空");
return false;
}
if (!$('#add_end_time').val()) {
layer.msg("结束时间不能为空");
return false;
}
data.start_hour = $('#add_start_time').val().split(":")[0];
data.start_minute = $('#add_start_time').val().split(":")[1];
data.start_second = $('#add_start_time').val().split(":")[2];
data.end_hour = $('#add_end_time').val().split(":")[0];
data.end_minute = $('#add_end_time').val().split(":")[1];
data.end_second = $('#add_end_time').val().split(":")[2];
if (repeat_flag) return;
repeat_flag = true;
$.ajax({
url: ns.url("seckill://shop/seckill/add"),
data: data,
dataType: 'JSON',
type: 'POST',
success: function(res) {
repeat_flag = false;
if (res.code == 0) {
layer.msg(res.message, {}, function() {
layer.close(index);
});
} else {
layer.msg(res.message);
}
}
});
}
});
laydate.render({
elem: '#add_end_time',
type: 'time'
});
laydate.render({
elem: '#add_start_time',
type: 'time'
});
});
}
// 监听单元格编辑
function editSort(id, event){
var data = $(event).val();
if (data == '') {
$(event).val(0);
data = 0;
}
if(!new RegExp("^-?[0-9]\\d*$").test(data)){
layer.msg("排序号只能是整数");
return ;
}
if(data<0){
layer.msg("排序号必须大于0");
return ;
}
$.ajax({
type: 'POST',
url: ns.url("seckill://shop/seckill/seckillSort"),
data: {
sort: data,
id: id
},
dataType: 'JSON',
success: function(res) {
layer.msg(res.message);
if(res.code==0){
table.reload();
}
}
});
}
</script>

View File

@@ -0,0 +1,104 @@
<div class="single-filter-box">
<button class="layui-btn" onclick="clickAdd()">添加秒杀场次</button>
</div>
<table id="seckill_list" lay-filter="seckill_list"></table>
<!-- 操作 -->
<script type="text/html" id="operation">
<div class="table-btn">
<a class="layui-btn" lay-event="check">查看商品</a>
<a class="layui-btn" lay-event="edit">编辑</a>
<a class="layui-btn" lay-event="delete">删除</a>
</div>
</script>
<script>
layui.use('form', function() {
var repeat_flag = false; //防重复标识
var table = new Table({
elem: '#seckill_list',
url: ns.url("seckill://shop/seckill/lists"),
parseData: function(res) { //res 即为原始返回的数据
return {
"code": res.code, //解析接口状态
"msg": res.message,
"data": res.data
};
},
cols: [
[{
field: 'name',
title: '时段名称',
unresize: 'false',
width: '20%'
}, {
field: 'seckill_start_time_show',
title: '开始时间',
unresize: 'false',
width: '20%'
}, {
field: 'seckill_end_time_show',
title: '结束时间',
unresize: 'false',
width: '20%'
},{
field: 'goods_num',
title: '商品数量',
unresize: 'false',
width: '20%',
}, {
title: '操作',
toolbar: '#operation',
unresize: 'false',
align:'right'
}]
],
page: false
});
/**
* 监听工具栏操作
*/
table.tool(function(obj) {
var data = obj.data;
switch (obj.event) {
case 'check': //查看
location.hash = ns.hash("seckill://shop/seckill/goodslist?seckill_time_id=" + data.id);
break;
case 'delete': //删除
layer.confirm('确定要删除该场次吗?', function(index) {
if (repeat_flag) return false;
repeat_flag = true;
layer.close(index);
$.ajax({
url: ns.url("seckill://shop/seckill/delete?id=" + data.id),
data: data,
dataType: 'JSON',
type: 'POST',
success: function(res) {
layer.msg(res.message);
repeat_flag = false;
if (res.code == 0) {
table.reload({
page: {
curr: 1
},
});
}
}
});
});
break;
case 'edit': //编辑
location.hash = ns.hash("seckill://shop/seckill/edit?id=" + data.id);
break;
}
});
});
function clickAdd() {
location.hash = ns.hash("seckill://shop/seckill/add");
}
</script>