refactor: 更新注释

This commit is contained in:
dap 2025-03-07 20:48:12 +08:00
parent a66e13eca6
commit a9b7bf6442

View File

@ -1,5 +1,5 @@
<script setup lang="ts"> <script setup lang="ts">
import { computed, reactive, ref } from 'vue'; import { computed, ref } from 'vue';
import { useVbenModal } from '@vben/common-ui'; import { useVbenModal } from '@vben/common-ui';
import { DictEnum } from '@vben/constants'; import { DictEnum } from '@vben/constants';
@ -20,6 +20,9 @@ const title = computed(() => {
return isUpdate.value ? $t('pages.common.edit') : $t('pages.common.add'); return isUpdate.value ? $t('pages.common.edit') : $t('pages.common.add');
}); });
/**
* 定义表单数据类型
*/
interface FormData { interface FormData {
noticeId?: number; noticeId?: number;
noticeTitle?: string; noticeTitle?: string;
@ -28,6 +31,9 @@ interface FormData {
noticeContent?: string; noticeContent?: string;
} }
/**
* 定义默认值 用于reset
*/
const defaultValues: FormData = { const defaultValues: FormData = {
noticeId: undefined, noticeId: undefined,
noticeTitle: '', noticeTitle: '',
@ -36,15 +42,23 @@ const defaultValues: FormData = {
noticeContent: '', noticeContent: '',
}; };
/**
* 表单数据ref
*/
const formData = ref(defaultValues); const formData = ref(defaultValues);
/**
const formRules = reactive<AntdFormRules<FormData>>({ * 表单校验规则
*/
const formRules = ref<AntdFormRules<FormData>>({
status: [{ required: true, message: $t('ui.formRules.selectRequired') }], status: [{ required: true, message: $t('ui.formRules.selectRequired') }],
noticeContent: [{ required: true, message: $t('ui.formRules.required') }], noticeContent: [{ required: true, message: $t('ui.formRules.required') }],
noticeType: [{ required: true, message: $t('ui.formRules.selectRequired') }], noticeType: [{ required: true, message: $t('ui.formRules.selectRequired') }],
noticeTitle: [{ required: true, message: $t('ui.formRules.required') }], noticeTitle: [{ required: true, message: $t('ui.formRules.required') }],
}); });
/**
* useForm解构出表单方法
*/
const { validate, validateInfos, resetFields } = Form.useForm( const { validate, validateInfos, resetFields } = Form.useForm(
formData, formData,
formRules, formRules,
@ -65,6 +79,7 @@ const [BasicModal, modalApi] = useVbenModal({
isUpdate.value = !!id; isUpdate.value = !!id;
if (isUpdate.value && id) { if (isUpdate.value && id) {
const record = await noticeInfo(id); const record = await noticeInfo(id);
//
const filterRecord = pick(record, Object.keys(defaultValues)); const filterRecord = pick(record, Object.keys(defaultValues));
formData.value = filterRecord; formData.value = filterRecord;
} }
@ -75,8 +90,8 @@ const [BasicModal, modalApi] = useVbenModal({
async function handleConfirm() { async function handleConfirm() {
try { try {
modalApi.modalLoading(true); modalApi.modalLoading(true);
const test = await validate(); await validate();
console.log(test); // 使cloneDeep
const data = cloneDeep(formData.value); const data = cloneDeep(formData.value);
await (isUpdate.value ? noticeUpdate(data) : noticeAdd(data)); await (isUpdate.value ? noticeUpdate(data) : noticeAdd(data));
emit('reload'); emit('reload');