<template> <BasicModal @register="registerModal" :title="title" width="40%" v-bind="$attrs" @ok="handleSubmit" > <div class="content"> <BasicForm @register="registerForm"/> </div> </BasicModal> </template> <script lang="ts" setup> import {computed, ref, unref} from 'vue'; import {BasicModal, useModalInner} from '/@/components/Modal'; import {BasicForm, useForm} from '/@/components/Form/index'; import {formSchema} from '../SysTableWhiteList.data'; import {saveOrUpdate} from '../SysTableWhiteList.api'; // Emits声明 const emit = defineEmits(['register', 'success']); const isUpdate = ref(true); //表单配置 const [registerForm, { resetFields, setFieldsValue, validate, setProps }] = useForm({ labelWidth: 120, wrapperCol: null, schemas: formSchema, showActionButtonGroup: false, }); //表单赋值 const [registerModal, {setModalProps, closeModal}] = useModalInner(async (data) => { //重置表单 await resetFields(); setModalProps({ confirmLoading: false, showCancelBtn: data?.showFooter, showOkBtn: data?.showFooter }); isUpdate.value = !!data?.isUpdate; if (unref(isUpdate)) { //表单赋值 await setFieldsValue({ ...data.record, }); } setProps({ disabled: !data?.showFooter }) }); //设置标题 const title = computed(() => (!unref(isUpdate) ? '新增' : '编辑')); //表单提交事件 async function handleSubmit(v) { try { let values = await validate(); setModalProps({confirmLoading: true}); //提交表单 await saveOrUpdate(values, isUpdate.value); //关闭弹窗 closeModal(); //刷新列表 emit('success', {isUpdate: isUpdate.value, values}); } finally { setModalProps({confirmLoading: false}); } } </script> <style lang="less" scoped> .content { padding: 20px 8% 0 4%; } </style>