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,51 +1,58 @@
<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"
:key="index">
{{ item.name }} {{ 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-form-item label="" prop="groupName" style="width: 180px">
<el-input
v-model="queryParams.groupName"
placeholder="请输入分组名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="">
<el-date-picker <el-date-picker
v-model="value" v-model="beginTime"
type="datetime" style="width: 160px"
placeholder="选择日期时间"> type="date"
placeholder="开始日期">
</el-date-picker> </el-date-picker>
</div>
<div class="d-s"> <el-date-picker
<el-button type="primary" icon="el-icon-search">搜索</el-button> v-model="endTime"
<el-button icon="el-icon-refresh-right" >重置</el-button> style="width: 160px"
<el-button type="primary" >新增分组</el-button> type="date"
</div> 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>
<!-- --> <!-- -->
<div style="height: 70vh;overflow: auto">
<el-table <el-table
:data="tableData" :data="userGroupList"
border border
style="width: 100%"> style="width: 100%">
<el-table-column type="index" width="50" align="center" label="序号"/> <el-table-column type="index" width="50" align="center" label="序号"/>
<el-table-column <el-table-column prop="groupName" label="分组名称" width="180"></el-table-column>
prop="date" <el-table-column prop="remark" label="备注" width="180"></el-table-column>
label="分组名称" <el-table-column prop="address" label="会员数量"></el-table-column>
width="180"> <el-table-column prop="address" label="会员占比"></el-table-column>
</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 align="center" prop="status" label="状态"> <el-table-column align="center" prop="status" label="状态">
<template slot-scope="scope"> <template slot-scope="scope">
<el-switch <el-switch
@ -57,204 +64,296 @@
</el-switch> </el-switch>
</template> </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 prop="updateTime" label="更新时间"></el-table-column>
</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"> <el-table-column align="center" label="操作" width="120">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
@click="handleUpdate(scope.row)" @click="handleUpdate(scope.row)"
>修改</el-button> >修改
</el-button>
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
@click="handleRecharge(scope.row)" @click="handleDelete(scope.row)"
>删除</el-button> >删除
</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
</div> </div>
<pagination
v-show="total>0"
:total="total"
:page.sync="queryParams.page"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
</div>
<div class="cot-box" v-if="tabindex==1"> <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-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 <el-date-picker
v-model="value" v-model="beginTime1"
type="datetime" style="width: 160px"
placeholder="选择日期时间"> type="date"
placeholder="开始日期">
</el-date-picker> </el-date-picker>
</div>
<div class="d-s"> <el-date-picker
<el-button type="primary" icon="el-icon-search">搜索</el-button> v-model="endTime1"
<el-button icon="el-icon-refresh-right" >重置</el-button> style="width: 160px"
<el-button type="primary" >新增定时群发</el-button> type="date"
</div> 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>
<!-- --> <!-- -->
<div style="height: 70vh;overflow: auto">
<el-table <el-table
:data="tableData" :data="massSendList"
border border
style="width: 100%"> style="width: 100%">
<el-table-column type="index" width="50" align="center" label="序号"/> <el-table-column type="index" width="50" align="center" label="序号"/>
<el-table-column <el-table-column prop="name" label="活动名称" width="180"></el-table-column>
prop="date" <el-table-column prop="activityTime" label="活动时间" width="180"></el-table-column>
label="活动名称" <el-table-column prop="sendFrequency" label="发送频次"></el-table-column>
width="180"> <el-table-column prop="address" label="群发会员"></el-table-column>
</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="群发礼品">
</el-table-column>
<el-table-column
prop="status"
label="活动状态">
<template slot-scope="scope"> <template slot-scope="scope">
<div v-if="scope.row.status == 0" style="color: #FF7E00">未开始</div> <div v-if="scope.row.status == 0" style="color: #FF7E00">未开始</div>
<div v-if="scope.row.status == 1" style="color: #00CAFF">进行中</div> <div v-if="scope.row.status == 1" style="color: #00CAFF">进行中</div>
<div v-if="scope.row.status == 2" style="color: #0DC291">已结束</div> <div v-if="scope.row.status == 2" style="color: #0DC291">已结束</div>
</template> </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>
<el-table-column
prop="address"
label="创建时间">
</el-table-column>
<el-table-column align="center" label="操作" width="120"> <el-table-column align="center" label="操作" width="120">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
v-if="scope.row.status == 0"
@click="handleUpdate(scope.row)" @click="handleUpdate(scope.row)"
>修改</el-button> >修改
</el-button>
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
@click="handleRecharge(scope.row)" @click="handleDelete(scope.row)"
>删除</el-button> >删除
</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
</div> </div>
<pagination
v-show="total1>0"
:total="total1"
:page.sync="queryParams1.page"
:limit.sync="queryParams1.pageSize"
@pagination="getList1"
/>
</div>
<div class="cot-box" v-if="tabindex==2"> <div class="cot-box" v-if="tabindex==2">
<div class="d-s-b"> <div >
<div class="d-s"> <el-form :model="queryParams2" 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-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>
<!-- --> <!-- -->
<div>
<el-table <el-table
:data="tableData" :data="massSendRecordList"
border border
style="width: 100%"> style="width: 100%">
<el-table-column type="index" width="50" align="center" label="序号"/> <el-table-column type="index" width="50" align="center" label="序号"/>
<el-table-column <el-table-column prop="activityName" label="活动名称" width="180"> </el-table-column>
prop="date" <el-table-column prop="sendGift" label="群发礼品" width="180"> </el-table-column>
label="活动名称" <el-table-column prop="sendWay" label="群发方式"> </el-table-column>
width="180"> <el-table-column prop="address" label="群发内容"> </el-table-column>
</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="userNum" label="群发会员数量"> </el-table-column>
prop="address" <el-table-column prop="successNum" label="成功数量"> </el-table-column>
label="群发会员数量"> <el-table-column prop="failNum" label="失败数量"> </el-table-column>
</el-table-column> <el-table-column prop="status" label="状态"> </el-table-column>
<el-table-column <el-table-column prop="address" label="已领取数量"> </el-table-column>
prop="address" <el-table-column prop="address" label="已核销数量"> </el-table-column>
label="成功数量"> <el-table-column prop="address" label="未核销数量"> </el-table-column>
</el-table-column> <el-table-column prop="accountName" label="操作人员"> </el-table-column>
<el-table-column <el-table-column prop="createTime" label="群发时间"> </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="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="address"
label="群发时间">
</el-table-column>
<el-table-column align="center" label="操作" width="120"> <el-table-column align="center" label="操作" width="120">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
@click="handleRecharge(scope.row)" @click="handleDelete(scope.row)"
>删除</el-button> >删除
</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
</div> </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 {
@ -292,12 +391,168 @@ 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: {
//
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) { 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()
}
} }
} }
} }
@ -318,6 +573,7 @@ export default {
margin-bottom: 25px; margin-bottom: 25px;
} }
.tab_ { .tab_ {
width: 75px; width: 75px;
height: 100%; height: 100%;
@ -331,10 +587,12 @@ 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;
@ -343,6 +601,7 @@ 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;
@ -350,6 +609,7 @@ export default {
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')