From 0dd7cf81c9d5ea63360e3f35df67bcb1baadc03e Mon Sep 17 00:00:00 2001 From: luobisheng <727299681@qq.com> Date: 星期五, 11 十一月 2022 14:19:28 +0800 Subject: [PATCH] 短信模板管理 --- src/views/operate/sms/smsTemplate/createTemplate/index.vue | 312 ++++++++------------------------------------------- 1 files changed, 51 insertions(+), 261 deletions(-) diff --git a/src/views/operate/sms/smsTemplate/createTemplate/index.vue b/src/views/operate/sms/smsTemplate/createTemplate/index.vue index 5720e60..db35460 100644 --- a/src/views/operate/sms/smsTemplate/createTemplate/index.vue +++ b/src/views/operate/sms/smsTemplate/createTemplate/index.vue @@ -5,10 +5,10 @@ <el-form ref="user" label-width="140px" autoComplete="on" :model="role" :rules="createRoleRules" label-position="right"> <!-- 娑堟伅鏍忕洰 --> - <el-form-item class="optionItem" label="妯℃澘绫诲瀷:" prop="messageType"> + <el-form-item class="optionItem" label="妯℃澘绫诲瀷:" prop="type"> <div class="message-item"> <div class="message-item__left"> - <el-select v-model="role.messageType" placeholder="璇烽�夋嫨"> + <el-select v-model="role.type" placeholder="璇烽�夋嫨"> <el-option v-for="item in colList" :key="item.id" :label="item.columnName" :value="item.id"> </el-option> @@ -17,315 +17,106 @@ </div> </el-form-item> <!-- 娑堟伅鏍囬 --> - <el-form-item class="optionItems" label="娑堟伅鏍囬:" prop="head"> + <el-form-item class="optionItems" label="娑堟伅鏍囬:" prop="title" :disabled="disabled"> <div class="message-item__left"> - <el-input v-model="role.head" placeholder="璇烽�夋嫨娑堟伅鏍囬"></el-input> + <el-input v-model="role.title" placeholder="璇烽�夋嫨娑堟伅鏍囬"></el-input> </div> </el-form-item> - <!-- 鎺ユ敹瀵硅薄 --> - <!-- <el-form-item class="optionItem" label="鎺ユ敹瀵硅薄:" prop="targetTo"> - <div class="message-item__left"> - <el-select v-model="role.targetTo" placeholder="璇烽�夋嫨鎺ユ敹瀵硅薄" > - <el-option :value="role.targetTo"> - <el-tree ref="tree" :data="departList" :props="defaultProps" show-checkbox - @check="handleCheck" default-expand-all node-key="id"> - </el-tree> - </el-option> - </el-select> - </div> - </el-form-item> --> <!-- 娑堟伅鍐呭 --> - <el-form-item class="optionItem" label="娑堟伅鍐呭:" prop="body"> - <MyEditor ref="edit" @getMyBody="getMyBody"></MyEditor> - <!-- <el-input type="textarea" v-model="role.description" placeholder="璇疯緭鍏ユ弿杩板唴瀹�200瀛椾互鍐�"></el-input> --> + <el-form-item class="optionItem" label="娑堟伅鍐呭:" prop="body" :disabled="disabled"> + <MyEditor ref="edit" @getMyBody="getMyBody" ></MyEditor> </el-form-item> - <!-- 鎻愰啋鏂瑰紡 --> - <!-- <el-form-item class="optionItem" label="鎻愰啋鏂瑰紡:" prop="channelCode"> - <el-radio-group v-model="role.channelCode"> - <el-radio label="01">绔欏唴淇�</el-radio> - <el-radio label="02">閭欢</el-radio> - <el-radio label="03">鐭俊</el-radio> - </el-radio-group> - <span class="message-tip">(鐭俊鍙敤鏁�: 1000鏉�)</span> - </el-form-item> --> <el-form-item> <div class="optionBtn"> <el-button type="primary" @click.native.prevent="handleSubmit(0)" class="btn save">淇濆瓨 </el-button> - <!-- <el-button type="primary" @click.native.prevent="handleSubmit(1)" class="btn submit">鍙戝竷 - </el-button> - <el-button type="primary" @click.native.prevent="handleView" class="btn submit">棰勮 - </el-button> --> <el-button class="btn cancel" @click.native.prevent="handleReset">閲嶇疆</el-button> </div> </el-form-item> </el-form> - <!-- 鏂板鏍忕洰 --> - <el-dialog title="娣诲姞鏍忕洰" :visible.sync="dialogCreate" v-if="dialogCreate" width="60%" - :before-close="handleConfirmClose" append-to-body> - <MyColumnAdd @closeDialog="closeDialog"></MyColumnAdd> - </el-dialog> - <!-- 棰勮娑堟伅 --> - <el-dialog title="娑堟伅棰勮" :visible.sync="dialogView" v-if="dialogView" width="60%" - :before-close="handleConfirmClose" append-to-body> - <MyColView :info="info" @closeDialog="closeDialog"></MyColView> - </el-dialog> </div> </main> </div> </template> <script> -import MyEditor from '@/components/edit' +import MyEditor from '@/components/edit'; +import SMS from "@/api/operate/SMS"; +import { deepClone } from "@/utils/helper"; + export default { - components: { MyEditor, }, + components: { MyEditor }, data() { - const validateNickname = (rule, value, callback) => { - if (!value) { - callback(new Error("璇峰~鍐欐秷鎭爮鐩�")); - } else { - callback(); - } - }; - const validatePass = (rule, value, callback) => { - if (!value) { - callback(); - } else { - callback(); - } - }; - const validateTruename = (rule, value, callback) => { - if (value.length !== 0) { - callback(); - } else { - callback(new Error('璇烽�夋嫨鎺ユ敹瀵硅薄')); - } - }; + const validateMessageContent = (rule, value, callback) => { + if (!value) { + callback(new Error('璇疯緭鍏ョ煭淇″唴瀹�')) + } else { + this.$refs.user.clearValidate('body'); + } + } return { role: { - messageType: '', - head: '', - targetTo: '', - targetFrom: null, + type: '', + title: '', body: '', - channelCode: '01', }, createRoleRules: { - messageType: [ - { required: true, trigger: "blur", validator: validateNickname }, + type: [ + { required: true, trigger: "blur", message: '璇峰~鍐欐秷鎭爮鐩�' }, ], - head: [ - { required: false, trigger: "blur", validator: validatePass }, + title: [ + { required: true, trigger: "blur", message: '璇峰~鍐欐秷鎭爣棰�' }, ], - targetTo: [ - { required: false, trigger: "blur", validator: validateTruename }, - ], + body: [ + { required: true, trigger: ['blur', 'change'], validator: validateMessageContent } + ] }, - colList: [], - departList: [], - typeList: [], - dialogCreate: false, - dialogView: false, - defaultProps: { - children: 'children', - label: 'departName', - // disabled: function (data, node) { - // if (data.createTime) { - // return !data.leaf - // } - // } - }, - checkedList: [], - tempNameArr:[], - info:{}, - sendUser:"" + colList: [{ id: "1", columnName: "楠岃瘉鐮佹ā鏉�"}, {id: "2",columnName: "娲诲姩妯℃澘"}], + disabled: this.dialogType === 'view' } }, created() { - this.setColumnList(); - this.setDepartList(); - this.getLoginUserInfo(); + if (this.tableRowData) { + this.role = deepClone(this.tableRowData); + } }, methods: { - // 鍏抽棴寮圭獥 - handleConfirmClose(done) { - this.$confirm('纭鍏抽棴?') - .then(_ => { - done(); - }) - }, - // 璁剧疆鏍忕洰 - async setColumnList() { - this.colList = [{"id":"1","columnName":"楠岃瘉鐮佹ā鏉�"},{"id":"2","columnName":"娲诲姩妯℃澘"}]; - }, - // 鑾峰彇鏍忕洰 - async getColumnList() { - let arr; - await this.$axios({ - method: 'get', - url: 'sccg/message_column/getAllColumn' - }) - .then(res => { - console.log(res); - arr = res.data; - }) - return arr; - }, - // 鍏抽棴寮圭獥 - closeDialog({ flag, index }) { - this.dialogCreate = flag; - if (index === 1) { - // 閲嶆柊璁剧疆鏍忕洰 - this.setColumnList(); - } - }, - // 鑾峰彇閮ㄩ棬鏍� - async getDepartList() { - let arr - await this.$axios({ - method: 'get', - url: 'sccg/depart/tree' - }) - .then(res => { - arr = res.data - }) - return arr; - }, - // 璁剧疆閮ㄩ棬鏍� - async setDepartList() { - this.departList = await this.filterDepartList(); - }, - // 澶勭悊閮ㄩ棬鏍� - async filterDepartList() { - let arr = await this.getDepartList(); - const { setChildren } = this; - // console.log(setChildren); - arr.forEach(item => { - setChildren(item); - }) - return arr; - }, - // 閫掑綊children - setChildren(obj) { - if (obj.children !== null) { - if (obj.children.length !== 0) { - obj.children.forEach(item => { - return this.setChildren(item); - }) - } - } else { - if (obj.userInfoDTOS.length !== 0) { - obj.children = []; - obj.userInfoDTOS.forEach(item => { - obj.children.push({ id: item.userId, departName: item.username }) - }) - } - } - }, - // 閫変腑id - handleCheck(data, node) { - let arr = [],nameArr = [] - console.log(node.checkedNodes) - node.checkedNodes.forEach(item => { - if(!item.hasOwnProperty('departType')){ - arr.push(item.id) - nameArr.push(item.departName) - } - }) - this.checkedList = arr - this.tempNameArr = nameArr - console.log(this.tempNameArr) - this.role.targetTo = arr.length + '浜�' - }, // 鏂板缓/淇濆瓨娑堟伅(1:鏂板缓,0淇濆瓨娑堟伅) - handleSubmit(mystatus) { + handleSubmit() { this.$refs.user.validate((valid) => { if (valid) { - const { role, checkedList } = this; - console.log(checkedList); - this.$axios({ - method: 'post', - url: 'sccg/message_sms_template/addSmsTemplate', - data: { - body: role.body, - channelCode: `${role.channelCode}`, - title: role.head, - type: role.messageType, - sendTime: new Date(), - targetTo: checkedList.join(','), - targetFrom: `${role.targetFrom}`, - status: mystatus, - } - }) - .then(res => { - if (res.code === 200) { - this.$message({ - type: 'success', - message: mystatus === 1 ? '鍙戦�佹垚鍔�' : '淇濆瓨鎴愬姛', - }) - this.$emit('closeMyDialog', { flag: false, index: 1 }); - } + if (this.dialogType === 'created') { + SMS.addNewSMSTemplate(this.role) + .then(() => { + this.$message({ type: 'success', message: '鎿嶄綔鎴愬姛' }); + this.$emit('closeDialog'); }) + .catch(err => this.$message({ type: 'error', message: err })); + } else { + SMS.updateSMSTemplatate(this.tableRowData.id, this.role) + .then(() => { + this.$message({ type: 'success', message: '鎿嶄綔鎴愬姛' }); + this.$emit('closeDialog'); + }) + .catch(err => this.$message({ type: 'error', message: err })); + } + } else { - return false; + this.$message({ type: 'warning', message: '璇锋鏌ュ繀濉」' }); } }) }, // 鑾峰緱娑堟伅浣� getMyBody(obj) { - console.log(obj); this.role.body = obj; }, + // 閲嶇疆琛ㄥ崟 handleReset() { this.$refs.edit.editor.txt.clear(); - // this.$refs.edit.wangEditor.txt.html('<p><br></p>') - this.setDepartList(); this.$refs.user.resetFields(); - }, - // 鑾峰彇褰撳墠鐧诲綍鐢ㄦ埛淇℃伅 - getLoginUserInfo() { - const name = sessionStorage.getItem('name'); - this.$axios({ - method: 'get', - url: 'sccg/admin/info?name=' + name, - }) - .then(res => { - this.role.targetFrom = res.data.userId - this.sendUser = res.data.username - }) - }, - // 娑堟伅棰勮 - handleView() { - this.$refs.user.validate((valid) => { - if (valid) { - const { role,getColText,tempNameArr,sendUser } = this - this.dialogView = true; - let info = {} - // 鑾峰緱鏍忕洰娑堟伅 - info.channelCode = role.channelCode === '01'? '绔欏唴淇�': role.channelCode === '02' ? '閭欢':'鐭俊' - info.messageType = getColText(role.messageType) - info.body = role.body - info.head = role.head - info.targetTo = tempNameArr - info.targetFrom = sendUser - this.info = info - } else { - return false - } - }) - }, - // 鑾峰緱鏍忕洰娑堟伅 - getColText(id){ - console.log(id) - const {colList} = this - let str = '' - colList.forEach(item=>{ - item.id === id ? str = item.columnName : '' - }) - return str } }, - props: ['closeMyDialog'] + props: ['tableRowData', 'dialogType'] } </script> <style lang="scss" scoped> @@ -335,7 +126,6 @@ main { text-align: left; - padding: 0 55px; background-color: #09152f; padding-bottom: 50px; -- Gitblit v1.8.0