This commit is contained in:
cun-nan 2024-08-12 09:36:58 +08:00
parent ba98275dab
commit 12cc890e91
3 changed files with 518 additions and 258 deletions

View File

@ -1,286 +1,385 @@
<template> <template>
<div class="content"> <div class="content">
<div class="tab-box"> <div class="tab-box">
<div class="tab_" :class="{active:index== tabindex }" @click="getindex(index)" v-for="(item,index) in tabs" :key="index"> <div class="tab_" :class="{active:index== tabindex }" @click="getindex(index)" v-for="(item,index) in tabs"
{{item.name}} :key="index">
{{ item.name }}
</div> </div>
</div> </div>
<div class="cot-box" v-if="tabindex==0" > <div class="cot-box" v-if="tabindex==0">
<div class="d-s-b"> <div>
<div class="d-s"> <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" label-width="120px">
<el-input v-model="input" placeholder="请输入内容" style="margin-right: 15px;width: 185px"></el-input>
<el-date-picker <el-form-item label="" prop="groupName" style="width: 180px">
v-model="value" <el-input
type="datetime" v-model="queryParams.groupName"
placeholder="选择日期时间"> placeholder="请输入分组名称"
</el-date-picker> clearable
</div> @keyup.enter.native="handleQuery"
<div class="d-s"> />
<el-button type="primary" icon="el-icon-search">搜索</el-button> </el-form-item>
<el-button icon="el-icon-refresh-right" >重置</el-button> <el-form-item label="">
<el-button type="primary" >新增分组</el-button> <el-date-picker
</div> v-model="beginTime"
</div> style="width: 160px"
<!-- --> type="date"
<el-table placeholder="开始日期">
:data="tableData" </el-date-picker>
border
style="width: 100%"> <el-date-picker
<el-table-column type="index" width="50" align="center" label="序号"/> v-model="endTime"
<el-table-column style="width: 160px"
prop="date" type="date"
label="分组名称" placeholder="结束日期">
width="180"> </el-date-picker>
</el-table-column> </el-form-item>
<el-table-column <el-form-item style="float: right">
prop="name" <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
label="备注" <el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
width="180"> <el-button type="primary" @click="handleAdd">新增分组</el-button>
</el-table-column> </el-form-item>
<el-table-column
prop="address" </el-form>
label="会员数量">
</el-table-column>
<el-table-column
prop="address"
label="会员占比">
</el-table-column>
<el-table-column align="center" prop="status" label="状态">
<template slot-scope="scope">
<el-switch
v-model="scope.row.status"
active-value="qy"
inactive-value="jy"
active-color="#13ce66"
inactive-color="#ff4949">
</el-switch>
</template>
</el-table-column>
<el-table-column
prop="address"
label="创建人">
</el-table-column>
<el-table-column
prop="address"
label="创建时间">
</el-table-column>
<el-table-column
prop="address"
label="更新时间">
</el-table-column>
<el-table-column align="center" label="操作" width="120">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
@click="handleUpdate(scope.row)"
>修改</el-button>
<el-button
size="mini"
type="text"
@click="handleRecharge(scope.row)"
>删除</el-button>
</template>
</el-table-column>
</el-table>
</div>
<div class="cot-box" v-if="tabindex==1" >
<div class="d-s-b">
<div class="d-s">
<el-input v-model="input" placeholder="请输入内容" style="margin-right: 15px;width: 185px"></el-input>
<el-date-picker
v-model="value"
type="datetime"
placeholder="选择日期时间">
</el-date-picker>
</div>
<div class="d-s">
<el-button type="primary" icon="el-icon-search">搜索</el-button>
<el-button icon="el-icon-refresh-right" >重置</el-button>
<el-button type="primary" >新增定时群发</el-button>
</div>
</div> </div>
<!-- --> <!-- -->
<el-table <div style="height: 70vh;overflow: auto">
:data="tableData" <el-table
border :data="userGroupList"
style="width: 100%"> border
<el-table-column type="index" width="50" align="center" label="序号"/> style="width: 100%">
<el-table-column <el-table-column type="index" width="50" align="center" label="序号"/>
prop="date" <el-table-column prop="groupName" label="分组名称" width="180"></el-table-column>
label="活动名称" <el-table-column prop="remark" label="备注" width="180"></el-table-column>
width="180"> <el-table-column prop="address" label="会员数量"></el-table-column>
</el-table-column> <el-table-column prop="address" label="会员占比"></el-table-column>
<el-table-column <el-table-column align="center" prop="status" label="状态">
prop="name" <template slot-scope="scope">
label="活动时间" <el-switch
width="180"> v-model="scope.row.status"
</el-table-column> active-value="qy"
<el-table-column inactive-value="jy"
prop="address" active-color="#13ce66"
label="发送频次"> inactive-color="#ff4949">
</el-table-column> </el-switch>
<el-table-column </template>
prop="address" </el-table-column>
label="群发会员"> <el-table-column prop="accountName" label="创建人"></el-table-column>
</el-table-column> <el-table-column prop="createTime" label="创建时间"></el-table-column>
<el-table-column prop="updateTime" label="更新时间"></el-table-column>
<el-table-column <el-table-column align="center" label="操作" width="120">
prop="address" <template slot-scope="scope">
label="群发礼品"> <el-button
</el-table-column> size="mini"
<el-table-column type="text"
prop="status" @click="handleUpdate(scope.row)"
label="活动状态"> >修改
<template slot-scope="scope"> </el-button>
<div v-if="scope.row.status == 0" style="color: #FF7E00">未开始</div> <el-button
<div v-if="scope.row.status == 1" style="color: #00CAFF">进行中</div> size="mini"
<div v-if="scope.row.status == 2" style="color: #0DC291">已结束</div> type="text"
</template> @click="handleDelete(scope.row)"
</el-table-column> >删除
<el-table-column </el-button>
prop="address" </template>
label="创建人"> </el-table-column>
</el-table-column> </el-table>
<el-table-column </div>
prop="address" <pagination
label="创建时间"> v-show="total>0"
</el-table-column> :total="total"
<el-table-column align="center" label="操作" width="120"> :page.sync="queryParams.page"
<template slot-scope="scope"> :limit.sync="queryParams.pageSize"
<el-button @pagination="getList"
size="mini" />
type="text"
@click="handleUpdate(scope.row)"
>修改</el-button>
<el-button
size="mini"
type="text"
@click="handleRecharge(scope.row)"
>删除</el-button>
</template>
</el-table-column>
</el-table>
</div> </div>
<div class="cot-box" v-if="tabindex==2" > <div class="cot-box" v-if="tabindex==1">
<div class="d-s-b"> <div>
<div class="d-s"> <el-form :model="queryParams1" ref="queryForm" size="small" :inline="true" label-width="120px">
<el-input v-model="input" placeholder="请输入内容" style="margin-right: 15px;width: 185px"></el-input>
<el-date-picker
v-model="value"
type="datetime"
placeholder="选择日期时间">
</el-date-picker>
</div>
<div class="d-s">
<el-button type="primary" icon="el-icon-search">搜索</el-button>
<el-button icon="el-icon-refresh-right" >重置</el-button>
</div> <el-form-item label="" prop="groupName" style="width: 180px">
<el-input
v-model="queryParams1.groupName"
placeholder="请输入活动名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="">
<el-date-picker
v-model="beginTime1"
style="width: 160px"
type="date"
placeholder="开始日期">
</el-date-picker>
<el-date-picker
v-model="endTime1"
style="width: 160px"
type="date"
placeholder="结束日期">
</el-date-picker>
</el-form-item>
<el-form-item style="float: right">
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
<el-button type="primary" @click="handleAdd">新增定时群发</el-button>
</el-form-item>
</el-form>
</div> </div>
<!-- --> <!-- -->
<el-table <div style="height: 70vh;overflow: auto">
:data="tableData" <el-table
border :data="massSendList"
style="width: 100%"> border
<el-table-column type="index" width="50" align="center" label="序号"/> style="width: 100%">
<el-table-column <el-table-column type="index" width="50" align="center" label="序号"/>
prop="date" <el-table-column prop="name" label="活动名称" width="180"></el-table-column>
label="活动名称" <el-table-column prop="activityTime" label="活动时间" width="180"></el-table-column>
width="180"> <el-table-column prop="sendFrequency" label="发送频次"></el-table-column>
</el-table-column> <el-table-column prop="address" label="群发会员"></el-table-column>
<el-table-column
prop="name"
label="群发礼品"
width="180">
</el-table-column>
<el-table-column
prop="address"
label="群发方式">
</el-table-column>
<el-table-column
prop="address"
label="群发内容">
</el-table-column>
<el-table-column <el-table-column prop="senfGift" label="群发礼品"></el-table-column>
prop="address" <el-table-column prop="status" label="活动状态">
label="群发会员数量"> <template slot-scope="scope">
</el-table-column> <div v-if="scope.row.status == 0" style="color: #FF7E00">未开始</div>
<el-table-column <div v-if="scope.row.status == 1" style="color: #00CAFF">进行中</div>
prop="address" <div v-if="scope.row.status == 2" style="color: #0DC291">已结束</div>
label="成功数量"> </template>
</el-table-column> </el-table-column>
<el-table-column <el-table-column prop="accountName" label="创建人"></el-table-column>
prop="address" <el-table-column prop="createTime" label="创建时间"></el-table-column>
label="失败数量"> <el-table-column align="center" label="操作" width="120">
</el-table-column> <template slot-scope="scope">
<el-table-column <el-button
prop="address" size="mini"
label="状态"> type="text"
</el-table-column> v-if="scope.row.status == 0"
<el-table-column @click="handleUpdate(scope.row)"
prop="address" >修改
label="已领取数量"> </el-button>
</el-table-column> <el-button
<el-table-column size="mini"
prop="address" type="text"
label="已核销数量"> @click="handleDelete(scope.row)"
</el-table-column> >删除
<el-table-column </el-button>
prop="address" </template>
label="未核销数量"> </el-table-column>
</el-table-column> </el-table>
<el-table-column </div>
prop="address" <pagination
label="操作人员"> v-show="total1>0"
</el-table-column> :total="total1"
<el-table-column :page.sync="queryParams1.page"
prop="address" :limit.sync="queryParams1.pageSize"
label="群发时间"> @pagination="getList1"
</el-table-column> />
<el-table-column align="center" label="操作" width="120">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
@click="handleRecharge(scope.row)"
>删除</el-button>
</template>
</el-table-column>
</el-table>
</div> </div>
<div class="cot-box" v-if="tabindex==2">
<div >
<el-form :model="queryParams2" ref="queryForm" size="small" :inline="true" label-width="120px">
<el-form-item label="" prop="groupName" style="width: 180px">
<el-select v-model="queryParams2.status" placeholder="请选择">
<el-option label="已发送" value="0"></el-option>
<el-option label="发送失败" value="1"></el-option>
</el-select>
</el-form-item>
<el-form-item label="">
<el-date-picker
v-model="beginTime2"
style="width: 160px"
type="date"
placeholder="开始日期">
</el-date-picker>
<el-date-picker
v-model="endTime2"
style="width: 160px"
type="date"
placeholder="结束日期">
</el-date-picker>
</el-form-item>
<el-form-item style="float: right">
<el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
</div>
<!-- -->
<div>
<el-table
:data="massSendRecordList"
border
style="width: 100%">
<el-table-column type="index" width="50" align="center" label="序号"/>
<el-table-column prop="activityName" label="活动名称" width="180"> </el-table-column>
<el-table-column prop="sendGift" label="群发礼品" width="180"> </el-table-column>
<el-table-column prop="sendWay" label="群发方式"> </el-table-column>
<el-table-column prop="address" label="群发内容"> </el-table-column>
<el-table-column prop="userNum" label="群发会员数量"> </el-table-column>
<el-table-column prop="successNum" label="成功数量"> </el-table-column>
<el-table-column prop="failNum" label="失败数量"> </el-table-column>
<el-table-column prop="status" label="状态"> </el-table-column>
<el-table-column prop="address" label="已领取数量"> </el-table-column>
<el-table-column prop="address" label="已核销数量"> </el-table-column>
<el-table-column prop="address" label="未核销数量"> </el-table-column>
<el-table-column prop="accountName" label="操作人员"> </el-table-column>
<el-table-column prop="createTime" label="群发时间"> </el-table-column>
<el-table-column align="center" label="操作" width="120">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
@click="handleDelete(scope.row)"
>删除
</el-button>
</template>
</el-table-column>
</el-table>
</div>
<pagination
v-show="total2>0"
:total="total2"
:page.sync="queryParams2.page"
:limit.sync="queryParams2.pageSize"
@pagination="getList2"
/>
</div>
<!-- 添加或修改对话框 -->
<el-dialog :title="title" :visible.sync="open" width="30%" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="分组名称" prop="labelName">
<el-input v-model="form.labelName" placeholder="请输入分组名称" maxlength="30"/>
</el-form-item>
<el-form-item label="会员等级" prop="paymentType">
<el-select v-model="form.paymentType" placeholder="请选择会员等级" style="width: 100%">
<el-option label="现金" value="CASH"></el-option>
</el-select>
</el-form-item>
<el-form-item label="会员标签" prop="paymentType">
<el-select v-model="form.paymentType" placeholder="请选择会员标签(多选)" style="width: 100%">
<el-option label="现金" value="CASH"></el-option>
</el-select>
</el-form-item>
<el-form-item label="会员性别" prop="paymentType">
<el-select v-model="form.paymentType" placeholder="请选择会员标签(多选)" style="width: 100%">
<el-option label="现金" value="CASH"></el-option>
</el-select>
</el-form-item>
<el-form-item label="会员年龄" prop="paymentType">
<el-input placeholder="请输入内容" v-model="form.age">
<template slot="append">.com</template>
</el-input>
</el-form-item>
<el-form-item label="会员余额" prop="paymentType">
<el-input placeholder="请输入内容" v-model="form.age">
<template slot="append">.com</template>
</el-input>
</el-form-item>
<el-form-item label="会员积分" prop="paymentType">
<el-input placeholder="请输入内容" v-model="form.age">
<template slot="append">.com</template>
</el-input>
</el-form-item>
<el-form-item label="充值次数" prop="paymentType">
<el-input placeholder="请输入内容" v-model="form.age">
<template slot="append">.com</template>
</el-input>
</el-form-item>
<el-form-item label="充值金额" prop="paymentType">
<el-input placeholder="请输入内容" v-model="form.age">
<template slot="append">.com</template>
</el-input>
</el-form-item>
<el-form-item label="消费周期" prop="paymentType">
<el-select v-model="form.paymentType" placeholder="请选择会员标签(多选)" style="width: 100%">
<el-option label="现金" value="CASH"></el-option>
</el-select>
</el-form-item>
<el-form-item label="消费油品" prop="paymentType">
<el-select v-model="form.paymentType" placeholder="请选择会员标签(多选)" style="width: 100%">
<el-option label="现金" value="CASH"></el-option>
</el-select>
</el-form-item>
<el-form-item label="消费次数" prop="paymentType">
<el-input placeholder="请输入内容" v-model="form.age">
<template slot="append">.com</template>
</el-input>
</el-form-item>
<el-form-item label="消费金额" prop="paymentType">
<el-input placeholder="请输入内容" v-model="form.age">
<template slot="append">.com</template>
</el-input>
</el-form-item>
<el-form-item label="平均消费" prop="paymentType">
<el-input placeholder="请输入内容" v-model="form.age">
<template slot="append">.com</template>
</el-input>
</el-form-item>
<el-form-item label="状态" prop="status">
<el-switch
v-model="form.status"
active-value="qy"
inactive-value="jy"
active-color="#13ce66"
inactive-color="#ff4949">
</el-switch>
</el-form-item>
<el-form-item label="备注" >
<el-input v-model="form.remark" placeholder="请输入备注" type="textarea"/>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</div> </div>
</template> </template>
<script> <script>
import {addUserGroup, deleteUserGroup, editUserGroup, getUserGroup, listUserGroup} from "@/api/userGroup/usergroup";
import {listUserMassSend} from "@/api/userGroup/userMassSend";
import {listUserMassSendRecord} from "@/api/userGroup/userMassSendRecord";
export default { export default {
data() { data() {
return { return {
tabindex:0, tabindex: 0,
tableData: [{ tableData: [{
status:0, status: 0,
date: '2016-05-02', date: '2016-05-02',
name: '王小虎', name: '王小虎',
address: '上海市普陀区金沙江路 1518 弄' address: '上海市普陀区金沙江路 1518 弄'
}, { }, {
status:0, status: 0,
date: '2016-05-04', date: '2016-05-04',
name: '王小虎', name: '王小虎',
address: '上海市普陀区金沙江路 1517 弄' address: '上海市普陀区金沙江路 1517 弄'
}, { }, {
status:0, status: 0,
date: '2016-05-01', date: '2016-05-01',
name: '王小虎', name: '王小虎',
address: '上海市普陀区金沙江路 1519 弄' address: '上海市普陀区金沙江路 1519 弄'
}, { }, {
status:0, status: 0,
date: '2016-05-03', date: '2016-05-03',
name: '王小虎', name: '王小虎',
address: '上海市普陀区金沙江路 1516 弄' address: '上海市普陀区金沙江路 1516 弄'
}], }],
input:'', input: '',
value: '', value: '',
tabs: [ tabs: [
{ {
@ -292,24 +391,180 @@ export default {
{ {
name: "群发记录", name: "群发记录",
} }
] ],
total: 0,
queryParams: {
page: 1,
pageSize: 10
},
beginTime: "",
endTime: "",
userGroupList: [],
total1: 0,
queryParams1: {
page: 1,
pageSize: 10
},
beginTime1: "",
endTime1: "",
massSendList: [],
total2: 0,
queryParams2: {
page: 1,
pageSize: 10
},
beginTime2: "",
endTime2: "",
massSendRecordList: [],
title:'',
open:false,
form:{},
//
rules: {
labelName: [
{required: true, message: "标签名称不能为空", trigger: "blur"},
],
status: [
{required: true, message: "状态不能为空", trigger: "blur"}
]
}
}; };
}, },
created() {
this.getList()
},
methods: { methods: {
getindex(index){ //
cancel() {
this.open = false;
this.reset();
},
//
submitForm: function () {
this.$refs["form"].validate(valid => {
if (valid) {
if (!this.form.id) {
addUserGroup(this.form).then(res => {
this.$message.success("添加成功")
this.open = false
this.queryParams.page = 1;
this.getList()
})
} else {
editUserGroup(this.form).then(res => {
this.$message.success("修改成功")
this.open = false
this.queryParams.page = 1;
this.getList()
})
}
}
});
},
getList() {
let dateRange = []
if (this.beginTime && this.endTime) {
dateRange.push(this.beginTime.toLocaleDateString())
dateRange.push(this.endTime.toLocaleDateString())
}
listUserGroup(this.addDateRange(this.queryParams, dateRange)).then(res => {
this.userGroupList = res.data.records
this.total = res.data.total
})
},
getList1() {
let dateRange = []
if (this.beginTime1 && this.endTime1) {
dateRange.push(this.beginTime1.toLocaleDateString())
dateRange.push(this.endTime1.toLocaleDateString())
}
listUserMassSend(this.addDateRange(this.queryParams1, dateRange)).then(res => {
this.massSendList = res.data.records
this.total1 = res.data.total
})
},
getList2() {
let dateRange = []
if (this.beginTime2 && this.endTime2) {
dateRange.push(this.beginTime2.toLocaleDateString())
dateRange.push(this.endTime2.toLocaleDateString())
}
listUserMassSendRecord(this.addDateRange(this.queryParams2, dateRange)).then(res => {
this.massSendRecordList = res.data.records
this.total2 = res.data.total
})
},
//
handleUpdate(row) {
this.reset();
getUserGroup(row.id).then(res => {
this.open = true;
this.form = res.data;
this.title = "修改会员标签"
})
},
//
reset() {
this.resetForm("form");
},
//
handleDelete(row) {
const name = row.labelName || this.id;
this.$modal.confirm('是否删除本条数据,删除后无法恢复!').then(function () {
return deleteUserGroup(row.id);
}).then(() => {
this.queryParams.page = 1
this.getList();
this.$modal.msgSuccess("删除成功");
}).catch(() => {
});
},
//
handleAdd() {
this.reset();
this.form = {
status: "qy"
}
this.open = true;
this.title = "新增会员标签";
},
//
handleQuery() {
this.queryParams.page = 1;
this.getList();
},
//
resetQuery() {
this.dateRange = [];
this.queryParams = {
page: 1,
pageSize: 10,
}
this.beginTime = ''
this.endTime = ''
this.handleQuery();
},
getindex(index) {
this.tabindex = index this.tabindex = index
if (index==0){
this.getList()
}else if (index==1){
this.getList1()
}else if (index==2){
this.getList2()
}
} }
} }
} }
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
.content{ .content {
background: #f5f7f8; background: #f5f7f8;
width: 100%; width: 100%;
height: 100vh; height: 100vh;
} }
.tab-box{ .tab-box {
width: 100%; width: 100%;
height: 40px; height: 40px;
background: #fff; background: #fff;
@ -318,7 +573,8 @@ export default {
margin-bottom: 25px; margin-bottom: 25px;
} }
.tab_{
.tab_ {
width: 75px; width: 75px;
height: 100%; height: 100%;
//border-bottom: 2px solid #FF770F; //border-bottom: 2px solid #FF770F;
@ -331,11 +587,13 @@ export default {
margin-left: 50px; margin-left: 50px;
cursor: pointer; cursor: pointer;
} }
.active{
.active {
border-bottom: 2px solid #FF770F !important; border-bottom: 2px solid #FF770F !important;
color: #FF770F !important; color: #FF770F !important;
} }
.cot-box{
.cot-box {
width: 98%; width: 98%;
border-radius: 8px; border-radius: 8px;
background: #fff; background: #fff;
@ -343,14 +601,16 @@ export default {
padding: 20px; padding: 20px;
margin: 0 auto; margin: 0 auto;
} }
.d-s-b{
.d-s-b {
width: 100%; width: 100%;
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: space-between; justify-content: space-between;
margin-bottom: 25px; margin-bottom: 25px;
} }
.d-s{
.d-s {
display: flex; display: flex;
align-items: center; align-items: center;
} }

View File

@ -44,7 +44,7 @@ public class UserMassSendRecord extends BaseEntity implements Serializable {
/** /**
* 群发礼品0积分1优惠券2成长值 * 群发礼品0积分1优惠券2成长值
*/ */
private String senfGift; private String sendGift;
/** /**
* 群发方式0短信消息 * 群发方式0短信消息
*/ */

View File

@ -16,8 +16,8 @@
<if test="entity.status != null and entity.status != ''"> <if test="entity.status != null and entity.status != ''">
and umsr.status = #{entity.status} and umsr.status = #{entity.status}
</if> </if>
<if test="entity.name != null and entity.name != ''"> <if test="entity.activityName != null and entity.activityName != ''">
and ums.name like concat('%', #{entity.name}, '%') and ums.name like concat('%', #{entity.activityName}, '%')
</if> </if>
<if test="entity.params.beginTime != null and entity.params.beginTime != ''"><!-- 开始时间检索 --> <if test="entity.params.beginTime != null and entity.params.beginTime != ''"><!-- 开始时间检索 -->
and date_format(ums.create_time,'%y%m%d') &gt;= date_format(#{entity.params.beginTime},'%y%m%d') and date_format(ums.create_time,'%y%m%d') &gt;= date_format(#{entity.params.beginTime},'%y%m%d')