Ben Lin
2024-06-18 9dfa701454d6a94690bad39dbb0e38f2a0b31489
src/components/Form/src/hooks/useForm.ts
@@ -1,10 +1,15 @@
import type { FormProps, FormActionType, UseFormReturnType, FormSchema } from '../types/form';
import type {
  FormProps,
  FormActionType,
  UseFormReturnType,
  FormSchemaInner as FormSchema,
} from '../types/form';
import type { NamePath } from 'ant-design-vue/lib/form/interface';
import type { DynamicProps } from '/#/utils';
import type { DynamicProps } from '#/utils';
import { ref, onUnmounted, unref, nextTick, watch } from 'vue';
import { isProdMode } from '/@/utils/env';
import { error } from '/@/utils/log';
import { getDynamicProps } from '/@/utils';
import { isProdMode } from '@/utils/env';
import { error } from '@/utils/log';
import { getDynamicProps } from '@/utils';
export declare type ValidateFields = (nameList?: NamePath[]) => Promise<Recordable>;
@@ -73,9 +78,13 @@
      form.clearValidate(name);
    },
    resetFields: async () => {
      getForm().then(async (form) => {
        await form.resetFields();
    resetFields: () => {
      // 修复表单重置后,页面变化了,但是由于异步问题导致表单内部的状态没有及时同步
      return new Promise((resolve) => {
        getForm().then(async (form) => {
          await form.resetFields();
          resolve();
        });
      });
    },
@@ -88,15 +97,15 @@
      return unref(formRef)?.getFieldsValue() as T;
    },
    setFieldsValue: async <T>(values: T) => {
    setFieldsValue: async <T extends Recordable<any>>(values: T) => {
      const form = await getForm();
      form.setFieldsValue<T>(values);
      form.setFieldsValue(values);
    },
    appendSchemaByField: async (
      schema: FormSchema | FormSchema[],
      prefixField: string | undefined,
      first: boolean,
      first?: boolean,
    ) => {
      const form = await getForm();
      form.appendSchemaByField(schema, prefixField, first);
@@ -107,7 +116,7 @@
      return form.submit();
    },
    validate: async (nameList?: NamePath[]): Promise<Recordable> => {
    validate: async <T = Recordable>(nameList?: NamePath[] | false): Promise<T> => {
      const form = await getForm();
      return form.validate(nameList);
    },
@@ -116,6 +125,9 @@
      const form = await getForm();
      return form.validateFields(nameList);
    },
    resetDefaultField: async (nameList?: NamePath[]) => {
      unref(formRef)?.resetDefaultField(nameList);
    },
  };
  return [register, methods];