Skip to content

Latest commit

 

History

History
89 lines (73 loc) · 2.33 KB

README.md

File metadata and controls

89 lines (73 loc) · 2.33 KB

hookformx

Using Schema-Typed for data modeling ,Using React hook for Building material forms. support TextField、Date/Time、Seclects、Checkboxes、RadioGroup、Switches Material Component

Installation

npm install hookformx --save

Usage

import { SchemaModel, StringType, DateType, NumberType, useFormx } from 'hookformx';

const loginFormSchema = SchemaModel({
  account:StringType().isRequired('account required ').minLength(3, 'should not be less than 3'),
  pwd:StringType().isRequired('password required').maxLength(20, 'pwd do not need be greater than 20')
});

const checkResult = loginFormSchema.check({
  account: 'test',
  pwd: '12345678910111213141516'
});

console.log(checkResult);

checkResult return structure is:

{
    hasError: true,
    account: { hasError: false },
    pwd: { hasError: true, errorMessage: 'pwd do not need be greater than 20' }
}

Use form Hook for material

const login = () => {
  const { useInput, isValid,values,errors } = useFormx({
    account:'test',
    pwd:'test'
    }, loginFormSchema,() = {
      console.log(values);
      console.log(errors)
      });
  return (
    <TextField {...useInput('account','change')} />
    <TextField {...useInput('pwd','blur')} />
    <Button color="primary" variant="contained" disabled={isValid}>  login  </Button>
  )
}

the useFormx hook have three params:first initial value, the second param is schema type have define above,the third param is a callback function. the return useFormX is :

{
   values, //form values
   useInput,
   errors, //form current errors
   isValid,  //use for disable submitbutton
   handleSubmit //callback function when the form submit
 }

the return useInput is :

{
    value,          // field value
    required,       // required?
    defaultValue,   // default field value
    onFocus:        // default onFocus function
    error:          //fieldValues
    helperText:     //field errorMessage
    onBlur:         // default onBlur function
    onChange:       // default onChange function
  }

More About Verification

it add errors property hasError is very useful for disable the button