123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 |
- <template>
- <a-drawer
- :title="title"
- :maskClosable="true"
- width=650
- placement="right"
- :closable="true"
- @close="close"
- :visible="visible"
- style="overflow: auto;padding-bottom: 53px;">
- <a-spin :spinning="confirmLoading">
- <a-form :form="form">
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="消息标题">
- <a-input placeholder="请输入消息标题" v-decorator="['esTitle', {}]"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="发送内容">
- <a-input placeholder="请输入发送内容" v-decorator="['esContent', {}]"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="发送所需参数">
- <a-input placeholder="请输入发送所需参数Json格式" v-decorator="['esParam', {}]"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="接收人">
- <a-input placeholder="请输入接收人" v-decorator="['esReceiver', {}]"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="发送方式">
- <j-dict-select-tag :triggerChange="true" dictCode="msgType" v-decorator="[ 'esType', {}]" placeholder="请选择发送方式">
- </j-dict-select-tag>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="发送时间">
- <a-date-picker showTime format='YYYY-MM-DD HH:mm:ss' v-decorator="[ 'esSendTime', {}]"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="发送状态">
- <j-dict-select-tag :triggerChange="true" dictCode="msgSendStatus" v-decorator="[ 'esSendStatus', {}]" placeholder="请选择发送状态">
- </j-dict-select-tag>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="发送次数">
- <a-input v-decorator="[ 'esSendNum', {}]"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="发送失败原因">
- <a-input v-decorator="['esResult', {}]"/>
- </a-form-item>
- <a-form-item
- :labelCol="labelCol"
- :wrapperCol="wrapperCol"
- label="备注">
- <a-input v-decorator="['remark', {}]"/>
- </a-form-item>
- </a-form>
- </a-spin>
- <div v-show="!disableSubmit">
- <a-button style="margin-right: .8rem" @confirm="handleCancel">取消</a-button>
- <a-button @click="handleOk" type="primary" :loading="confirmLoading">提交</a-button>
- </div>
- </a-drawer>
- </template>
- <script>
- import {httpAction} from '@/api/manage'
- import pick from 'lodash.pick'
- import moment from "moment"
- export default {
- name: "SysMessageModal",
- data() {
- return {
- title: "操作",
- visible: false,
- model: {},
- labelCol: {
- xs: {span: 24},
- sm: {span: 5},
- },
- wrapperCol: {
- xs: {span: 24},
- sm: {span: 16},
- },
- confirmLoading: false,
- form: this.$form.createForm(this),
- validatorRules: {},
- disableSubmit: true,
- url: {
- add: "/sys/message/sysMessage/add",
- edit: "/sys/message/sysMessage/edit",
- },
- }
- },
- created() {
- },
- methods: {
- add() {
- this.edit({});
- },
- edit(record) {
- this.form.resetFields();
- this.model = Object.assign({}, record);
- this.visible = true;
- this.$nextTick(() => {
- this.form.setFieldsValue(pick(this.model, 'esContent', 'esParam', 'esReceiver', 'esResult', 'esSendNum', 'esSendStatus', 'esTitle', 'esType', 'remark'))
- //时间格式化
- this.form.setFieldsValue({esSendTime: this.model.esSendTime ? moment(this.model.esSendTime) : null})
- });
- },
- close() {
- this.$emit('close');
- this.visible = false;
- },
- handleOk() {
- const that = this;
- // 触发表单验证
- this.form.validateFields((err, values) => {
- if (!err) {
- that.confirmLoading = true;
- let httpurl = '';
- let method = '';
- if (!this.model.id) {
- httpurl += this.url.add;
- method = 'post';
- } else {
- httpurl += this.url.edit;
- //method = 'put';
- method = 'post';
- }
- let formData = Object.assign(this.model, values);
- //时间格式化
- formData.esSendTime = formData.esSendTime ? formData.esSendTime.format('YYYY-MM-DD HH:mm:ss') : null;
- console.log(formData)
- httpAction(httpurl, formData, method).then((res) => {
- if (res.success) {
- that.$message.success(res.message);
- that.$emit('ok');
- } else {
- that.$message.warning(res.message);
- }
- }).finally(() => {
- that.confirmLoading = false;
- that.close();
- })
- }
- })
- },
- handleCancel() {
- this.close()
- },
- }
- }
- </script>
- <style scoped>
- </style>
|