auth-web/src/views/configuration/email-template/utils/hooks.tsx

127 lines
3.4 KiB
TypeScript
Raw Normal View History

2025-04-25 16:21:15 +08:00
import { addDialog } from '@/components/ReDialog/index';
import EmailTemplateDialog from '@/views/configuration/email-template/components/email-template-dialog.vue';
2025-04-24 13:43:37 +08:00
import { useEmailTemplateStore } from '@/store/configuration/emailTemplate';
import { h, ref } from 'vue';
2025-04-27 22:16:06 +08:00
import { messageBox } from '@/utils/message';
2025-04-24 13:43:37 +08:00
import type { FormItemProps } from '@/views/configuration/email-template/utils/types';
import { $t } from '@/plugins/i18n';
2025-04-25 16:21:15 +08:00
const emailTemplateStore = useEmailTemplateStore();
2025-04-24 13:43:37 +08:00
// 选择的row列表
export const selectRows = ref([]);
/** 搜索初始化邮件模板表 */
export async function onSearch() {
emailTemplateStore.loading = true;
2025-04-26 10:25:12 +08:00
await emailTemplateStore.fetchEmailTemplatePage();
2025-04-24 13:43:37 +08:00
emailTemplateStore.loading = false;
}
/** 添加邮件模板表 */
export function onAdd() {
2025-04-25 16:21:15 +08:00
const formRef = ref();
2025-04-24 13:43:37 +08:00
addDialog({
title: `${$t('addNew')}${$t('emailTemplate')}`,
width: '30%',
props: {
formInline: {
templateName: undefined,
emailUser: undefined,
subject: undefined,
2025-04-27 22:16:06 +08:00
isDefault: false,
2025-04-24 13:43:37 +08:00
body: undefined,
type: undefined,
},
},
draggable: true,
fullscreenIcon: true,
closeOnClickModal: false,
contentRenderer: () => h(EmailTemplateDialog, { ref: formRef }),
beforeSure: (done, { options }) => {
const form = options.props.formInline as FormItemProps;
formRef.value.formRef.validate(async (valid: any) => {
if (!valid) return;
const result = await emailTemplateStore.addEmailTemplate(form);
if (!result) return;
done();
await onSearch();
});
},
});
}
2025-04-27 22:16:06 +08:00
/* 更新邮件模板表 */
2025-04-24 13:43:37 +08:00
export function onUpdate(row: any) {
2025-04-25 16:21:15 +08:00
const formRef = ref();
2025-04-24 13:43:37 +08:00
addDialog({
title: `${$t('modify')}${$t('emailTemplate')}`,
width: '30%',
props: {
formInline: {
templateName: row.templateName,
emailUser: row.emailUser,
subject: row.subject,
isDefault: row.isDefault,
body: row.body,
type: row.type,
},
},
draggable: true,
fullscreenIcon: true,
closeOnClickModal: false,
contentRenderer: () => h(EmailTemplateDialog, { ref: formRef }),
beforeSure: (done, { options }) => {
const form = options.props.formInline as FormItemProps;
2025-04-25 16:21:15 +08:00
// 验证表单
2025-04-24 13:43:37 +08:00
formRef.value.formRef.validate(async (valid: any) => {
if (!valid) return;
2025-04-27 22:16:06 +08:00
const result = await emailTemplateStore.editEmailTemplate({ ...form, id: row.id });
2025-04-24 13:43:37 +08:00
if (!result) return;
done();
await onSearch();
});
},
});
}
/** 删除邮件模板表 */
export const onDelete = async (row: any) => {
const id = row.id;
// 是否确认删除
const result = await messageBox({
title: $t('confirmDelete'),
showMessage: false,
confirmMessage: undefined,
cancelMessage: $t('confirmDelete'),
});
if (!result) return;
// 删除数据
2025-04-27 22:16:06 +08:00
await emailTemplateStore.removeEmailTemplate([id]);
2025-04-24 13:43:37 +08:00
await onSearch();
};
/** 批量删除 */
export const onDeleteBatch = async () => {
2025-04-27 22:16:06 +08:00
// 是否确认删除
const result = await messageBox({
title: $t('confirmDelete'),
showMessage: false,
confirmMessage: undefined,
cancelMessage: $t('cancel_delete'),
2025-04-24 13:43:37 +08:00
});
2025-04-27 22:16:06 +08:00
if (!result) return;
2025-04-24 13:43:37 +08:00
2025-04-27 22:16:06 +08:00
// 删除数据
const ids = selectRows.value.map((row: any) => row.id);
await emailTemplateStore.removeEmailTemplate(ids);
await onSearch();
2025-04-24 13:43:37 +08:00
};