| <script lang="ts" setup> | 
| import { ref, unref } from 'vue' | 
| import { createFormSchema, updateFormSchema } from './${classNameVar}.data' | 
| import { useI18n } from '@/hooks/web/useI18n' | 
| import { useMessage } from '@/hooks/web/useMessage' | 
| import { BasicForm, useForm } from '@/components/Form' | 
| import { BasicModal, useModalInner } from '@/components/Modal' | 
| import { create${simpleClassName}, get${simpleClassName}, update${simpleClassName} } from '@/api/${table.moduleName}/${table.businessName}' | 
|   | 
| defineOptions({ name: '${table.className}Modal' }) | 
|   | 
| const emit = defineEmits(['success', 'register']) | 
|   | 
| const { t } = useI18n() | 
| const { createMessage } = useMessage() | 
| const isUpdate = ref(true) | 
|   | 
| const [registerForm, { setFieldsValue, resetFields, resetSchema, validate }] = useForm({ | 
|   labelWidth: 120, | 
|   baseColProps: { span: 24 }, | 
|   schemas: createFormSchema, | 
|   showActionButtonGroup: false, | 
|   actionColOptions: { span: 23 }, | 
| }) | 
|   | 
| const [registerModal, { setModalProps, closeModal }] = useModalInner(async (data) => { | 
|   resetFields() | 
|   setModalProps({ confirmLoading: false }) | 
|   isUpdate.value = !!data?.isUpdate | 
|   if (unref(isUpdate)) { | 
|     resetSchema(updateFormSchema) | 
|     const res = await get${simpleClassName}(data.record.id) | 
|     setFieldsValue({ ...res }) | 
|   } | 
| }) | 
|   | 
| async function handleSubmit() { | 
|   try { | 
|     const values = await validate() | 
|     setModalProps({ confirmLoading: true }) | 
|     if (unref(isUpdate)) | 
|       await update${simpleClassName}(values) | 
|     else | 
|       await create${simpleClassName}(values) | 
|   | 
|     closeModal() | 
|     emit('success') | 
|     createMessage.success(t('common.saveSuccessText')) | 
|   } finally { | 
|     setModalProps({ confirmLoading: false }) | 
|   } | 
| } | 
| </script> | 
| <template> | 
|   <BasicModal v-bind="$attrs" :title="isUpdate ? t('action.edit') : t('action.create')" @register="registerModal" @ok="handleSubmit"> | 
|     <BasicForm @register="registerForm" /> | 
|   </BasicModal> | 
| </template> |