perf: 更新写法

This commit is contained in:
dap
2024-09-25 14:46:02 +08:00
parent 27e976c40d
commit b68d746fdd
14 changed files with 84 additions and 133 deletions

View File

@@ -3,6 +3,7 @@ import { computed, ref } from 'vue';
import { useVbenDrawer } from '@vben/common-ui';
import { $t } from '@vben/locales';
import { cloneDeep } from '@vben/utils';
import { useVbenForm } from '#/adapter';
import { clientAdd, clientUpdate } from '#/api/system/client';
@@ -69,9 +70,7 @@ const [BasicDrawer, drawerApi] = useVbenDrawer({
if (dictCode && isUpdate.value) {
const record = await dictDetailInfo(dictCode);
setupSelectType(record.listClass);
for (const key in record) {
await formApi.setFieldValue(key, record[key as keyof typeof record]);
}
await formApi.setValues(record);
}
drawerApi.drawerLoading(false);
@@ -85,7 +84,7 @@ async function handleConfirm() {
if (!valid) {
return;
}
const data = await formApi.getValues();
const data = cloneDeep(await formApi.getValues());
await (isUpdate.value ? clientUpdate(data) : clientAdd(data));
emit('reload');
await handleCancel();

View File

@@ -3,19 +3,19 @@ import { computed, ref } from 'vue';
import { useVbenModal } from '@vben/common-ui';
import { $t } from '@vben/locales';
import { cloneDeep } from '@vben/utils';
import { useVbenForm } from '#/adapter';
import { dictTypeAdd, dictTypeUpdate } from '#/api/system/dict/dict-type';
import {
dictTypeAdd,
dictTypeInfo,
dictTypeUpdate,
} from '#/api/system/dict/dict-type';
import { modalSchema } from './data';
const emit = defineEmits<{ reload: [] }>();
interface ModalProps {
update: boolean;
record?: any;
}
const isUpdate = ref(false);
const title = computed(() => {
return isUpdate.value ? $t('pages.common.edit') : $t('pages.common.add');
@@ -38,12 +38,11 @@ const [BasicModal, modalApi] = useVbenModal({
return null;
}
modalApi.modalLoading(true);
const { record, update } = modalApi.getData() as ModalProps;
isUpdate.value = update;
if (update && record) {
for (const key in record) {
await formApi.setFieldValue(key, record[key]);
}
const { id } = modalApi.getData() as { id?: number | string };
isUpdate.value = !!id;
if (isUpdate.value && id) {
const record = await dictTypeInfo(id);
await formApi.setValues(record);
}
modalApi.modalLoading(false);
},
@@ -56,7 +55,7 @@ async function handleConfirm() {
if (!valid) {
return;
}
const data = await formApi.getValues();
const data = cloneDeep(await formApi.getValues());
await (isUpdate.value ? dictTypeUpdate(data) : dictTypeAdd(data));
emit('reload');
await handleCancel();