You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

192 lines
8.0 KiB
Vue

<template>
<div class="container">
<!-- 填写信息 -->
<el-row :gutter="20">
<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
<el-form ref="form" :model="form" :rules="rules" label-width="auto" class="form" size="medium">
<el-form-item label="优惠券名称" prop="couponName">
<el-input v-model.trim="form.couponName" placeholder="优惠券名称"></el-input>
</el-form-item>
<el-form-item label="优惠券数量" prop="couponNumber">
<el-input-number v-model="form.couponNumber" :min="1" :precision="0" label="优惠券数量" style="width:100%"></el-input-number>
</el-form-item>
<el-form-item label="优惠方式" prop="couponType">
<el-radio v-model="form.couponType" :label="0">代金券</el-radio>
<el-radio v-model="form.couponType" :label="1">折扣券</el-radio>
<el-radio v-model="form.couponType" :label="2">代扣券</el-radio>
</el-form-item>
<el-form-item label="优惠限制" prop="serviceConditions">
<el-radio v-model="form.serviceConditions" :label="0">满减</el-radio>
<el-radio v-model="form.serviceConditions" :label="1">没有限制</el-radio>
</el-form-item>
<el-form-item v-if="form.serviceConditions===0" prop="fullReductionMoney">
<amount-input ref="fullReductionMoney" @amount="handleAmount" name="fullReductionMoney" placeholder="满减金额(满多少可以减)"></amount-input>
</el-form-item>
<el-form-item label="适用门店" prop="suitableStore">
<el-radio v-model="form.suitableStore" :label="0">所有门店</el-radio>
<el-radio v-model="form.suitableStore" :label="1">指定门店</el-radio>
</el-form-item>
<el-form-item v-if="form.suitableStore===1" prop="useStoreList">
<el-button type="primary" size="mini">选择门店</el-button>
</el-form-item>
<el-form-item label="适用项目" prop="suitableProject">
<el-radio v-model="form.suitableProject" :label="0">所有项目</el-radio>
<el-radio v-model="form.suitableProject" :label="1">指定项目</el-radio>
</el-form-item>
<el-form-item v-if="form.suitableProject===1" prop="projectList">
<el-button type="primary" size="mini">选择项目</el-button>
</el-form-item>
<el-form-item label="有效方式" prop="indateType">
<el-radio v-model="form.indateType" :label="0">领取后多少天</el-radio>
<el-radio v-model="form.indateType" :label="1">固定日期</el-radio>
</el-form-item>
<el-form-item v-if="form.indateType===0" prop="startDay">
<el-input v-model.trim="form.startDay" placeholder="领取后多少天生效"></el-input>
</el-form-item>
<el-form-item v-if="form.indateType===0" prop="endDay">
<el-input v-model.trim="form.endDay" placeholder="生效后多少天内有效"></el-input>
</el-form-item>
<el-form-item v-if="form.indateType===1" prop="startDate">
<el-date-picker v-model="form.fixDate" type="daterange" range-separator="至" start-placeholder="开始日期" end-placeholder="截止日期" value-format="yyyy-MM-dd">
</el-date-picker>
</el-form-item>
<el-form-item label="分享提成规则" prop="shareCommissionRules">
<el-radio v-model="form.shareCommissionRules" :label="0">固定提成</el-radio>
<el-radio v-model="form.shareCommissionRules" :label="1">单据金额抽成(%)</el-radio>
</el-form-item>
<el-form-item v-if="form.shareCommissionRules===0" prop="fixedAmount">
<amount-input ref="fixedAmount" @amount="handleAmount" name="fixedAmount" placeholder="固定提成(元)"></amount-input>
</el-form-item>
<el-form-item v-if="form.shareCommissionRules===1" prop="orderCommission">
<amount-input ref="orderCommission" @amount="handleAmount" name="orderCommission" placeholder="单据金额抽成(%)"></amount-input>
</el-form-item>
<el-form-item label="活动图片" prop="imageUrl">
<active-img ref="activeImg" @active-img="handleImage"></active-img>
</el-form-item>
</el-form>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
<div class="box">
<el-button type="warning" @click="handleNext" size="medium">下一步</el-button>
<!-- <el-button type="primary" @click="handleNext" size="medium">提交</el-button> -->
<el-button @click="resetForm" size="medium">重置</el-button>
</div>
</el-col>
</el-row>
</div>
</template>
<script>
import AmountInput from '@/components/AmountInput/index'
import ActiveImg from './activeImg'
export default {
name: 'Form',
components: { AmountInput, ActiveImg },
data() {
return {
form: {
couponNumber: 1,
},
rules: {
couponName: [
{ required: true, message: '请输入优惠券名称', trigger: 'blur' },
],
couponNumber: [
{ required: true, message: '请输入优惠券数量', trigger: 'blur' },
],
serviceConditions: [
{ required: true, message: '请选择优惠限制', trigger: ['blur', 'change'] },
],
couponType: [
{ required: true, message: '请选择优惠方式', trigger: ['blur', 'change'] },
],
fullReductionMoney: [
{ required: true, message: '请输入满减金额', trigger: 'blur' },
],
suitableStore: [
{ required: true, message: '请选择适用门店', trigger: ['blur', 'change'] },
],
suitableProject: [
{ required: true, message: '请选择适用项目', trigger: ['blur', 'change'] },
],
indateType: [
{ required: true, message: '请选择有效方式', trigger: ['blur', 'change'] },
],
startDay: [
{ required: true, message: '请输入多少天', trigger: 'blur' },
],
endDay: [
{ required: true, message: '请输入多少天', trigger: 'blur' },
],
shareCommissionRules: [
{ required: true, message: '请选择分享提成规则', trigger: ['blur', 'change'] },
],
imageUrl: [{ required: true, message: '请上传活动图片', trigger: ['blur', 'change'] }],
},
}
},
methods: {
// ============================== 操作 ============================== //
// 下一步
handleNext() {
this.$refs.form.validate((valid) => {
if (valid) {
this.$emit('next', 2, this.form)
} else {
return false
}
})
},
// 重置
resetForm() {
let form = Object.assign({}, this.form);
if (form.serviceConditions === 0) {
this.$refs.fullReductionMoney.reset()
}
if (shareCommissionRules === 0) {
this.$refs.fixedAmount.reset()
}
if (shareCommissionRules === 1) {
this.$refs.orderCommission.reset()
}
this.$refs.form.resetFields()
this.$baseMessage('重置成功', 'success')
},
// ============================== 第三方插件方法 ============================== //
// 选择图片后返回
handleImage(file) {
let form = Object.assign({}, this.form);
form.multipartFile = file
this.form = Object.assign({}, form);
},
// 金额自定义组件返回值
handleAmount(name, amount) {
let form = Object.assign({}, this.form)
form[name] = amount
this.form = Object.assign({}, form)
},
// 发布后清除选择的文件
handleClear() {
this.$refs.activeImg.handleClear()
}
},
}
</script>
<style scoped>
.container .form {
width: 500px;
/* // margin: 0 auto; */
}
.container .box {
display: flex;
align-items: center;
justify-content: center;
padding: 50px 0;
}
.form .el-form-item {
margin-bottom: 15px;
}
</style>