feat:邮箱模版的读取,放到 data.ts

pull/76/head
YunaiV 2025-04-19 09:44:49 +08:00
parent 3ff60f9690
commit eea46a1920
2 changed files with 10 additions and 29 deletions

View File

@ -1,7 +1,6 @@
import type { VbenFormSchema } from '#/adapter/form'; import type { VbenFormSchema } from '#/adapter/form';
import type { OnActionClickFn, VxeTableGridOptions } from '#/adapter/vxe-table'; import type { OnActionClickFn, VxeTableGridOptions } from '#/adapter/vxe-table';
import type { SystemMailTemplateApi } from '#/api/system/mail/template'; import type { SystemMailTemplateApi } from '#/api/system/mail/template';
import type { ComputedRef } from 'vue';
import { z } from '#/adapter/form'; import { z } from '#/adapter/form';
import { getSimpleMailAccountList } from '#/api/system/mail/account'; import { getSimpleMailAccountList } from '#/api/system/mail/account';
@ -192,9 +191,9 @@ export function useGridFormSchema(): VbenFormSchema[] {
} }
/** 列表的字段 */ /** 列表的字段 */
const accountList = await getSimpleMailAccountList();
export function useGridColumns<T = SystemMailTemplateApi.SystemMailTemplate>( export function useGridColumns<T = SystemMailTemplateApi.SystemMailTemplate>(
onActionClick: OnActionClickFn<T>, onActionClick: OnActionClickFn<T>
getAccountName: ComputedRef<(cellValue: number) => string>,
): VxeTableGridOptions['columns'] { ): VxeTableGridOptions['columns'] {
return [ return [
{ {
@ -221,7 +220,7 @@ export function useGridColumns<T = SystemMailTemplateApi.SystemMailTemplate>(
field: 'accountId', field: 'accountId',
title: '邮箱账号', title: '邮箱账号',
minWidth: 120, minWidth: 120,
formatter: ({ cellValue }) => getAccountName.value(cellValue), formatter: ({ cellValue }) => accountList.find((account) => account.id === cellValue)?.mail || '-',
}, },
{ {
field: 'nickname', field: 'nickname',

View File

@ -1,20 +1,17 @@
<script lang="ts" setup> <script lang="ts" setup>
import type { OnActionClickParams, VxeTableGridOptions } from '#/adapter/vxe-table'; import type { OnActionClickParams, VxeTableGridOptions } from '#/adapter/vxe-table';
import type { SystemMailAccountApi } from '#/api/system/mail/account';
import type { SystemMailTemplateApi } from '#/api/system/mail/template'; import type { SystemMailTemplateApi } from '#/api/system/mail/template';
import { DocAlert } from '#/components/doc-alert';
import Form from './modules/form.vue'; import Form from './modules/form.vue';
import SendForm from './modules/send-form.vue'; import SendForm from './modules/send-form.vue';
import { Page, useVbenModal } from '@vben/common-ui'; import { Page, useVbenModal } from '@vben/common-ui';
import { Plus } from '@vben/icons'; import { Plus } from '@vben/icons';
import { Button, message } from 'ant-design-vue'; import { Button, message } from 'ant-design-vue';
import { DocAlert } from '#/components/doc-alert';
import { useVbenVxeGrid } from '#/adapter/vxe-table'; import { useVbenVxeGrid } from '#/adapter/vxe-table';
import { getSimpleMailAccountList } from '#/api/system/mail/account';
import { deleteMailTemplate, getMailTemplatePage } from '#/api/system/mail/template'; import { deleteMailTemplate, getMailTemplatePage } from '#/api/system/mail/template';
import { $t } from '#/locales'; import { $t } from '#/locales';
import { computed, ref } from 'vue';
import { useGridColumns, useGridFormSchema } from './data'; import { useGridColumns, useGridFormSchema } from './data';
@ -70,30 +67,27 @@ async function onDelete(row: SystemMailTemplateApi.SystemMailTemplate) {
/** 表格操作按钮的回调函数 */ /** 表格操作按钮的回调函数 */
function onActionClick({ code, row }: OnActionClickParams<SystemMailTemplateApi.SystemMailTemplate>) { function onActionClick({ code, row }: OnActionClickParams<SystemMailTemplateApi.SystemMailTemplate>) {
switch (code) { switch (code) {
case 'delete': {
onDelete(row);
break;
}
case 'edit': { case 'edit': {
onEdit(row); onEdit(row);
break; break;
} }
case 'delete': {
onDelete(row);
break;
}
case 'send': { case 'send': {
onSend(row); onSend(row);
break; break;
} }
} }
} }
const mailAccountList = ref<SystemMailAccountApi.SystemMailAccount[]>([]);
const getAccountName = computed(
() => (cellValue: number) => mailAccountList.value.find((item) => item.id === cellValue)?.mail || '',
);
const [Grid, gridApi] = useVbenVxeGrid({ const [Grid, gridApi] = useVbenVxeGrid({
formOptions: { formOptions: {
schema: useGridFormSchema(), schema: useGridFormSchema(),
}, },
gridOptions: { gridOptions: {
columns: useGridColumns(onActionClick, getAccountName), columns: useGridColumns(onActionClick),
height: 'auto', height: 'auto',
keepSource: true, keepSource: true,
proxyConfig: { proxyConfig: {
@ -116,18 +110,6 @@ const [Grid, gridApi] = useVbenVxeGrid({
}, },
} as VxeTableGridOptions<SystemMailTemplateApi.SystemMailTemplate>, } as VxeTableGridOptions<SystemMailTemplateApi.SystemMailTemplate>,
}); });
/** 获取邮箱账号精简列表 */
async function initMailAccountList() {
try {
mailAccountList.value = await getSimpleMailAccountList();
} catch (error) {
console.error('获取邮箱账号精简列表失败', error);
}
}
/** 初始化 */
initMailAccountList();
</script> </script>
<template> <template>
<Page auto-content-height> <Page auto-content-height>