interface.ts 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. /* eslint-disable one-var */
  2. /* eslint-disable react/prefer-stateless-function, max-len */
  3. import * as React from 'react';
  4. import { Subtract } from 'utility-types';
  5. import type { RuleItem } from 'async-validator';
  6. import { Options as scrollIntoViewOptions } from 'scroll-into-view-if-needed';
  7. import { BaseFormApi as FormApi, FormState, WithFieldOption } from '@douyinfe/semi-foundation/form/interface';
  8. import { SelectProps } from '../select/index';
  9. import Option from '../select/option';
  10. import OptGroup from '../select/optionGroup';
  11. import { CheckboxProps } from '../checkbox/index';
  12. import { RadioProps } from '../radio/index';
  13. import { ErrorMessageProps, ReactFieldError as FieldError } from './errorMessage';
  14. import { LabelProps } from './label';
  15. export { FormState, FormApi, WithFieldOption };
  16. export type CommonFieldProps = {
  17. /** Field is required (except Form. Checkbox within the Group, Form. Radio) */
  18. field: string;
  19. /** The label text of the form control is the same name as the field by default when it is not passed */
  20. label?: LabelProps | React.ReactNode;
  21. labelPosition?: 'top' | 'left' | 'inset';
  22. labelAlign?: 'left' | 'right';
  23. labelWidth?: number | string;
  24. noLabel?: boolean;
  25. noErrorMessage?: boolean;
  26. name?: string;
  27. fieldClassName?: string;
  28. fieldStyle?: React.CSSProperties;
  29. initValue?: any;
  30. validate?: (fieldValue: any, values: Record<string, any>) => string | Promise<string>;
  31. /** Check rules, check library based on async-validator */
  32. rules?: Array<RuleItem>;
  33. /** Check trigger timing */
  34. trigger?: 'blur' | 'change' | 'custom' | 'mount' | Array<string>;
  35. // onChange: (fieldValue: any) => void;
  36. /** Converts form control values before validation */
  37. transform?: (fieldValue: any) => any;
  38. /** Make a second change to the component's value before the UI update */
  39. convert?: (fieldValue: any) => any;
  40. allowEmptyString?: boolean;
  41. /** When true, use rules verification, after encountering the first rule that fails the test, the verification of subsequent rules will no longer be triggered */
  42. stopValidateWithError?: boolean;
  43. /* Custom prompt information is displayed in the same block as the verification information. When both have values, the verification information is displayed first */
  44. helpText?: React.ReactNode;
  45. /* Extra message, you can use this when you need an error message and the prompt text to appear at the same time, after helpText/errorMessage */
  46. extraText?: React.ReactNode;
  47. extraTextPosition?: 'middle' | 'bottom';
  48. /** These declaration just hack for Subtract, not valid props in CommonFieldProps */
  49. defaultValue?: any;
  50. /** Whether to take over only the data stream, when true, it will not automatically insert modules such as ErrorMessage, Label, extraText, etc. The style and DOM structure are consistent with the original component */
  51. pure?: boolean;
  52. };
  53. export type CommonexcludeType = {
  54. defaultValue?: any;
  55. value?: any;
  56. checked?: boolean;
  57. defaultChecked?: boolean;
  58. };
  59. export type RadioCheckboxExcludeProps = {
  60. defaultValue?: any;
  61. chekced?: boolean;
  62. defaultChecked?: boolean;
  63. field: string;
  64. };
  65. export type RCIncludeType = {
  66. // Need to take into account the use of Form. Checkbox, Form. Radio and Group scenarios
  67. field?: string;
  68. };
  69. export class FormSelect extends React.Component<Subtract<SelectProps & CommonFieldProps, CommonexcludeType>> {
  70. static Option: typeof Option;
  71. static OptGroup: typeof OptGroup;
  72. }
  73. export interface SelectStatic {
  74. Option: typeof Option;
  75. OptGroup: typeof OptGroup;
  76. }
  77. export class Field<P> extends React.Component<Subtract<P & CommonFieldProps, CommonexcludeType> & React.RefAttributes<any>> {}
  78. export let FormSelectType: React.ComponentType<Subtract<SelectProps & CommonFieldProps, CommonexcludeType>> & SelectStatic;
  79. export let FormCheckboxType: React.ComponentType<Subtract<CommonFieldProps, RadioCheckboxExcludeProps> & CheckboxProps & RCIncludeType>;
  80. export let FormRadioType: React.ComponentType<Subtract<CommonFieldProps, RadioCheckboxExcludeProps> & RadioProps & RCIncludeType>;
  81. export interface ErrorMsg {
  82. [optionalKey: string]: FieldError;
  83. }
  84. export interface FormFCChild<K extends Record<string, any> = any> {
  85. formState: FormState<K>;
  86. values: K;
  87. formApi: FormApi<K>;
  88. }
  89. interface setValuesConfig {
  90. isOverride: boolean;
  91. }
  92. export interface BaseFormProps extends Omit<React.FormHTMLAttributes<HTMLFormElement>, 'children' | 'onChange'> {
  93. 'aria-label'?: React.AriaAttributes['aria-label'];
  94. onSubmit?: (values: Record<string, any>) => void;
  95. onSubmitFail?: (errors: Record<string, FieldError>, values: any) => void;
  96. onReset?: () => void;
  97. onValueChange?: (values: Record<string, any>, changedValue: Record<string, any>) => void;
  98. onChange?: (formState: FormState) => void;
  99. validateFields?: (values: Record<string, any>) => string | Record<string, any>;
  100. /** Use this if you want to populate the form with initial values. */
  101. initValues?: Record<string, any>;
  102. id?: string;
  103. /** getFormApi will be call once when Form mounted, u can save formApi reference in your component */
  104. getFormApi?: (formApi: FormApi) => void;
  105. style?: React.CSSProperties;
  106. className?: string;
  107. layout?: 'horizontal' | 'vertical';
  108. labelPosition?: 'top' | 'left' | 'inset';
  109. labelWidth?: number | string;
  110. labelAlign?: 'left' | 'right';
  111. labelCol?: Record<string, any>;
  112. wrapperCol?: Record<string, any>;
  113. allowEmpty?: boolean;
  114. render?: (internalProps: FormFCChild) => React.ReactNode;
  115. component?: React.FC<any> | React.ComponentClass<any>;
  116. children?: React.ReactNode | ((internalProps: FormFCChild) => React.ReactNode);
  117. autoScrollToError?: boolean | scrollIntoViewOptions;
  118. disabled?: boolean;
  119. showValidateIcon?: boolean;
  120. extraTextPosition?: 'middle' | 'bottom';
  121. }