This commit is contained in:
hujiabin 2024-05-11 18:05:57 +08:00
parent b09c08a76a
commit bd19dd8ae3
3 changed files with 420 additions and 398 deletions

View File

@ -15,10 +15,10 @@ export function getMailList() {
})
}
export function updatmail(data) {
export function updateEmail(data) {
return request({
url: '/mail/update',
method: 'put',
url: '/mail/edit',
method: 'post',
data
})
}

View File

@ -50,7 +50,7 @@
<el-col :span="24">
<el-form-item v-show="groupMailVisible" style="margin-bottom: 40px;" prop="to" label="收件人列表:">
<el-input v-model="postForm.recipients" type="textarea" :rows="6" required />
</el-input>
</el-form-item>
</el-col>
</el-row>
@ -123,16 +123,12 @@ export default {
'postForm.mailtype'(val) {
switch (val) {
case MAIL_TYPE_GROUP:
{
this.userRegVisible = true
this.groupMailVisible = true
}
break
case MAIL_TYPE_ALL:
{
this.userRegVisible = true
this.groupMailVisible = false
}
break
}
/*
@ -147,13 +143,17 @@ export default {
this.dialogStatus = 'update'
const editEmail = JSON.parse(sessionStorage.getItem('editEmail' + mailid))
this.postForm = editEmail
let str = ''
editEmail.attachments.forEach((item) => {
str += item['itemid'] + ':' + item['itemnum'] + '|'
str += item['itemid'] + ':' + item['itemnum'] + '\n'
})
this.postForm.attachments = str.slice(0, -1)
this.postForm.sendtime = editEmail.sendtime * 1000
this.postForm.expiretime = editEmail.expiretime * 1000
this.postForm.user_reg_start_time = editEmail.user_reg_start_time * 1000
this.postForm.user_reg_end_time = editEmail.user_reg_end_time * 1000
this.postForm.recipients = editEmail.recipients.join('\n')
} else {
this.dialogStatus = 'create'
sessionStorage.removeItem('editEmail' + mailid)
@ -168,6 +168,16 @@ export default {
data.user_reg_start_time = data.user_reg_start_time / 1000
data.user_reg_end_time = data.user_reg_end_time / 1000
console.log('valid begin')
data.recipients = data.recipients.split('\n')
var arr = data.attachments.split('\n')
arr.forEach((item, index) => {
var recipientsArr = {}
var itemArr = item.split(':')
recipientsArr['itemid'] = parseInt(itemArr[0])
recipientsArr['itemnum'] = parseInt(itemArr[1])
arr[index] = recipientsArr
})
data.attachments = arr
try {
this.$refs['postForm'].validate((valid) => {
console.log('valid end', valid)
@ -194,6 +204,19 @@ export default {
const data = JSON.parse(JSON.stringify(this.postForm))
data.sendtime = data.sendtime / 1000
data.expiretime = data.expiretime / 1000
data.user_reg_start_time = data.user_reg_start_time / 1000
data.user_reg_end_time = data.user_reg_end_time / 1000
console.log('valid begin')
data.recipients = data.recipients.split('\n')
var arr = data.attachments.split('\n')
arr.forEach((item, index, arr) => {
var recipientsArr = {}
var itemArr = item.split(':')
recipientsArr['itemid'] = parseInt(itemArr[0])
recipientsArr['itemnum'] = parseInt(itemArr[1])
arr[index] = recipientsArr
})
data.attachments = arr
this.$refs['postForm'].validate((valid) => {
if (valid) {
updateEmail(data).then(response => {
@ -204,7 +227,7 @@ export default {
duration: 1200,
onClose: () => {
sessionStorage.removeItem('editEmail' + data.mailid)
this.$router.replace('/mail/index')
this.$router.replace('/email/index')
}
})
}

View File

@ -39,7 +39,6 @@
prop="to"
label="收件人"
/>
</el-table-column>
<el-table-column
prop="subject"
label="邮件标题"
@ -107,8 +106,8 @@ export default {
},
handleUpdate(row) {
// this.$store.dispatch('emailView/addEmail', row)
sessionStorage.setItem('editEmail' + row.mailid, JSON.stringify(row))
this.$router.replace('update/' + row.mailid)
sessionStorage.setItem('editEmail' + row.mail_id, JSON.stringify(row))
this.$router.push('update/' + row.mail_id)
},
handleDelete(row) {
delMail(row.mailid).then((response) => {