@che-ins-ui/form
TypeScript icon, indicating that this package has built-in type declarations

3.2.62 • Public • Published

Form Component

Компоненты

  • Form
  • FormField

Для работы необходимо добавить reducer

{ [FORMS_STATE_NAMESPACE]: formsReducer }

Form принимает formName, и в redux работает с объектом

<Form formName={BASE_FORM_NAME}>
    {form}
</Form>

В большинстве случаев для использования компонентов ввода необходимо использовать HOC

Пропсы component и field обязательны, все остальные передаются к компоненту который передали

  • component - компонент
  • field - путь до изменяемого поля в модели

Компонент всегда должен первым аргументом в функцию onChange передавать новое значение

<FormField
  component={Input}
  field={'firstname'}
  placeholder="Ivan"
  label="Firstname"
/>

field во всех actons и selectors - пусть в строковом представлении до поля через точку,

prop.prop1.prop2[arrayIndex][arrayIndex2].prop3 = 'some value'

Ошибки показываются только полей на которых что либо вводили, т.н. toched, для того что бы избежать показа ошибок незаполненных полей на всей форме когда её только начали заполнять

Для переопределения этого поведения для конкретного поля необходимо сделать это поле touched в необходимый момент

dispatch(
  formActions.setFieldTouched({
    formName: formName,
    field: fieldName,
    isTouched: true,
  })
)

Для показа всех ошибок на форме существует флаг isShowAllErrors. Его простановка необходима вручную.

dispatch(
  formActions.setIsShowAllErrors({
    formName: formName,
    isShow: true,
  })
)

Основной кейс использования - перед отправкой на сервер включить показ всех ошибок на форме setIsShowAllErrors и отвалидировать её, показав все ошибки

Readme

Keywords

none

Package Sidebar

Install

npm i @che-ins-ui/form

Weekly Downloads

62

Version

3.2.62

License

MIT

Unpacked Size

215 kB

Total Files

31

Last publish

Collaborators

  • che-svc