Skip to content

Latest commit

 

History

History
107 lines (88 loc) · 3.97 KB

readme.md

File metadata and controls

107 lines (88 loc) · 3.97 KB

React easy forms

To do

High Priority

  • Complete unit testing
  • Update support for Custom Controllers

Low Priority

  • Add default values for undefined default values for all input types (button, color, date, datetime-local, email, file, hidden, image, month, password, reset, search, submit, tel, time, url, week)

  • Add form inputMapper and outputMapper?

  • Add option to evaluate fields that were removed from the DOM (if they are not explicitly unregistered). How should getValues() handle this?

  • Add error handling (generic function to catch thrown errors)

  • Fix ref type of CustomFieldController

  • Cleanup git repository

Done

  • Include field validators in general form validation function.
  • - Transform all validation functions to accept asynchronous validators
  • Complete handleSubmit and executeSubmit functions. Maybe move handleSubmit to registerForm()?
  • Add validator support onsubmit, onchange and onblur
  • Make decision on how data should be handled (always nested keys or 1 level deep object) - see prop flattenObject on useGetValues.
    • Decision above for field values and field errors
  • Add support to custom controllers
  • Create isTouched() method.
  • Add support for touched functionality.
  • Change getValue and getValues to retrieve values from _formState instead of the DOM. (Need to make sure that _formState is always up to date)
  • Add never dirty.
  • Create resetField(), resetForm(), syncDefaultValues() methods.
  • Add debug tools for setValue() (to know from where it was called, if necessary)
  • Add debug tools for isDirty() (console log all dirty fields)

How to use (TO DO)

Available hooks

  • useForm(formName: string)
  • useFormContext()
  • useWatch()
  • useWatchValue()
  • useWatchError()
  • useWatchTouched()

useForm(formName: string)

This is used to register a new form. The reference for the returned form always remains the same , so it is safe to pass as a prop or hook dependency, for example.

Methods (WIP)

  • register(name: string, options?: RegisterFieldOptions) - Registers a new field. Options properties below:
    • defaultOption?: string - used only to define the default value for <select /> inputs.
  • registerForm() - Registers the form.
  • getValue(fieldName: string) - Returns the value from a single field
  • getValues(fieldPath?: string) - Returns the values for the the specified path (using dot notation). If no fieldPath is specified, the whole form is returned.
  • isDirty(fieldName?: string) - Returns true/false if the form contains values different from the initially set on defaultValue prop.
  • setValue(fieldName: string, value: FieldValue) - Sets the value for a field.
  • clearValue: ClearValue;
  • setError: SetFieldError;
  • clearErrors: ClearFieldsErrors;
  • getError: GetFieldError;
  • executeSubmit: ExecuteSubmit;
  • isDirty: IsDirty;
  • syncDefaultValues: SyncDefaultValues;
  • isTouched: IsTouched;
  • getDefaultValue: GetDefaultValue;
  • getExternalUpdatedValues: GetExternalUpdatedValues;
  • syncDOMValues: SyncDOMValues;
  • updateFormOptions: UpdateFormOptions;
  • validate: ValidateForm;
  • resetForm: ResetForm;