创建推送信息功能

This commit is contained in:
coderxqt 2026-04-29 19:24:16 +08:00
parent b71f02d9d3
commit 7096d597fd
5 changed files with 816 additions and 128 deletions

View File

@ -42,3 +42,29 @@ export function delBatchSendTaskInfo(id) {
method: 'delete' method: 'delete'
}) })
} }
// 获取总结标签数据
export function getPhysicalExaminationLabel() {
return request({
url: '/system/batchSendTaskInfo/getPhysicalExaminationLabel',
method: 'get',
})
}
// 查询不分页数据
export function AllBatchSendTaskInfo(query) {
return request({
url: '/system/batchSendTaskInfo/batchSendTaskList',
method: 'get',
params: query
})
}
// 生成推送任务
export function generatePushTask(data) {
return request({
url: '/system/batchSendTaskInfo/batchSend',
method: 'post',
data: data
})
}

View File

@ -0,0 +1,301 @@
<template>
<div class="app-container">
<el-card>
<h2 style="margin-bottom: 20px">创建推送任务</h2>
<el-form :model="form" ref="form" label-width="120px" :rules="rules">
<el-form-item label="任务名称" prop="manageRouteName">
<el-input
v-model="form.manageRouteName"
placeholder="请输入任务名称"
style="width: 200px"
/>
</el-form-item>
<el-form-item label="指定时间" prop="nodePlanTime">
<el-date-picker
v-model="form.nodePlanTime"
type="datetime"
value-format="yyyy-MM-dd HH:mm:ss"
placeholder="请选择指定时间"
:picker-options="pickerOptions"
style="width: 200px"
/>
</el-form-item>
<el-form-item label="任务节点类型" prop="batchTaskSource">
<el-radio-group v-model="form.batchTaskSource">
<el-radio label="telephone">电话外呼</el-radio>
<el-radio label="message">短信推送</el-radio>
</el-radio-group>
</el-form-item>
<!-- 电话外呼部分 -->
<template v-if="form.batchTaskSource === 'telephone'">
<el-form-item label="话术模板" prop="phoneTemplate">
<scripts
@on-template="handlePhoneTemplateSelect"
:templateId="form.phoneTemplateId"
:node="form.phoneDialMethod"
:templateName="form.phoneTemplate"
></scripts>
</el-form-item>
<el-form-item label="话术简介" prop="phoneDesc">
<el-input
v-model="form.phoneNodeContent"
type="textarea"
placeholder="话术简介"
autosize
disabled
/>
</el-form-item>
<!-- <el-form-item label="话术变量" prop="phoneVars">
<el-input
v-model="form.phoneVars"
type="textarea"
placeholder="请输入话术变量(如有多个请用逗号分隔)"
/>
</el-form-item> -->
<el-form-item label="重播次数" prop="phoneRedialTimes">
<el-select v-model="form.phoneRedialTimes" style="width: 200px">
<el-option
v-for="item in optionslisttime"
:key="item.dictValue"
:label="item.dictLabel"
:value="item.dictValue"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="时间间隔(分)" prop="phoneTimeInterval">
<el-input
v-model.number="form.phoneTimeInterval"
oninput="value=value.replace(/[^\d]/g,'')"
style="width: 200px"
/>
</el-form-item>
</template>
<!-- 短信推送部分 -->
<template v-if="form.batchTaskSource === 'message'">
<el-form-item label="短信模板" prop="smsTemplate">
<message
@on-template="handleSmsTemplateSelect"
:templateId="form.smsTemplateId"
:templateName="form.smsTemplate"
></message>
</el-form-item>
<el-form-item label="短信简介" prop="messageNodeContent">
<el-input
v-model="form.messageNodeContent"
type="textarea"
placeholder="短信简介"
autosize
disabled
/>
</el-form-item>
<el-form-item label="短信变量" v-if="smsVarsVisible">
<div
style="
display: flex;
gap: 12px;
align-items: center;
flex-wrap: wrap;
"
>
<div
v-for="key in smsVarKeys"
:key="key"
style="display: flex; align-items: center; gap: 8px"
>
<el-form-item :label="key">
<el-input
v-model="form.vars[key]"
:placeholder="'请输入' + key"
style="width: 200px"
/>
</el-form-item>
</div>
</div>
</el-form-item>
</template>
<el-form-item>
<el-button type="primary" @click="handleSubmit">保存</el-button>
</el-form-item>
</el-form>
</el-card>
</div>
</template>
<script>
import scripts from "../components/script.vue";
import message from "../components/message.vue";
import { getAgencytype } from "@/api/system/agency";
import {
AllBatchSendTaskInfo,
generatePushTask,
} from "@/api/system/batchSendTaskInfo";
export default {
name: "CreatePushTask",
components: { scripts, message },
data() {
return {
rules: {
manageRouteName: [
{ required: true, message: "任务名称不能为空", trigger: "blur" },
],
nodePlanTime: [
{ required: true, message: "指定时间不能为空", trigger: "change" },
],
batchTaskSource: [
{
required: true,
message: "任务节点类型不能为空",
trigger: "change",
},
],
},
pickerOptions: {
disabledDate(time) {
return time.getTime() < Date.now() - 8.64e7;
},
},
optionslisttime: [],
smsVarsVisible: false,
smsVarKeys: [],
form: {
manageRouteName: "",
nodePlanTime: "",
batchTaskSource: "",
phoneDialMethod: "AI",
phoneTemplateId: "",
phoneTemplate: "",
phoneNodeContent: "",
scriptInfoId: "",
robotPublishId: "",
phoneTemplateName: "",
phoneDesc: "",
phoneVars: "",
phoneRedialTimes: "",
phoneTimeInterval: "",
smsTemplateId: "",
smsTemplate: "",
messageTemplateId: "",
messageTemplateCode: "",
messageTemplateName: "",
messageNodeContent: "",
physicalExaminationLabel: "",
vars: {},
list: [],
},
};
},
created() {
this.infolistMESSAGE();
this.form.physicalExaminationLabel =
this.$route.query.physicalExaminationLabel || "";
AllBatchSendTaskInfo(this.$route.query).then((res) => {
this.form.list = res || [];
});
},
mounted() {},
methods: {
infolistMESSAGE() {
const dictType = "redial_times";
getAgencytype(dictType).then((res) => {
this.optionslisttime = res.data || [];
});
},
handlePhoneTemplateSelect(item) {
this.form.phoneTemplateId = item.phoneTemplateId || "";
this.form.phoneTemplate = item.templateName || "";
this.form.phoneNodeContent = item.templateContent || "";
this.form.robotPublishId = item.robotPublishId || "";
this.form.phoneTemplateName = item.templateName || "";
this.form.scriptInfoId = item.scriptInfoId || "";
},
handleSmsTemplateSelect(item) {
this.form.smsTemplateId = item.templateId || "";
this.form.smsTemplate = item.templateName || "";
this.form.messageTemplateId = item.templateId || "";
this.form.messageTemplateCode = item.messageTemplateCode || "";
this.form.messageTemplateName = item.templateName || "";
this.form.messageNodeContent = item.templateContent || "";
const variablesStr = item.variables;
if (variablesStr && String(variablesStr).trim() !== "") {
const keys = String(variablesStr)
.split("|")
.map((s) => s.trim())
.filter(Boolean);
this.smsVarsVisible = keys.length > 0;
this.smsVarKeys = keys;
const keySet = new Set(keys);
// month|day
keys.forEach((key) => {
if (this.form.vars[key] === undefined)
this.$set(this.form.vars, key, "");
});
// 沿
Object.keys(this.form.vars).forEach((existingKey) => {
if (!keySet.has(existingKey))
this.$delete(this.form.vars, existingKey);
});
} else {
this.smsVarsVisible = false;
this.smsVarKeys = [];
Object.keys(this.form.vars).forEach((existingKey) => {
this.$delete(this.form.vars, existingKey);
});
}
},
handleSubmit() {
this.$refs.form.validate((valid) => {
if (valid) {
if (
this.form.batchTaskSource == "message" &&
!this.form.messageTemplateName
) {
this.$message.error("请选择短信模板");
return;
}
if (
this.form.batchTaskSource == "telephone" &&
!this.form.phoneTemplateName
) {
this.$message.error("请选择话术模板");
return;
}
const loading = this.$loading({
lock: true,
text: "加载中",
spinner: "el-icon-loading",
background: "rgba(0, 0, 0, 0.7)",
});
generatePushTask(this.form).then((res) => {
loading.close();
if (res.code == 200) {
this.$message.success(res.msg);
}
});
}
});
},
},
};
</script>
<style scoped>
.app-container {
padding: 24px;
}
::v-deep .el-form-item__label {
font-size: 16px !important;
}
.el-textarea {
font-size: 16px;
}
</style>

View File

@ -84,12 +84,19 @@
/> />
</el-form-item> </el-form-item>
<el-form-item label="总结标签" prop="physicalExaminationLabel"> <el-form-item label="总结标签" prop="physicalExaminationLabel">
<el-input <el-select
v-model="queryParams.physicalExaminationLabel" v-model="queryParams.physicalExaminationLabel"
placeholder="请输入总结标签" placeholder="请选择总结标签"
clearable clearable
@keyup.enter.native="handleQuery" >
/> <el-option
v-for="item in ExaminationLabelList"
:key="item"
:label="item"
:value="item"
>
</el-option>
</el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button <el-button
@ -171,6 +178,16 @@
<el-button @click="uploadCancel"> </el-button> <el-button @click="uploadCancel"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
<el-col :span="1.5">
<el-button
type="warning"
plain
icon="el-icon-edit-outline"
size="mini"
@click="handleCreatePushTask"
>创建推送任务</el-button
>
</el-col>
<el-col :span="1.5"> <el-col :span="1.5">
<el-button <el-button
type="danger" type="danger"
@ -196,7 +213,12 @@
@selection-change="handleSelectionChange" @selection-change="handleSelectionChange"
> >
<el-table-column type="selection" width="55" align="center" /> <el-table-column type="selection" width="55" align="center" />
<el-table-column label="流水号" align="center" prop="sn" /> <el-table-column
label="流水号"
align="center"
prop="sn"
show-overflow-tooltip
/>
<el-table-column label="导入批次" align="center" prop="importName" /> <el-table-column label="导入批次" align="center" prop="importName" />
<el-table-column label="团体" align="center" prop="teamName" /> <el-table-column label="团体" align="center" prop="teamName" />
<el-table-column label="科室名称" align="center" prop="departmentName" /> <el-table-column label="科室名称" align="center" prop="departmentName" />
@ -217,14 +239,25 @@
width="130" width="130"
/> />
<el-table-column label="姓名" align="center" prop="patientName" /> <el-table-column label="姓名" align="center" prop="patientName" />
<el-table-column label="电话" align="center" prop="patientPhone" /> <el-table-column
label="电话"
align="center"
prop="patientPhone"
width="110"
/>
<el-table-column label="年龄" align="center" prop="age" /> <el-table-column label="年龄" align="center" prop="age" />
<el-table-column label="身份证号" align="center" prop="cardNo" /> <el-table-column
label="身份证号"
align="center"
prop="cardNo"
show-overflow-tooltip
/>
<el-table-column label="人群" align="center" prop="crowdName" /> <el-table-column label="人群" align="center" prop="crowdName" />
<el-table-column <el-table-column
label="总结标签" label="总结标签"
align="center" align="center"
prop="physicalExaminationLabel" prop="physicalExaminationLabel"
show-overflow-tooltip
/> />
<el-table-column <el-table-column
label="操作" label="操作"
@ -235,10 +268,10 @@
<el-button <el-button
size="mini" size="mini"
type="text" type="text"
icon="el-icon-edit" icon="el-icon-view"
@click="handleUpdate(scope.row)" @click="handleUpdate(scope.row)"
v-hasPermi="['system:batchSendTaskInfo:edit']" v-hasPermi="['system:batchSendTaskInfo:edit']"
>修改</el-button >查看</el-button
> >
<el-button <el-button
size="mini" size="mini"
@ -260,20 +293,78 @@
@pagination="getList" @pagination="getList"
/> />
<!-- 创建推送任务弹窗 -->
<el-dialog
title="请确认创建推送任务的名单"
:visible.sync="createPushTaskOpen"
width="90%"
append-to-body
>
<el-table
v-loading="createPushTaskLoading"
:data="createPushTaskList"
border
style="width: 100%"
>
<el-table-column label="流水号" align="center" prop="sn" width="120" />
<el-table-column label="导入批次" align="center" prop="importName" />
<el-table-column label="团体" align="center" prop="teamName" />
<el-table-column
label="就诊/体检时间"
align="center"
prop="visitDate"
width="180"
>
<template slot-scope="scope">
<span>{{ parseTime(scope.row.visitDate, "{y}-{m}-{d}") }}</span>
</template>
</el-table-column>
<el-table-column label="姓名" align="center" prop="patientName" />
<el-table-column
label="电话"
align="center"
prop="patientPhone"
width="120"
/>
<el-table-column label="年龄" align="center" prop="age" />
<el-table-column
label="身份证号"
align="center"
prop="cardNo"
width="190"
/>
</el-table>
<pagination
v-show="createPushTaskTotal > 0"
:total="createPushTaskTotal"
:page.sync="createPushTaskQueryParams.pageNum"
:limit.sync="createPushTaskQueryParams.pageSize"
@pagination="getCreatePushTaskList"
/>
<div slot="footer" class="dialog-footer" style="text-align: center">
<el-button @click="createPushTaskOpen = false">关闭</el-button>
<el-button
type="primary"
v-show="createPushTaskList.length > 0"
@click="toNewPage"
>确认并创建推送任务</el-button
>
</div>
</el-dialog>
<!-- 添加或修改批量推送任务信息对话框 --> <!-- 添加或修改批量推送任务信息对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body> <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="80px"> <el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="序号" prop="orderNum"> <el-form-item label="序号" prop="orderNum">
<el-input v-model="form.orderNum" placeholder="请输入序号" /> <el-input v-model="form.orderNum" placeholder="请输入序号" />
</el-form-item> </el-form-item>
<el-form-item label="流水号/导入编号" prop="sn"> <el-form-item label="流水号" prop="sn">
<el-input v-model="form.sn" placeholder="请输入流水号/导入编号" /> <el-input v-model="form.sn" placeholder="请输入流水号" />
</el-form-item> </el-form-item>
<el-form-item label="导入批次名称" prop="importName"> <el-form-item label="导入批次" prop="importName">
<el-input <el-input v-model="form.importName" placeholder="请输入导入批次" />
v-model="form.importName"
placeholder="请输入导入批次名称"
/>
</el-form-item> </el-form-item>
<el-form-item label="团体名称" prop="teamName"> <el-form-item label="团体名称" prop="teamName">
<el-input v-model="form.teamName" placeholder="请输入团体名称" /> <el-input v-model="form.teamName" placeholder="请输入团体名称" />
@ -290,28 +381,22 @@
placeholder="请输入所属医院名称" placeholder="请输入所属医院名称"
/> />
</el-form-item> </el-form-item>
<el-form-item label="匹配的科室ID" prop="departmentId"> <el-form-item label="科室ID" prop="departmentId">
<el-input <el-input v-model="form.departmentId" placeholder="请输入科室ID" />
v-model="form.departmentId"
placeholder="请输入匹配的科室ID"
/>
</el-form-item> </el-form-item>
<el-form-item label="匹配的科室名称" prop="departmentName"> <el-form-item label="科室名称" prop="departmentName">
<el-input <el-input
v-model="form.departmentName" v-model="form.departmentName"
placeholder="请输入匹配的科室名称" placeholder="请输入科室名称"
/> />
</el-form-item> </el-form-item>
<el-form-item <el-form-item label="就诊/体检时间" prop="visitDate">
label="就诊/体检时间时间格式yyyy-MM-dd"
prop="visitDate"
>
<el-date-picker <el-date-picker
clearable clearable
v-model="form.visitDate" v-model="form.visitDate"
type="date" type="date"
value-format="yyyy-MM-dd" value-format="yyyy-MM-dd"
placeholder="请选择就诊/体检时间时间格式yyyy-MM-dd" placeholder="请选择就诊/体检时间"
> >
</el-date-picker> </el-date-picker>
</el-form-item> </el-form-item>
@ -348,18 +433,15 @@
placeholder="请输入体检总结/主要诊断" placeholder="请输入体检总结/主要诊断"
/> />
</el-form-item> </el-form-item>
<el-form-item <el-form-item label="总结标签" prop="physicalExaminationLabel">
label="总结标签,逗号隔断"
prop="physicalExaminationLabel"
>
<el-input <el-input
v-model="form.physicalExaminationLabel" v-model="form.physicalExaminationLabel"
placeholder="请输入总结标签,逗号隔断" placeholder="请输入总结标签"
/> />
</el-form-item> </el-form-item>
</el-form> </el-form>
<div slot="footer" class="dialog-footer"> <div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button> <!-- <el-button type="primary" @click="submitForm"> </el-button> -->
<el-button @click="cancel"> </el-button> <el-button @click="cancel"> </el-button>
</div> </div>
</el-dialog> </el-dialog>
@ -373,6 +455,7 @@ import {
delBatchSendTaskInfo, delBatchSendTaskInfo,
addBatchSendTaskInfo, addBatchSendTaskInfo,
updateBatchSendTaskInfo, updateBatchSendTaskInfo,
getPhysicalExaminationLabel,
} from "@/api/system/batchSendTaskInfo"; } from "@/api/system/batchSendTaskInfo";
import { getToken } from "@/utils/auth"; import { getToken } from "@/utils/auth";
@ -380,6 +463,7 @@ export default {
name: "BatchSendTaskInfo", name: "BatchSendTaskInfo",
data() { data() {
return { return {
ExaminationLabelList: [],
// //
loading: true, loading: true,
// //
@ -392,6 +476,15 @@ export default {
showSearch: true, showSearch: true,
// //
total: 0, total: 0,
//
createPushTaskOpen: false,
createPushTaskLoading: false,
createPushTaskList: [],
createPushTaskTotal: 0,
createPushTaskQueryParams: {
pageNum: 1,
pageSize: 10,
},
// //
batchSendTaskInfoList: [], batchSendTaskInfoList: [],
// //
@ -414,8 +507,6 @@ export default {
}, },
// //
queryParams: { queryParams: {
pageNum: 1,
pageSize: 10,
orderNum: null, orderNum: null,
sn: null, sn: null,
importName: null, importName: null,
@ -464,6 +555,9 @@ export default {
}, },
created() { created() {
this.getList(); this.getList();
getPhysicalExaminationLabel().then((res) => {
this.ExaminationLabelList = res;
});
}, },
methods: { methods: {
/** 查询批量推送任务信息列表 */ /** 查询批量推送任务信息列表 */
@ -616,6 +710,59 @@ export default {
`batchSendTaskInfo_${new Date().getTime()}.xlsx` `batchSendTaskInfo_${new Date().getTime()}.xlsx`
); );
}, },
/** 创建推送任务按钮操作 */
handleCreatePushTask() {
//
const params = this.queryParams;
const hasQuery = Object.keys(params).some(
(key) =>
params[key] !== null &&
params[key] !== "" &&
key !== "pageNum" &&
key !== "pageSize"
);
if (!hasQuery) {
this.$modal.msgError("请选择查询条件");
return;
}
this.createPushTaskOpen = true;
this.createPushTaskQueryParams.pageNum = 1;
this.getCreatePushTaskList();
},
/** 创建推送任务弹窗列表(调用 listBatchSendTaskInfo */
getCreatePushTaskList() {
this.createPushTaskLoading = true;
const params = {
...this.queryParams,
pageNum: this.createPushTaskQueryParams.pageNum,
pageSize: this.createPushTaskQueryParams.pageSize,
};
listBatchSendTaskInfo(params)
.then((response) => {
this.createPushTaskList = response.rows || [];
this.createPushTaskTotal = response.total || 0;
this.createPushTaskLoading = false;
})
.catch(() => {
this.createPushTaskLoading = false;
});
},
toNewPage() {
this.createPushTaskOpen = false;
//
const query = {};
Object.keys(this.queryParams).forEach((key) => {
if (key !== "pageNum" && key !== "pageSize") {
query[key] = this.queryParams[key];
}
});
this.$router.push({
path: "/batchsendtask/CreatePushTask",
query,
});
},
}, },
}; };
</script> </script>

View File

@ -1,68 +1,171 @@
<template> <template>
<div class="app-container"> <div class="app-container">
<el-button size="small" @click="classificationOpen = true" style=" <el-button
size="small"
@click="classificationOpen = true"
style="
width: 200px; width: 200px;
font-size: 14px; font-size: 14px;
text-align: left; text-align: left;
white-space: nowrap; white-space: nowrap;
text-overflow: ellipsis; text-overflow: ellipsis;
overflow: hidden; overflow: hidden;
" :style="handleselectName ? 'color:black' : 'color:#C0C4CC'">{{ handleselectName ? handleselectName : "选择短信模板" "
}}</el-button> :style="handleselectName ? 'color:black' : 'color:#C0C4CC'"
<el-dialog title="短信库模板选择" :visible.sync="classificationOpen" width="70%" :before-close="classificationOpenfalse"> >{{ handleselectName ? handleselectName : "选择短信模板" }}</el-button
>
<el-dialog
title="短信库模板选择"
:visible.sync="classificationOpen"
width="70%"
:before-close="classificationOpenfalse"
>
<el-row :gutter="20"> <el-row :gutter="20">
<!--部门数据--> <!--部门数据-->
<el-col :span="6" :xs="24"> <el-col :span="6" :xs="24">
<DepartmentList ref="DepartmentList" :modal="false" @clickdepartment="clickdepartment" <DepartmentList
:methods="'listMessageNumtwo'"> ref="DepartmentList"
:modal="false"
@clickdepartment="clickdepartment"
:methods="'listMessageNumtwo'"
>
</DepartmentList> </DepartmentList>
</el-col> </el-col>
<!--用户数据--> <!--用户数据-->
<el-col :span="18" :xs="24"> <el-col :span="18" :xs="24">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" <el-form
label-width="68px"> :model="queryParams"
<el-form-item label="短信模板名称" prop="textMessageName" label-width="100px"> ref="queryForm"
<el-input v-model="queryParams.textMessageName" placeholder="请输入模版名称" clearable size="small"
@keyup.enter.native="handleQuery" /> :inline="true"
v-show="showSearch"
label-width="68px"
>
<el-form-item
label="短信模板名称"
prop="textMessageName"
label-width="100px"
>
<el-input
v-model="queryParams.textMessageName"
placeholder="请输入模版名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item label="模板ID" prop="textMessageId"> <el-form-item label="模板ID" prop="textMessageId">
<el-input v-model="queryParams.textMessageId" placeholder="请输入模板ID" clearable <el-input
@keyup.enter.native="handleQuery" /> v-model="queryParams.textMessageId"
placeholder="请输入模板ID"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> <el-button
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> type="primary"
icon="el-icon-search"
size="mini"
@click="handleQuery"
>搜索</el-button
>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
>重置</el-button
>
</el-form-item> </el-form-item>
</el-form> </el-form>
<el-table v-loading="loading" :data="templateList" @row-dblclick="handleselect"> <el-table
<el-table-column type="index" width="48" align="center" label="序号" /> v-loading="loading"
<el-table-column label="短信模板名称" align="center" prop="textMessageName" :show-overflow-tooltip="true" /> :data="templateList"
<el-table-column label="短信ID" align="center" prop="textMessageId" /> @row-dblclick="handleselect"
<el-table-column label="短信内容" align="center" prop="textMessageContent" :show-overflow-tooltip="true" /> >
<el-table-column :show-overflow-tooltip="true" label="适用任务类型" align="center" prop="suitTaskTypeName"> <el-table-column
type="index"
width="48"
align="center"
label="序号"
/>
<el-table-column
label="短信模板名称"
align="center"
prop="textMessageName"
:show-overflow-tooltip="true"
/>
<el-table-column
label="短信ID"
align="center"
prop="textMessageId"
/>
<el-table-column
label="短信内容"
align="center"
prop="textMessageContent"
:show-overflow-tooltip="true"
/>
<el-table-column
:show-overflow-tooltip="true"
label="适用任务类型"
align="center"
prop="suitTaskTypeName"
>
<template slot-scope="scope"> <template slot-scope="scope">
{{ scope.row.suitTaskTypeName != "null" ? scope.row.suitTaskTypeName : "" }} {{
scope.row.suitTaskTypeName != "null"
? scope.row.suitTaskTypeName
: ""
}}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="短信通道" align="center" prop="textMessageChannel"> <el-table-column
label="短信通道"
align="center"
prop="textMessageChannel"
>
<template slot-scope="scope"> <template slot-scope="scope">
{{ scope.row.textMessageChannel == "WATER_DROPLET_PLATFORM" ? "水滴平台" : "" }} {{
scope.row.textMessageChannel == "WATER_DROPLET_PLATFORM"
? "水滴平台"
: ""
}}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column label="病种名称" align="center" prop="diseaseTypeName" /> <el-table-column
<el-table-column label="操作" align="center" class-name="small-padding fixed-width"> label="病种名称"
align="center"
prop="diseaseTypeName"
/>
<el-table-column
label="操作"
align="center"
class-name="small-padding fixed-width"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button size="mini" type="text" @click="handleselect(scope.row)" <el-button
v-if="handleselectId != scope.row.id">选择</el-button> size="mini"
<el-button size="mini" type="text" @click="nohandleselect(scope.row)" type="text"
v-if="handleselectId == scope.row.id">取消选择</el-button> @click="handleselect(scope.row)"
v-if="handleselectId != scope.row.id"
>选择</el-button
>
<el-button
size="mini"
type="text"
@click="nohandleselect(scope.row)"
v-if="handleselectId == scope.row.id"
>取消选择</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
</el-col> </el-col>
</el-row> </el-row>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" <pagination
@pagination="getList" /> v-show="total > 0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
</el-dialog> </el-dialog>
</div> </div>
</template> </template>
@ -78,10 +181,10 @@ import {
} from "@/api/manage/message"; } from "@/api/manage/message";
import { typelist } from "@/api/manage/template"; import { typelist } from "@/api/manage/template";
import { department, listDisease } from "@/api/manage/script"; import { department, listDisease } from "@/api/manage/script";
import DepartmentList from '../../components/DepartmentList.vue' import DepartmentList from "../../components/DepartmentList.vue";
export default { export default {
components: { components: {
DepartmentList DepartmentList,
}, },
props: ["templateId", "templateName"], props: ["templateId", "templateName"],
name: "Template", name: "Template",
@ -140,14 +243,14 @@ export default {
methods: { methods: {
// //
clickdepartment(item) { clickdepartment(item) {
this.queryParams.hospitalAgencyId = item.hospitalAgencyId this.queryParams.hospitalAgencyId = item.hospitalAgencyId;
this.queryParams.hospitalAgencyName = item.hospitalAgencyName this.queryParams.hospitalAgencyName = item.hospitalAgencyName;
this.queryParams.departmentId = item.itemid this.queryParams.departmentId = item.itemid;
this.queryParams.departmentName = item.itemName this.queryParams.departmentName = item.itemName;
if (item.hospitalAgencyId) { if (item.hospitalAgencyId) {
this.handleQuery(); this.handleQuery();
} }
this.$forceUpdate() this.$forceUpdate();
}, },
nohandleselect() { nohandleselect() {
this.handleselectId = ""; this.handleselectId = "";
@ -156,7 +259,7 @@ export default {
templateId: "", templateId: "",
templateName: "", templateName: "",
templateContent: "", templateContent: "",
messageTemplateCode:"", messageTemplateCode: "",
}); });
}, },
handleselect(item) { handleselect(item) {
@ -165,8 +268,9 @@ export default {
this.$emit("on-template", { this.$emit("on-template", {
templateId: item.id, templateId: item.id,
templateName: item.textMessageName, templateName: item.textMessageName,
templateContent: item.templateContent, templateContent: item.textMessageContent,
messageTemplateCode:item.messageTemplateCode messageTemplateCode: item.messageTemplateCode,
variables: item.variables,
}); });
this.classificationOpen = false; this.classificationOpen = false;
}, },
@ -193,7 +297,7 @@ export default {
this.queryParams.departmentId = null; this.queryParams.departmentId = null;
this.itemname = null; this.itemname = null;
this.resetForm("queryForm"); this.resetForm("queryForm");
this.$refs.DepartmentList.resetQuery() this.$refs.DepartmentList.resetQuery();
// this.handleQuery(); // this.handleQuery();
}, },
}, },

View File

@ -1,72 +1,180 @@
<template> <template>
<div class="app-containers"> <div class="app-containers">
<el-button size="small" @click="classificationOpen = true" style=" <el-button
size="small"
@click="classificationOpen = true"
style="
width: 200px; width: 200px;
font-size: 14px; font-size: 14px;
text-align: left; text-align: left;
white-space: nowrap; white-space: nowrap;
text-overflow: ellipsis; text-overflow: ellipsis;
overflow: hidden; overflow: hidden;
" :style="handleselectName ? 'color:black' : 'color:#C0C4CC'">{{ handleselectName ? handleselectName : "请选择" "
}}</el-button> :style="handleselectName ? 'color:black' : 'color:#C0C4CC'"
<el-dialog title="话术库模板选择" :visible.sync="classificationOpen" width="70%" :before-close="classificationOpenfalse"> >{{ handleselectName ? handleselectName : "请选择" }}</el-button
>
<el-dialog
title="话术库模板选择"
:visible.sync="classificationOpen"
width="70%"
:before-close="classificationOpenfalse"
>
<el-row :gutter="20"> <el-row :gutter="20">
<!--部门数据--> <!--部门数据-->
<el-col :span="6" :xs="24"> <el-col :span="6" :xs="24">
<DepartmentList ref="DepartmentList" :modal="false" @clickdepartment="clickdepartment" <DepartmentList
:methods="'listScriptNumtwo'"> ref="DepartmentList"
:modal="false"
@clickdepartment="clickdepartment"
:methods="'listScriptNumtwo'"
>
</DepartmentList> </DepartmentList>
</el-col> </el-col>
<!--用户数据--> <!--用户数据-->
<el-col :span="18" :xs="24"> <el-col :span="18" :xs="24">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" <el-form
label-width="100px"> :model="queryParams"
ref="queryForm"
size="small"
:inline="true"
v-show="showSearch"
label-width="100px"
>
<el-form-item label="通用话术名称" prop="commonScriptName"> <el-form-item label="通用话术名称" prop="commonScriptName">
<el-input v-model="queryParams.commonScriptName" placeholder="请输入通用话术名称" clearable <el-input
@keyup.enter.native="handleQuery" /> v-model="queryParams.commonScriptName"
placeholder="请输入通用话术名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item label="话术名称" prop="scriptName"> <el-form-item label="话术名称" prop="scriptName">
<el-input v-model="queryParams.scriptName" placeholder="请输入话术名称" clearable <el-input
@keyup.enter.native="handleQuery" /> v-model="queryParams.scriptName"
placeholder="请输入话术名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item label="话术ID" prop="scriptId"> <el-form-item label="话术ID" prop="scriptId">
<el-input v-model="queryParams.scriptId" placeholder="请输入话术ID" clearable <el-input
@keyup.enter.native="handleQuery" /> v-model="queryParams.scriptId"
placeholder="请输入话术ID"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item label="平台ID" prop="platformId"> <el-form-item label="平台ID" prop="platformId">
<el-input v-model="queryParams.platformId" placeholder="请输入平台ID" clearable <el-input
@keyup.enter.native="handleQuery" /> v-model="queryParams.platformId"
placeholder="请输入平台ID"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> <el-button
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> type="primary"
icon="el-icon-search"
size="mini"
@click="handleQuery"
>搜索</el-button
>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
>重置</el-button
>
</el-form-item> </el-form-item>
</el-form> </el-form>
<el-table v-loading="loading" :data="scriptList" @row-dblclick="handleselect"> <el-table
<el-table-column label="序号" align="center" prop="sort" type="index" width="48" /> v-loading="loading"
<el-table-column label="通用话术名称" align="center" prop="commonScriptName" :show-overflow-tooltip="true" /> :data="scriptList"
<el-table-column label="话术名称" align="center" prop="scriptName" :show-overflow-tooltip="true" /> @row-dblclick="handleselect"
<el-table-column label="话术ID" align="center" prop="scriptId" :show-overflow-tooltip="true" /> >
<el-table-column label="平台ID" align="center" prop="platformId" :show-overflow-tooltip="true" /> <el-table-column
<el-table-column label="话术简介" align="center" prop="scriptIntroduction" :show-overflow-tooltip="true" /> label="序号"
<el-table-column label="病种名称" align="center" prop="diseaseTypeName" :show-overflow-tooltip="true" /> align="center"
<el-table-column label="操作" align="center" class-name="small-padding fixed-width"> prop="sort"
type="index"
width="48"
/>
<el-table-column
label="通用话术名称"
align="center"
prop="commonScriptName"
:show-overflow-tooltip="true"
/>
<el-table-column
label="话术名称"
align="center"
prop="scriptName"
:show-overflow-tooltip="true"
/>
<el-table-column
label="话术ID"
align="center"
prop="scriptId"
:show-overflow-tooltip="true"
/>
<el-table-column
label="平台ID"
align="center"
prop="platformId"
:show-overflow-tooltip="true"
/>
<el-table-column
label="话术简介"
align="center"
prop="scriptIntroduction"
:show-overflow-tooltip="true"
/>
<el-table-column
label="病种名称"
align="center"
prop="diseaseTypeName"
:show-overflow-tooltip="true"
/>
<el-table-column
label="操作"
align="center"
class-name="small-padding fixed-width"
>
<template slot-scope="scope"> <template slot-scope="scope">
<el-button size="mini" type="text" @click="handlesee(scope.row)">预览</el-button> <el-button size="mini" type="text" @click="handlesee(scope.row)"
<el-button size="mini" type="text" @click="handleselect(scope.row)" >预览</el-button
v-if="handleselectId != scope.row.id">选择</el-button> >
<el-button size="mini" type="text" @click="nohandleselect(scope.row)" <el-button
v-if="handleselectId == scope.row.id">取消选择</el-button> size="mini"
type="text"
@click="handleselect(scope.row)"
v-if="handleselectId != scope.row.id"
>选择</el-button
>
<el-button
size="mini"
type="text"
@click="nohandleselect(scope.row)"
v-if="handleselectId == scope.row.id"
>取消选择</el-button
>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
</el-col> </el-col>
</el-row> </el-row>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" <pagination
@pagination="getList" /> v-show="total > 0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
</el-dialog> </el-dialog>
<el-dialog title="话术预览" :visible.sync="lookshow" width="90%"> <el-dialog title="话术预览" :visible.sync="lookshow" width="90%">
<Scriptpreview :phoneNodeContent="phoneNodeContent" v-if="lookshow"></Scriptpreview> <Scriptpreview
:phoneNodeContent="phoneNodeContent"
v-if="lookshow"
></Scriptpreview>
<span slot="footer" class="dialog-footer"> <span slot="footer" class="dialog-footer">
<el-button type="primary" @click="lookshow = false"> </el-button> <el-button type="primary" @click="lookshow = false"> </el-button>
</span> </span>
@ -88,9 +196,9 @@ import {
listScriptNum, listScriptNum,
} from "@/api/manage/script"; } from "@/api/manage/script";
import stationAcatar from "../../system/stationAvatar/index.vue"; import stationAcatar from "../../system/stationAvatar/index.vue";
import DepartmentList from '../../components/DepartmentList.vue' import DepartmentList from "../../components/DepartmentList.vue";
export default { export default {
props: ["templateId", "templateName", 'node'], props: ["templateId", "templateName", "node"],
components: { stationAcatar, Scriptpreview, DepartmentList }, components: { stationAcatar, Scriptpreview, DepartmentList },
name: "Script", name: "Script",
data() { data() {
@ -160,14 +268,14 @@ export default {
methods: { methods: {
// //
clickdepartment(item) { clickdepartment(item) {
this.queryParams.hospitalAgencyId = item.hospitalAgencyId this.queryParams.hospitalAgencyId = item.hospitalAgencyId;
this.queryParams.hospitalAgencyName = item.hospitalAgencyName this.queryParams.hospitalAgencyName = item.hospitalAgencyName;
this.queryParams.departmentId = item.itemid this.queryParams.departmentId = item.itemid;
this.queryParams.departmentName = item.itemName this.queryParams.departmentName = item.itemName;
if (item.hospitalAgencyId) { if (item.hospitalAgencyId) {
this.handleQuery(); this.handleQuery();
} }
this.$forceUpdate() this.$forceUpdate();
}, },
handlesee(row) { handlesee(row) {
if (row.flowScheme == null || row.flowScheme == "") { if (row.flowScheme == null || row.flowScheme == "") {
@ -181,18 +289,20 @@ export default {
this.handleselectId = ""; this.handleselectId = "";
this.handleselectName = ""; this.handleselectName = "";
this.$emit("on-template", { this.$emit("on-template", {
robotPublishId: '', robotPublishId: "",
templateId: "", templateId: "",
templateName: "", templateName: "",
templateContent: "", templateContent: "",
scriptInfoId: '', scriptInfoId: "",
phoneTemplateId: '', phoneTemplateId: "",
}); });
}, },
handleselect(item) { handleselect(item) {
if (this.node == 'AI') { if (this.node == "AI") {
if (!item.robotPublishId) { if (!item.robotPublishId) {
return this.$message.error("机器人ID不存在请维护机器人ID或重新选择模板"); return this.$message.error(
"机器人ID不存在请维护机器人ID或重新选择模板"
);
} }
} }
this.handleselectId = item.id; this.handleselectId = item.id;
@ -204,7 +314,7 @@ export default {
phoneNodeContent: item.flowScheme, phoneNodeContent: item.flowScheme,
scriptInfoId: item.id, scriptInfoId: item.id,
phoneTemplateId: item.scriptId, phoneTemplateId: item.scriptId,
robotPublishId: item.robotPublishId robotPublishId: item.robotPublishId,
}); });
this.classificationOpen = false; this.classificationOpen = false;
}, },
@ -246,7 +356,7 @@ export default {
scriptRemark: null, scriptRemark: null,
}; };
this.resetForm("queryForm"); this.resetForm("queryForm");
this.$refs.DepartmentList.resetQuery() this.$refs.DepartmentList.resetQuery();
// this.getList(); // this.getList();
}, },
}, },