会员管理,批量操作

master
382696293@qq.com 2 years ago
parent 6b9333533a
commit a4688c106a

@ -89,6 +89,8 @@ public class WxScriptTemplate extends BaseEntity
/** 子话术 */
private List<SysTag> children = new ArrayList<SysTag>();
private List<WxScriptTemplate> scriptTemplateChildren = new ArrayList<>();
private List<Long> tagIdArray = new ArrayList<Long>();
@ -259,6 +261,14 @@ public class WxScriptTemplate extends BaseEntity
this.tagIdArray = tagIdArray;
}
public List<WxScriptTemplate> getScriptTemplateChildren() {
return scriptTemplateChildren;
}
public void setScriptTemplateChildren(List<WxScriptTemplate> scriptTemplateChildren) {
this.scriptTemplateChildren = scriptTemplateChildren;
}
@Override
public String toString() {
return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)

@ -0,0 +1,31 @@
package com.flossom.common.core.domain.req;
public class AllSendScriptOperateReq {
private WxUserScriptReq wxUserScriptReq;
private WxUserMemberVm wxUserMemberVm;
public AllSendScriptOperateReq() {
}
public AllSendScriptOperateReq(WxUserScriptReq wxUserScriptReq, WxUserMemberVm wxUserMemberVm) {
this.wxUserScriptReq = wxUserScriptReq;
this.wxUserMemberVm = wxUserMemberVm;
}
public WxUserScriptReq getWxUserScriptReq() {
return wxUserScriptReq;
}
public void setWxUserScriptReq(WxUserScriptReq wxUserScriptReq) {
this.wxUserScriptReq = wxUserScriptReq;
}
public WxUserMemberVm getWxUserMemberVm() {
return wxUserMemberVm;
}
public void setWxUserMemberVm(WxUserMemberVm wxUserMemberVm) {
this.wxUserMemberVm = wxUserMemberVm;
}
}

@ -57,8 +57,6 @@ public class WxUserScriptReq {
/**
* 013456
*/
@NotNull(message = "请选择跳转类型")
@Range(min = 0, max = 6)
private Integer type;
/**
@ -94,12 +92,12 @@ public class WxUserScriptReq {
/**
* (xxx,xxx,xxx)
*/
private String tagNames;
private List<String> tagNames;
/**
* ID(xxxx,xxxx,xxx)
*/
private String tagIds;
private List<String> tagIds;
public List<Long> getUserIdList() {
@ -214,19 +212,19 @@ public class WxUserScriptReq {
this.feedId = feedId;
}
public String getTagNames() {
public List<String> getTagNames() {
return tagNames;
}
public void setTagNames(String tagNames) {
public void setTagNames(List<String> tagNames) {
this.tagNames = tagNames;
}
public String getTagIds() {
public List<String> getTagIds() {
return tagIds;
}
public void setTagIds(String tagIds) {
public void setTagIds(List<String> tagIds) {
this.tagIds = tagIds;
}

@ -4,6 +4,7 @@ import com.fasterxml.jackson.annotation.JsonInclude;
import com.flossom.common.core.domain.entity.SysDept;
import com.flossom.common.core.domain.entity.SysMenu;
import com.flossom.common.core.domain.entity.SysTag;
import com.flossom.common.core.domain.entity.WxScriptTemplate;
import java.io.Serializable;
import java.util.List;
@ -27,6 +28,11 @@ public class TreeSelect implements Serializable {
*/
private String label;
/**
*
*/
private String content;
/**
*
*/
@ -55,6 +61,13 @@ public class TreeSelect implements Serializable {
this.children = sysTag.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList());
}
public TreeSelect(WxScriptTemplate wxScriptTemplate) {
this.id = wxScriptTemplate.getId();
this.label = wxScriptTemplate.getTitile();
this.content = wxScriptTemplate.getContent();
this.children = wxScriptTemplate.getScriptTemplateChildren().stream().map(TreeSelect::new).collect(Collectors.toList());
}
public Long getId() {
return id;
}
@ -78,4 +91,12 @@ public class TreeSelect implements Serializable {
public void setChildren(List<TreeSelect> children) {
this.children = children;
}
public String getContent() {
return content;
}
public void setContent(String content) {
this.content = content;
}
}

@ -4,7 +4,6 @@ import java.util.List;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;
import com.flossom.common.core.domain.entity.SysTag;
import com.flossom.common.core.domain.entity.WxScriptTemplate;
import com.flossom.common.core.utils.StringUtils;
import com.flossom.common.core.utils.poi.ExcelUtil;
@ -122,4 +121,13 @@ public class WxScriptTemplateController extends BaseController
// tags.removeIf(d -> d.getId().intValue() == id || ArrayUtils.contains(StringUtils.split(d.getAncestors(), ","), id + ""));
// return success(tags);
// }
/**
*
*/
@GetMapping("/scriptTree")
public AjaxResult scriptTree(WxScriptTemplate wxScriptTemplate) {
return success(wxScriptTemplateService.scriptTree(wxScriptTemplate));
}
}

@ -5,6 +5,7 @@ import javax.servlet.http.HttpServletResponse;
import com.flossom.common.core.domain.R;
import com.flossom.common.core.domain.entity.WxUserMember;
import com.flossom.common.core.domain.entity.WxUserScriptLog;
import com.flossom.common.core.domain.req.AllSendScriptOperateReq;
import com.flossom.common.core.domain.req.WxUserMemberVm;
import com.flossom.common.core.domain.req.WxUserScriptReq;
import com.flossom.common.core.exception.ServiceException;
@ -177,7 +178,10 @@ public class WxUserScriptLogController extends BaseController {
* @return
*/
@PostMapping("/allSendScript")
public R allSendScript(@RequestBody @Validated WxUserScriptReq wxUserScriptReq, WxUserMemberVm wxUserMemberVm) {
public R allSendScript(@RequestBody @Validated AllSendScriptOperateReq allSendScriptOperateReq) {
WxUserScriptReq wxUserScriptReq = allSendScriptOperateReq.getWxUserScriptReq();
WxUserMemberVm wxUserMemberVm = allSendScriptOperateReq.getWxUserMemberVm();
if (wxUserScriptReq.getIsCustom() == 0) {
// 模板话术
if (wxUserScriptReq.getScriptTemplateId() == null || wxUserScriptReq.getScriptTemplateId() == 0) {

@ -3,6 +3,7 @@ package com.flossom.system.service;
import java.util.List;
import com.flossom.common.core.domain.entity.WxScriptTemplate;
import com.flossom.common.core.domain.vo.TreeSelect;
/**
* Service
@ -67,4 +68,6 @@ public interface IWxScriptTemplateService
* @return
*/
public boolean hasChildByScriptId(Long id);
public List<TreeSelect> scriptTree(WxScriptTemplate wxScriptTemplate);
}

@ -1,5 +1,7 @@
package com.flossom.system.service.impl;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors;
@ -7,10 +9,12 @@ import java.util.stream.Collectors;
import com.flossom.common.core.domain.entity.SysTag;
import com.flossom.common.core.domain.entity.WxScriptTag;
import com.flossom.common.core.domain.entity.WxScriptTemplate;
import com.flossom.common.core.domain.vo.TreeSelect;
import com.flossom.common.core.mapper.SysTagMapper;
import com.flossom.common.core.mapper.WxScriptTagMapper;
import com.flossom.common.core.mapper.WxScriptTemplateMapper;
import com.flossom.common.core.utils.DateUtils;
import com.flossom.common.core.utils.SpringUtils;
import com.flossom.common.core.utils.StringUtils;
import com.flossom.common.security.utils.SecurityUtils;
import org.apache.commons.compress.utils.Lists;
@ -26,14 +30,14 @@ import org.springframework.util.CollectionUtils;
* @date 2023-12-18
*/
@Service
public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
{
public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService {
@Autowired
private WxScriptTemplateMapper wxScriptTemplateMapper;
@Autowired
private WxScriptTagMapper wxScriptTagMapper;
@Autowired
private SysTagMapper sysTagMapper;
/**
*
*
@ -41,8 +45,7 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
* @return
*/
@Override
public WxScriptTemplate selectWxScriptTemplateById(Long id)
{
public WxScriptTemplate selectWxScriptTemplateById(Long id) {
return wxScriptTemplateMapper.selectWxScriptTemplateById(id);
}
@ -53,8 +56,7 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
* @return
*/
@Override
public List<WxScriptTemplate> selectWxScriptTemplateList(WxScriptTemplate wxScriptTemplate)
{
public List<WxScriptTemplate> selectWxScriptTemplateList(WxScriptTemplate wxScriptTemplate) {
return wxScriptTemplateMapper.selectWxScriptTemplateList(wxScriptTemplate);
}
@ -65,15 +67,14 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
* @return
*/
@Override
public int insertWxScriptTemplate(WxScriptTemplate wxScriptTemplate)
{
public int insertWxScriptTemplate(WxScriptTemplate wxScriptTemplate) {
wxScriptTemplate.setCreateTime(DateUtils.getNowDate());
wxScriptTemplate.setCreateBy(SecurityUtils.getLoginUser().getUsername());
List<SysTag> sysTags = Lists.newArrayList();
// 处理标签在字段的展示
List<Long> tagIds = wxScriptTemplate.getTagIdArray();
if(!CollectionUtils.isEmpty(tagIds)) {
for (long tagId:tagIds) {
if (!CollectionUtils.isEmpty(tagIds)) {
for (long tagId : tagIds) {
SysTag sysTag = sysTagMapper.selectDeptById(tagId);
if (Objects.nonNull(sysTag)) {
sysTags.add(sysTag);
@ -90,7 +91,7 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
int i = wxScriptTemplateMapper.insertWxScriptTemplate(wxScriptTemplate);
for(SysTag tag : sysTags) {
for (SysTag tag : sysTags) {
// 增加关联关系
WxScriptTag scriptTag = new WxScriptTag();
scriptTag.setScriptId(wxScriptTemplate.getId());
@ -110,8 +111,7 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
* @return
*/
@Override
public int updateWxScriptTemplate(WxScriptTemplate wxScriptTemplate)
{
public int updateWxScriptTemplate(WxScriptTemplate wxScriptTemplate) {
wxScriptTemplate.setUpdateTime(DateUtils.getNowDate());
wxScriptTemplate.setUpdateBy(SecurityUtils.getLoginUser().getUsername());
wxScriptTemplate.setTagIds("");
@ -119,8 +119,8 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
List<SysTag> sysTags = Lists.newArrayList();
// 处理标签在字段的展示
List<Long> tagIds = wxScriptTemplate.getTagIdArray();
if(!CollectionUtils.isEmpty(tagIds)) {
for (long tagId:tagIds) {
if (!CollectionUtils.isEmpty(tagIds)) {
for (long tagId : tagIds) {
SysTag sysTag = sysTagMapper.selectDeptById(tagId);
if (Objects.nonNull(sysTag)) {
sysTags.add(sysTag);
@ -138,7 +138,7 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
// 先删除原本的关系
wxScriptTagMapper.deleteWxScriptByScriptId(wxScriptTemplate.getId());
for(SysTag tag : sysTags) {
for (SysTag tag : sysTags) {
// 增加关联关系
WxScriptTag scriptTag = new WxScriptTag();
scriptTag.setScriptId(wxScriptTemplate.getId());
@ -158,8 +158,7 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
* @return
*/
@Override
public int deleteWxScriptTemplateByIds(Long[] ids)
{
public int deleteWxScriptTemplateByIds(Long[] ids) {
return wxScriptTemplateMapper.deleteWxScriptTemplateByIds(ids);
}
@ -170,8 +169,7 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
* @return
*/
@Override
public int deleteWxScriptTemplateById(Long id)
{
public int deleteWxScriptTemplateById(Long id) {
// 先删除原本的关系
int i = wxScriptTagMapper.deleteWxScriptByScriptId(id);
return wxScriptTemplateMapper.deleteWxScriptTemplateById(id);
@ -182,4 +180,68 @@ public class WxScriptTemplateServiceImpl implements IWxScriptTemplateService
int result = wxScriptTemplateMapper.hasChildByScriptId(id);
return result > 0;
}
@Override
public List<TreeSelect> scriptTree(WxScriptTemplate wxScriptTemplate) {
List<WxScriptTemplate> wxScriptTemplateList = this.selectWxScriptTemplateList(wxScriptTemplate);
return buildTree(wxScriptTemplateList);
}
public List<TreeSelect> buildTree(List<WxScriptTemplate> wxScriptTemplateList) {
List<WxScriptTemplate> deptTrees = buildDeptTree(wxScriptTemplateList);
return deptTrees.stream().map(TreeSelect::new).collect(Collectors.toList());
}
public List<WxScriptTemplate> buildDeptTree(List<WxScriptTemplate> wxScriptTemplateList) {
List<WxScriptTemplate> returnList = new ArrayList<>();
List<Long> tempList = wxScriptTemplateList.stream().map(WxScriptTemplate::getId).collect(Collectors.toList());
for (WxScriptTemplate wxScriptTemplate : wxScriptTemplateList) {
// 如果是顶级节点, 遍历该父节点的所有子节点
if (!tempList.contains(wxScriptTemplate.getParentId())) {
recursionFn(wxScriptTemplateList, wxScriptTemplate);
returnList.add(wxScriptTemplate);
}
}
if (returnList.isEmpty()) {
returnList = wxScriptTemplateList;
}
return returnList;
}
/**
*
*/
private void recursionFn(List<WxScriptTemplate> list, WxScriptTemplate t) {
// 得到子节点列表
List<WxScriptTemplate> childList = getChildList(list, t);
t.setScriptTemplateChildren(childList);
for (WxScriptTemplate tChild : childList) {
if (hasChild(list, tChild)) {
recursionFn(list, tChild);
}
}
}
/**
*
*/
private List<WxScriptTemplate> getChildList(List<WxScriptTemplate> list, WxScriptTemplate t) {
List<WxScriptTemplate> tlist = new ArrayList<>();
Iterator<WxScriptTemplate> it = list.iterator();
while (it.hasNext()) {
WxScriptTemplate n = (WxScriptTemplate) it.next();
if (StringUtils.isNotNull(n.getParentId()) && n.getParentId().longValue() == t.getId().longValue()) {
tlist.add(n);
}
}
return tlist;
}
/**
*
*/
private boolean hasChild(List<WxScriptTemplate> list, WxScriptTemplate t) {
return getChildList(list, t).size() > 0 ? true : false;
}
}

@ -111,6 +111,9 @@ public class WxUserScriptLogServiceImpl implements IWxUserScriptLogService {
for (Long wxUserId : userIdList) {
WxUserScriptLog wxUserScriptLog = new WxUserScriptLog();
BeanUtils.copyProperties(wxUserScriptReq, wxUserScriptLog);
if (wxUserScriptReq.getTagIds() != null && wxUserScriptReq.getTagIds().size() > 0) {
wxUserScriptLog.setTagIds(wxUserScriptReq.getTagIds().stream().collect(Collectors.joining(",")));
}
wxUserScriptLog.setWxUserId(wxUserId);
wxUserScriptLog.setCreateBy(SecurityUtils.getUsername());
wxUserScriptLog.setCreateTime(DateUtils.getNowDate());
@ -131,9 +134,8 @@ public class WxUserScriptLogServiceImpl implements IWxUserScriptLogService {
}
if (wxUserScriptReq.getIsCustom() == 1) {
// 自定义话术
if (StringUtils.isNotBlank(wxUserScriptReq.getTagIds())) {
List<String> list = Arrays.asList(wxUserScriptReq.getTagIds().split(","));
List<Integer> tagList = list.stream().map(Integer::parseInt).collect(Collectors.toList());
if (wxUserScriptReq.getTagIds() != null && wxUserScriptReq.getTagIds().size() > 0) {
List<Integer> tagList = wxUserScriptReq.getTagIds().stream().map(Integer::parseInt).collect(Collectors.toList());
List<Integer> collect = userIdList.stream().map(Long::intValue).collect(Collectors.toList());
wxUserMemberService.batchAddMiniProgramTag(tagList, collect);
}

@ -179,11 +179,14 @@ export function batchSendScript(data) {
}
// 全量发送话术
export function allSendScript(data) {
export function allSendScript(data, user) {
return request({
url: '/system/userScriptLog/allSendScript',
method: 'post',
data: data
data: {
wxUserScriptReq: data,
wxUserMemberVm: user
},
})
}
@ -205,5 +208,11 @@ export function allAddRemark(content, user) {
})
}
export function scriptTreeSelect(query) {
return request({
url: '/system/scriptTemplate/scriptTree',
method: 'get',
params: query
})
}

@ -442,7 +442,7 @@
<el-row>
<el-col :span="24">
<el-form-item label="类型" prop="isCustom">
<el-select v-model="scriptForm.isCustom">
<el-select v-model="scriptForm.isCustom" @change="clearScript">
<el-option label="话术模板发送" :value="0" :key="0"></el-option>
<el-option label="自定义发送" :value="1" :key="1"></el-option>
</el-select>
@ -451,12 +451,14 @@
</el-row>
<!-- 话术模板发送 -->
<el-row v-if="scriptForm.isCustom == 0">
<el-col :span="24">
<el-form-item label="话术二级标题选择" prop="scriptTemplateId">
<el-input v-model="scriptForm.scriptTemplateId" placeholder="请输入话术标题"/>
<el-col :span="40">
<el-form-item label="话术二级标题选择" prop="scriptTemplateId" label-width="90px">
<treeselect v-model="scriptForm.scriptTemplateId" :options="scriptOptions" :show-count="true"
@select="selectTree"
placeholder="请选择话术" :disable-branch-nodes="true"/>
</el-form-item>
</el-col>
<el-col :span="24">
<el-col :span="40">
<el-form-item label="话术通知内容" prop="scriptContent">
<el-input v-model="scriptForm.scriptContent"/>
</el-form-item>
@ -476,7 +478,7 @@
</el-col>
<el-col :span="24">
<el-form-item label="小程序标签" prop="tagIdArray" label-width="90px">
<treeselect v-model="form.tagIdArray" :options="chatTagOptions" :multiple="true" :show-count="true"
<treeselect v-model="tagIdArray" :options="chatTagOptions" :multiple="true" :show-count="true"
placeholder="请选择小程序标签" :disable-branch-nodes="true"/>
</el-form-item>
</el-col>
@ -530,7 +532,7 @@
</el-row>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button type="primary" @click="submitBatchOperate"> </el-button>
<el-button @click="cancelscriptDialog"> </el-button>
</div>
</el-dialog>
@ -560,6 +562,7 @@ import {
batchAddRemark,
allAddRemark,
getMiniProgramTagsTree,
scriptTreeSelect,
} from "@/api/system/member";
import Treeselect from "@riophae/vue-treeselect";
import {tagTreeSelect} from "@/api/system/wechatTab";
@ -613,6 +616,7 @@ export default {
//
batchMiniProgramVisible: false,
chatTagOptions: [],
scriptOptions: [],
tagIdArray: [],
//
batchIntegralVisible: false,
@ -630,6 +634,7 @@ export default {
//
batchRemarkVisible: null,
scriptForm: {
userIdList: null,
isCustom: null,
scriptTemplateId: null,
scriptName: null,
@ -643,8 +648,8 @@ export default {
redirectUrl: null,
videoNo: null,
feedId: null,
tagNames: null,
tagIds: null,
tagNames: [],
tagIds: [],
//
scriptContent: null,
},
@ -705,6 +710,7 @@ export default {
this.getProvinceList();
//
this.getDeptTree();
this.getScriptTree();
},
methods: {
/** 查询用户列表 */
@ -789,7 +795,24 @@ export default {
}
},
cancelscriptDialog(isclose) {
this.scriptForm = null;
this.scriptForm.isCustom = null,
this.scriptForm.scriptName = null;
this.scriptForm.titile = null;
this.scriptForm.content = null;
this.scriptForm.tagType = null;
this.scriptForm.type = null;
this.scriptForm.link = null;
this.scriptForm.linkParams = null;
this.scriptForm.redirectAppid = null;
this.scriptForm.redirectUrl = null;
this.scriptForm.videoNo = null;
this.scriptForm.feedId = null;
this.scriptForm.tagNames = null;
this.scriptForm.tagIds = null;
this.scriptForm.scriptContent = null;
this.tagIdArray = [];
this.scriptForm.scriptTemplateId = null;
this.scriptForm.scriptContent = null;
if (isclose) {
this.batchScriptVisible = false;
}
@ -800,6 +823,40 @@ export default {
this.chatTagOptions = response.data;
});
},
/** 查询话术下拉树结构 */
getScriptTree() {
scriptTreeSelect().then(response => {
this.scriptOptions = response.data;
});
},
clearScript() {
//
if (this.scriptForm.isCustom == 0) {
this.scriptForm.scriptName = null;
this.scriptForm.titile = null;
this.scriptForm.content = null;
this.scriptForm.tagType = null;
this.scriptForm.type = null;
this.scriptForm.link = null;
this.scriptForm.linkParams = null;
this.scriptForm.redirectAppid = null;
this.scriptForm.redirectUrl = null;
this.scriptForm.videoNo = null;
this.scriptForm.feedId = null;
this.scriptForm.tagNames = null;
this.scriptForm.tagIds = null;
this.scriptForm.scriptContent = null;
this.tagIdArray = [];
}
//
if (this.scriptForm.isCustom == 1) {
this.scriptForm.scriptTemplateId = null;
this.scriptForm.scriptContent = null;
}
},
selectTree(raw, instanceId) {
this.scriptForm.scriptContent = raw.content;
},
//
reset() {
this.form = {
@ -1068,14 +1125,19 @@ export default {
/* 批量操作:发送话术 */
if (this.batchOperateValue == 7) {
alert("批量发送话术");
alert(this.scriptForm.isCustom);
alert(this.ids);
this.scriptForm.userIdList = this.ids;
this.scriptForm.tagIds = this.tagIdArray;
batchSendScript(this.scriptForm).then(Response => {
this.$modal.msgSuccess("批量发送话术成功");
this.cancelscriptDialog(true);
})
}
if (this.batchOperateValue == 8) {
alert("全量发送话术");
alert(this.scriptForm.isCustom);
alert(this.queryParams.nickname);
this.scriptForm.tagIds = this.tagIdArray;
allSendScript(this.scriptForm, this.queryParams).then(Response => {
this.$modal.msgSuccess("全量发送话术成功");
this.cancelscriptDialog(true);
})
}
//

Loading…
Cancel
Save