多租户商城-商户端
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

502 lines
17 KiB

<template>
<div class="addGroupBuy">
<!-- 新增用户 -->
<div class="addGroupBuyBox">
<el-form ref="ruleForm" class="formBox" :model="addForm" label-width="150px" :rules="groupBuyRules" :disabled="visitDetail">
<div class="flexBox">
<el-form-item label="活动名称" prop="groupName">
<el-input v-model="addForm.groupName" maxlength="15" placeholder="请输入活动名称" oninput="value=value.replace(/\s+/g, '')" />
</el-form-item>
</div>
<div class="flexBox">
<el-form-item label="备注">
<el-input v-model="addForm.remark" maxlength="200" placeholder="请输入备注" />
</el-form-item>
</div>
<el-form-item class="timeDataBox" label="拼团使用时间">
<div class="dateBox">
<el-form-item>
<el-date-picker
v-model="dateInfo"
type="datetimerange"
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期"
value-format="yyyy-MM-dd HH:mm:ss"
/>
</el-form-item>
</div>
</el-form-item>
<el-form-item class="inputW" label="成团人数" prop="person">
<el-input v-model="addForm.person" maxlength="9" oninput="value=value.replace(/[^\d]/g,'')" />人
</el-form-item>
<el-form-item class="inputW" label="成团有效时间" prop="effectiveTime">
<el-input v-model="addForm.effectiveTime" maxlength="9" oninput="value=value.replace(/[^\d]/g,'')" />小时
</el-form-item>
<el-form-item class="boxWidth" label="商品限购" prop="proQuota">
<el-radio v-model="addForm.ifLimit" label="1">不限购</el-radio>
<el-radio v-model="addForm.ifLimit" label="2">限购</el-radio>
<el-input v-model="addForm.limitNumber" maxlength="9" :disabled="addForm.ifLimit === '1'" oninput="value=value.replace(/[^\d]/g,'')" />件/人
</el-form-item>
<el-form-item class="boxWidth" label="活动预热" prop="preheat">
<el-radio v-model="addForm.ifEnable" label="1">停用</el-radio>
<el-radio v-model="addForm.ifEnable" label="2">启用</el-radio>
<el-input v-model="addForm.enableTime" maxlength="9" :disabled="addForm.ifEnable === '1'" oninput="value=value.replace(/[^\d]/g,'')" />小时前
</el-form-item>
<el-form-item label="优惠券叠加" prop="overlying">
<el-radio v-model="addForm.ifAdd" label="1">叠加</el-radio>
<el-radio v-model="addForm.ifAdd" label="0">不叠加</el-radio>
</el-form-item>
<el-form-item class="applyType" label="活动商品" prop="commodity">
<span class="selectBtn" @click="chooseProduct"><span v-if="!visitDetail">请选择</span><span v-else>查看商品</span><i v-if="addForm.details.length !== 0" class="selectNum">{{ addForm.details.length }}</i></span>
</el-form-item>
</el-form>
</div>
<span slot="footer" class="dialog-footer">
<el-button v-show="!visitDetail" type="primary" @click="addGroupBuyFn('ruleForm')">保 存</el-button>
<el-button v-if="visitDetail" type="primary" @click="goToGroupBuy">取 消</el-button>
<el-button v-else type="danger" @click="goToGroupBuy">取 消</el-button>
</span>
<!-- 新建分组弹框 -->
<el-dialog
:title="visitDetail ? '查看商品' : '选择商品'"
:visible.sync="isVisible"
width="55%"
top="50px"
class="group-dialog"
:close-on-click-modal="false"
:modal-append-to-body="false"
:modal="false"
>
<!-- 表格 -->
<div class="tableBox">
<el-table
ref="multipleTable"
:data="tableData"
border
:header-cell-style="{ background: '#EEF3FF', color: '#333333' }"
tooltip-effect="dark"
style="width: 100%"
:row-key="getRowKeys"
max-height="600"
@selection-change="handleSelectionChange"
>
<el-table-column
v-if="!visitDetail"
type="selection"
:reserve-selection="true"
width="55"
/>
<el-table-column label="商品信息" width="200" align="center">
<template slot-scope="scope">
<img height="80" width="80" :src="scope.row.image " alt srcset>
</template>
</el-table-column>
<el-table-column prop="productName" label="" />
<el-table-column prop="originalPrice" label="原价(元)" width="120" />
<el-table-column prop="value" label="规格" width="120" />
<el-table-column prop="workPrice" label="拼团价(元)" width="153">
<template slot-scope="scope">
<el-input-number v-model="scope.row.workPrice" :disabled="visitDetail" size="small" :controls="false" :max="10000000" :min="0.01" :precision="2" @change="changeInput(scope.row)" />
<!-- <el-input v-model="scope.row.workPrice" size="small" type="number" oninput="value=value.replace(/-/, '')" /> -->
</template>
</el-table-column>
<el-table-column prop="stockNumber" label="库存" width="120" show-overflow-tooltip />
<!-- <el-table-column width="80" label="操作" show-overflow-tooltip>-->
<!-- <template slot-scope="scope">-->
<!-- <div class="btnList">-->
<!-- <el-popconfirm title="确定删除此券?" @onConfirm="delGroupBuyFn(scope.row)">-->
<!-- <el-button slot="reference" class="delCls" type="text">删除</el-button>-->
<!-- </el-popconfirm>-->
<!-- </div>-->
<!-- </template>-->
<!-- </el-table-column>-->
</el-table>
<div class="fenye">
<el-pagination
:current-page="proOption.page"
:page-sizes="[10, 20, 50, 100]"
:page-size="proOption.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="total"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
/>
</div>
<div class="footBtnBox">
<span slot="footer">
<el-button v-if="!visitDetail" type="primary" @click="saveIdList">确 定</el-button>
<el-button @click="closeSelect"> </el-button>
</span>
</div>
</div>
</el-dialog>
</div>
</template>
<script>
import { addGroupBuy, getGroupButPro, groupUpdate, groupDetail } from '@/api/marketing'
function InitGroupForm() {
this.details = [] // 商品明细数据
this.effectiveTime = null // 成团有效时间几(小时)
this.enableTime = null // 预热几小时前
this.endTime = '' // 活动结束时间
this.groupName = '' // 活动名称
this.ifAdd = '1' // 优惠券是否叠加 1-是 0-否
this.ifEnable = '1' // 活动预热 1-停用 2-启用
this.ifLimit = '1' // 商品限购 1-不限购 2-限购
this.limitNumber = null // 限购几件/人
this.person = null // 成团人数
this.remark = '' // 备注
this.startTime = '' // 活动开始时间
}
export default {
name: 'AddGroupBuy',
props: {
groupId: {
type: Number,
default: 0
},
visitDetail: {
type: Boolean,
default: false
}
},
data() {
return {
// 新增
getRowKeys(row) {
return row.skuId
},
addForm: new InitGroupForm(),
proOption: {
page: 1,
pageSize: 10
},
details: [],
dateInfo: [], // 时间数组
total: 0,
tableData: [],
shopGroupWorkId: '', // 拼团ID
groupBuyRules: {
groupName: [
{ required: true, message: '请输入活动名称', trigger: 'blur' }
],
person: [{ required: true, message: '请输入成团人数', trigger: 'blur' }],
effectiveTime: [{ required: true, message: '请输入成团有效时间', trigger: 'blur' }]
},
multipleSelection: [],
roleList: [],
isVisible: false, // 选择商品弹窗
inputGroupTableData: []
}
},
watch: {
groupId: {
handler(nVal, oVal) {
this.shopGroupWorkId = nVal
if (!nVal) {
this.addForm = new InitGroupForm()
this.dateInfo = []
this.inputGroupTableData = []
} else {
this.addForm = new InitGroupForm()
this.getGroupBuyInfo()
}
}
}
},
mounted() {
this.getProList()
this.shopGroupWorkId = this.groupId
if (this.shopGroupWorkId) {
this.getGroupBuyInfo()
}
},
methods: {
changeInput(data) {
const index = this.inputGroupTableData.findIndex(item => item.skuId === data.skuId)
if (index === -1) {
this.inputGroupTableData.push(data)
} else {
this.inputGroupTableData[index].workPrice = data.workPrice
}
},
reset() {
this.proOption.page = 1
if (this.shopGroupWorkId === 0) {
this.addForm = new InitGroupForm()
this.dateInfo = []
this.inputGroupTableData = []
}
if (this.$refs.multipleTable) {
this.$refs.multipleTable.clearSelection()
}
},
addGroupBuyFn(ruleForm) {
this.$refs[ruleForm].validate(valid => {
if (valid) {
if (this.dateInfo.length === 0) {
this.$message.warning('请选择用券时间开始和结束日期')
return false
}
if (this.addForm.ifLimit === '2' && this.addForm.limitNumber === null) {
this.$message.warning('请填写活动限购件数')
return false
}
if (this.addForm.ifEnable === ' 2' && this.addForm.enableTime === null) {
this.$message.warning('请填写活动预热前多少小时')
return false
}
if (this.addForm.person < 2 || this.addForm.person > 10) {
this.$message.warning('拼团人数只能在2~10人之间 !')
return false
}
this.addForm.startTime = this.dateInfo[0]
this.addForm.endTime = this.dateInfo[1]
if (this.shopGroupWorkId) {
groupUpdate(this.addForm).then(res => {
if (res.code === '') {
this.$message.success('修改成功')
this.$emit('reset')
} else {
this.$message.error(res.message)
}
})
} else {
addGroupBuy(this.addForm).then(res => {
if (res.code === '') {
this.$message.success('提交成功')
this.$emit('reset')
} else {
this.$message.error(res.message)
}
})
}
} else {
console.log('error submit!!')
return false
}
})
},
handleSizeChange(val) {
this.proOption.pageSize = val
this.getProList()
},
handleCurrentChange(val) {
this.proOption.page = val
this.getProList()
},
// 选择商品
chooseProduct(type) {
this.isVisible = true
if (this.visitDetail) {
this.proOption.activityId = this.shopGroupWorkId
} else {
this.proOption.activityId = null
}
this.getProList()
},
getProList() {
getGroupButPro(this.proOption).then(res => {
if (res.code === '') {
const dataList = res.data.list
if (this.inputGroupTableData.length > 0) {
dataList.forEach(item => {
const index = this.inputGroupTableData.findIndex(cItem => cItem.skuId === item.skuId)
if (index !== -1) {
item.workPrice = this.inputGroupTableData[index].workPrice
}
})
}
this.tableData = dataList
this.total = res.data.total
// 点击编辑时回显表格勾选
/* if (this.$refs.multipleTable) {
for (let i = 0; i < this.tableData.length; i++) {
for (let j = 0; j < this.addForm.details.length; j++) {
if (this.tableData[i].productId === this.addForm.details[j].productId && this.tableData[i].skuId === this.addForm.details[j].skuId) {
this.$refs.multipleTable.toggleRowSelection(this.tableData[i]);
}
}
}
} */
}
})
},
// 选中商品
handleSelectionChange(val) {
this.multipleSelection = val
},
// 保存选择商品ID
saveIdList() {
try {
const idList = []
this.multipleSelection.forEach(item => {
console.log(item)
if (!item.workPrice) {
this.$message.warning('请输入价格')
throw new Error()
}
idList.push({
price: item.workPrice,
productId: item.productId,
skuId: item.skuId
})
})
this.addForm.details = idList
this.isVisible = false
} catch (e) {
console.log(e)
}
},
// 取消选择
closeSelect() {
this.isVisible = false
},
// 跳转秒杀列表
goToGroupBuy() {
this.$emit('reset')
},
async getGroupBuyInfo() {
const res = await groupDetail({ shopGroupWorkId: this.shopGroupWorkId })
this.addForm.groupBuyContent = res.data.groupBuyContent
this.addForm.groupName = res.data.groupName
this.addForm.person = res.data.person
this.addForm.effectiveDay = res.data.effectiveDay
this.addForm.effectiveTime = res.data.effectiveTime
this.addForm.startTime = res.data.startTime
this.addForm.endTime = res.data.endTime
this.addForm.enableTime = res.data.enableTime
this.addForm.frequency = res.data.frequency
this.addForm.ifAdd = res.data.ifAdd.toString()
this.addForm.ifEnable = res.data.ifEnable.toString()
this.addForm.ifLimit = res.data.ifLimit.toString()
this.addForm.number = res.data.number
this.addForm.limitNumber = res.data.limitNumber
this.addForm.remark = res.data.remark
this.addForm.shopGroupWorkId = res.data.shopGroupWorkId
console.log(res, 'res')
console.log(res.data.products, 'res.data.products')
const idList = res.data.products
idList.forEach(i => {
this.addForm.details.push({
price: i.workPrice || i.originalPrice,
productId: i.productId,
skuId: i.skuId
})
})
this.dateInfo = [this.addForm.startTime, this.addForm.endTime]
}
}
}
</script>
<style lang='scss' scoped>
//@import url(); 引入公共css类
@import url("../../../styles/elDialog.scss");
.addGroupBuy {
background: #FFFFFF;
.dialog-footer {
display: flex;
justify-content: center;
.el-button {
margin: 0px 16px;
}
}
.formBox {
margin-top: 20px;
.flexBox {
display: flex;
}
.applyType {
span {
width: 100px;
height: 30px;
line-height: 30px;
background: #66b1ff;
color: #FFFFFF;
text-align: center;
display: inline-block;
font-size: 14px;
margin-right: 30px;
border-radius: 4px;
cursor: pointer;
position: relative;
i {
position: absolute;
right: -10px;
top: -10px;
width: 25px;
height: 25px;
line-height: 25px;
background: #FFFFFF;
border-radius: 50%;
border: 1px solid #66b1ff;
text-align: center;
color: #409EFF;
font-style: normal;
font-size: 12px;
}
}
}
}
.footBtnBox {
width: 100%;
display: flex;
justify-content: center;
margin-top: 50px;
}
.dateBox {
display: flex;
align-items: center;
.description {
width: 59px;
text-align: center;
display: block;
font-size: 14px;
color: #999999;
}
}
}
</style>
<style scoped>
.flexBox /deep/ .el-input {
width: 500px;
}
.inputW /deep/ .el-input {
width: 100px;
margin: 0 8px 0 0;
}
.inputW /deep/ .el-input .el-input__inner {
text-align: center;
}
.inputW /deep/ .el-form-item__error {
padding-left: 0;
}
.inputW /deep/ .el-checkbox {
margin-left: 20px;
}
.inputW /deep/ .el-radio {
margin-left: 30px;
}
.boxWidth /deep/ .el-input {
width: 100px;
margin-right: 15px;
}
.boxWidth /deep/ .el-input .el-input__inner {
text-align: center;
}
.addGroupBuy .timeDataBox /deep/ .el-form-item__content {
display: flex;
align-items: center;
}
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
-webkit-appearance: none;
}
input[type="number"]{
-moz-appearance: textfield;
}
</style>