Vue3 重构:邮件日志的列表

pull/34/MERGE
YunaiV 2023-03-18 12:24:21 +08:00
parent e8d83d4718
commit 3c75d6065d
3 changed files with 169 additions and 201 deletions

View File

@ -1,98 +1,59 @@
<template> <template>
<ContentWrap> <!-- 搜索工作栏 -->
<!-- 列表 --> <content-wrap>
<XTable @register="registerTable"> <Search :schema="allSchemas.searchSchema" @search="setSearchParams" @reset="setSearchParams" />
<template #accountId_search> </content-wrap>
<el-select v-model="queryParams.accountId">
<el-option :key="undefined" label="全部" :value="undefined" /> <!-- 列表 -->
<el-option <content-wrap>
v-for="item in accountOptions" <Table
:key="item.id" :columns="allSchemas.tableColumns"
:label="item.mail" :data="tableObject.tableList"
:value="item.id" :loading="tableObject.loading"
/> :pagination="{
</el-select> total: tableObject.total
</template> }"
<template #toMail_default="{ row }"> v-model:pageSize="tableObject.pageSize"
<div>{{ row.toMail }}</div> v-model:currentPage="tableObject.currentPage"
<div v-if="row.userType && row.userId"> >
<DictTag :type="DICT_TYPE.USER_TYPE" :value="row.userType" />{{ '(' + row.userId + ')' }} <template #action="{ row }">
</div> <el-button
</template> link
<template #actionbtns_default="{ row }"> type="primary"
<!-- 操作详情 --> @click="openModal('update', row.id)"
<XTextButton
preIcon="ep:view"
:title="t('action.detail')"
v-hasPermi="['system:mail-log:query']" v-hasPermi="['system:mail-log:query']"
@click="handleDetail(row.id)" >
/> 详情
</el-button>
</template> </template>
</XTable> </Table>
</ContentWrap> </content-wrap>
<!-- 弹窗 -->
<XModal id="mailLogModel" :loading="modelLoading" v-model="modelVisible" :title="modelTitle"> <!-- 表单弹窗添加/修改 -->
<!-- 表单详情 --> <!-- <mail-account-form ref="modalRef" @success="getList" />-->
<Descriptions
v-if="actionType === 'detail'"
:schema="allSchemas.detailSchema"
:data="detailData"
/>
<template #footer>
<!-- 按钮关闭 -->
<XButton :loading="actionLoading" :title="t('dialog.close')" @click="modelVisible = false" />
</template>
</XModal>
</template> </template>
<script setup lang="ts" name="MailLog"> <script setup lang="ts" name="MailLog">
// import
import { DICT_TYPE } from '@/utils/dict'
import { allSchemas } from './log.data' import { allSchemas } from './log.data'
import * as MailLogApi from '@/api/system/mail/log' import * as MailLogApi from '@/api/system/mail/log'
import * as MailAccountApi from '@/api/system/mail/account' // import MailAccountForm from './form.vue'
const { t } = useI18n() // // tableObject
// tableMethods
// // https://kailong110120130.gitee.io/vue-element-plus-admin-doc/components/table.html#usetable
const queryParams = reactive({ const { tableObject, tableMethods } = useTable({
accountId: null getListApi: MailLogApi.getMailLogPageApi //
}) })
const [registerTable] = useXTable({ //
allSchemas: allSchemas, const { getList, setSearchParams } = tableMethods
topActionSlots: false,
params: queryParams,
getListApi: MailLogApi.getMailLogPageApi
})
const accountOptions = ref<any[]>([]) //
// /** 添加/修改操作 */
const modelVisible = ref(false) // const modalRef = ref()
const modelTitle = ref('edit') // const openModal = (type: string, id?: number) => {
const modelLoading = ref(false) // loading modalRef.value.openModal(type, id)
const actionType = ref('') //
const actionLoading = ref(false) // Loading
const detailData = ref() // Ref
//
const setDialogTile = (type: string) => {
modelLoading.value = true
modelTitle.value = t('action.' + type)
actionType.value = type
modelVisible.value = true
} }
// /** 初始化 **/
const handleDetail = async (rowId: number) => {
setDialogTile('detail')
const res = await MailLogApi.getMailLogApi(rowId)
detailData.value = res
modelLoading.value = false
}
// ========== ==========
onMounted(() => { onMounted(() => {
MailAccountApi.getSimpleMailAccountList().then((data) => { getList()
accountOptions.value = data
})
}) })
</script> </script>

View File

@ -1,121 +1,127 @@
import type { VxeCrudSchema } from '@/hooks/web/useVxeCrudSchemas' import type { CrudSchema } from '@/hooks/web/useCrudSchemas'
import { dateFormatter } from '@/utils/formatTime'
import * as MailAccountApi from '@/api/system/mail/account'
// CrudSchema // 邮箱账号的列表
const crudSchemas = reactive<VxeCrudSchema>({ const accounts = await MailAccountApi.getSimpleMailAccountList()
primaryKey: 'id',
primaryTitle: '编号', // CrudSchemahttps://kailong110120130.gitee.io/vue-element-plus-admin-doc/hooks/useCrudSchemas.html
primaryType: 'id', const crudSchemas = reactive<CrudSchema[]>([
action: true, {
actionWidth: '70', label: '编号',
columns: [ field: 'id'
{ },
title: '发送时间', {
field: 'sendTime', label: '发送时间',
table: { field: 'sendTime',
width: 180 formatter: dateFormatter,
}, search: {
formatter: 'formatDate', show: true,
search: { component: 'DatePicker',
show: true, componentProps: {
itemRender: { valueFormat: 'YYYY-MM-DD HH:mm:ss',
name: 'XDataTimePicker' type: 'daterange',
} defaultTime: [new Date('1 00:00:00'), new Date('1 23:59:59')]
} }
},
{
title: '接收邮箱',
field: 'toMail',
isSearch: true,
table: {
width: 180,
slots: {
default: 'toMail_default'
}
}
},
{
title: '用户编号',
field: 'userId',
isSearch: true,
isTable: false
},
{
title: '用户类型',
field: 'userType',
dictType: DICT_TYPE.USER_TYPE,
dictClass: 'number',
isSearch: true,
isTable: false
},
{
title: '邮件标题',
field: 'templateTitle'
},
{
title: '邮件内容',
field: 'templateContent',
isTable: false
},
{
title: '邮箱参数',
field: 'templateParams',
isTable: false
},
{
title: '发送状态',
field: 'sendStatus',
dictType: DICT_TYPE.SYSTEM_MAIL_SEND_STATUS,
dictClass: 'string',
isSearch: true
},
{
title: '邮箱账号',
field: 'accountId',
isSearch: true,
isTable: false,
search: {
slots: {
default: 'accountId_search'
}
}
},
{
title: '发送邮箱地址',
field: 'fromMail',
table: {
title: '邮箱账号'
}
},
{
title: '模板编号',
field: 'templateId',
isSearch: true
},
{
title: '模板编码',
field: 'templateCode',
isTable: false
},
{
title: '模版发送人名称',
field: 'templateNickname',
isTable: false
},
{
title: '发送返回的消息编号',
field: 'sendMessageId',
isTable: false
},
{
title: '发送异常',
field: 'sendException',
isTable: false
},
{
title: '创建时间',
field: 'createTime',
isTable: false
} }
] },
}) {
export const { allSchemas } = useVxeCrudSchemas(crudSchemas) label: '接收邮箱',
field: 'toMail'
},
{
label: '用户编号',
field: 'userId',
isSearch: true,
isTable: false
},
{
label: '用户类型',
field: 'userType',
dictType: DICT_TYPE.USER_TYPE,
dictClass: 'number',
isSearch: true,
isTable: false
},
{
label: '邮件标题',
field: 'templateTitle'
},
{
label: '邮件内容',
field: 'templateContent',
isTable: false
},
{
label: '邮箱参数',
field: 'templateParams',
isTable: false
},
{
label: '发送状态',
field: 'sendStatus',
dictType: DICT_TYPE.SYSTEM_MAIL_SEND_STATUS,
dictClass: 'string',
isSearch: true
},
{
label: '邮箱账号',
field: 'accountId',
isTable: false,
search: {
show: true,
component: 'Select',
api: () => accounts,
componentProps: {
optionsAlias: {
labelField: 'mail',
valueField: 'id'
}
}
}
},
{
label: '发送邮箱地址',
field: 'fromMail',
table: {
label: '邮箱账号'
}
},
{
label: '模板编号',
field: 'templateId',
isSearch: true
},
{
label: '模板编码',
field: 'templateCode',
isTable: false
},
{
label: '模版发送人名称',
field: 'templateNickname',
isTable: false
},
{
label: '发送返回的消息编号',
field: 'sendMessageId',
isTable: false
},
{
label: '发送异常',
field: 'sendException',
isTable: false
},
{
label: '创建时间',
field: 'createTime',
isTable: false,
formatter: dateFormatter
},
{
label: '操作',
field: 'action',
isForm: false
}
])
export const { allSchemas } = useCrudSchemas(crudSchemas)

View File

@ -3,6 +3,7 @@ import { dateFormatter } from '@/utils/formatTime'
import { TableColumn } from '@/types/table' import { TableColumn } from '@/types/table'
import * as MailAccountApi from '@/api/system/mail/account' import * as MailAccountApi from '@/api/system/mail/account'
// 邮箱账号的列表
const accounts = await MailAccountApi.getSimpleMailAccountList() const accounts = await MailAccountApi.getSimpleMailAccountList()
// 表单校验 // 表单校验