Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/guilouro/formcat

A simple and easy way to control forms in React using the React Context API
https://github.com/guilouro/formcat

context context-api form react react-hooks

Last synced: 3 months ago
JSON representation

A simple and easy way to control forms in React using the React Context API

Awesome Lists containing this project

README

        

A simple and easy way to control forms in React using the [React Context API](https://reactjs.org/docs/context.html)

![CI](https://github.com/guilouro/formcat/workflows/CI/badge.svg)
[![codecov.io](https://codecov.io/gh/guilouro/formcat/branch/master/graph/badge.svg)](https://codecov.io/gh/guilouro/formcat)
[![styled with prettier](https://img.shields.io/badge/styled_with-prettier-ff69b4.svg)](https://github.com/prettier/prettier)

## Getting Started

## Install

With npm

```
npm install --save formcat
```

With yarn

```
yarn add formcat
```

## How to use

First of all, we need to create a Field using the [HOC](https://facebook.github.io/react/docs/higher-order-components.html) `withContextForm` as the example below:

```js
/* InputField.js */

import { withContextForm } from 'formcat'

const InputField = ({ error, ...input }) => (

)

export default withContextForm(InputField)
```

Now we can use this component inside the Form:

```js
import { Form } from 'formcat'
import InputField from './InputField'

function Main () {
return (



)
}
```

# API

### Form

| Props | Type | Default value | Description |
| ----- | ---- | ------------- | ----------- |
| **keyUpValidation** | Boolean | `false` | When `true` the validations Field works with `keyUp` |
| **clearAfterSubmit** | Boolean | `false` | When `true` the form will be reset after submit |
| **onFormChange** | Function | `undefined` | A callback that returns an object with `name`, `type` and `value`
of the current change. |
| **onSubmit** | Function | `undefined` | A callback that returns an object with status and values. |

### Submit

For an easy `submit` process we can use the HOC `withSubmit` and create a Button that will be controlled by Form, or using the Submit component that already exists.

```js
// Creating
import { withSubmit } from 'formcat'

const Submit = withSubmit(props => )

//or

import { Submit } from 'formcat'

// Using

...
render (

...
Button Text

)
...
```

*Obs: This `button` will be enabled when Form is valid and disabled when is not valid*

### Custom Field

It's a field created with `withContextForm`.

| Props | Type | Default value | Description |
| ----- | ---- | ------------- | ----------- |
| **error** | Boolean | `false` | A flag that controls the field validation |
| **validations** | Array | `[]` | A list with functions validation |
| **required** | Boolean | `false` | Set required validation for this field |
| **defaultValue** | String | `""` | Set initial text value |
| **defaultChecked** | String | `""` | Set initial checked for field |

## Using validations

We can use many validations per field using the props `validations`. All we need to do is create a pure function that returns `true` or `false` following the example below:

```js
import { Form, withFormContext } from 'formcat'

const Field = withFormContext(({ error, ...input }) => (

))

const Main = () => {

// Validate if username is @guilouro
const usernameValidation = value => (
value === '@guilouro'
)

return (



)
}
```

A validation function has two params `value` and `state`:

```js
function validationName (value, state) {}
```

| Param | Type | Description |
| ----- | ---- | ------------- |
| **value** | String | Current field value |
| **state** | Object | An object with all fields value |

### Set values

We can set values out of Form using `Ref` and `updateFieldValue` as the example below:

| Param | Type | Description |
| ----- | ---- | ------------- |
| **name** | String | `null` | Field name |
| **text** | String | A new value for this field |

```js
import { Form, withFormContext } from 'formcat'

const Field = withFormContext(({ error, ...input }) => {}(

))

const Main = () => {
const form = useRef(null)

const setValue = () => {
form.current.updateFieldValue('username', '@guilouro')
}

return (
<>



Set @guilouro as value

>
)
}

```

## Fields we can use

There are some simple field created with `withContexForm` we can use in project or use as a reference for create a new custon field

### InputField

A simple `input` field

```js
import { InputField } from 'formcat/fields'

...

...
```

| Param | Type | Default value | Description |
| ----- | ---- | ------------- | --------------|
| **name** | String | `null` | Field name |
| **label** | String | `''` | A label for this field |
| **type** | String | `text` | A type for this input |

*Obs: And all common props*

### CheckboxField

A `input` `checkbox` field

```js
import { CheckboxField } from 'formcat/fields'

...

...
```

| Param | Type | Default value | Description |
| ----- | ---- | ------------- | --------------|
| **name** | String | `null` | Field name |
| **label** | String | `''` | A label for this field |
| **defaultChecked** | Boolean | `false` | A flag to define the initial status |

*Obs: And all common props*

### RadiosField

A simple `input` `radio` field

```js
import { RadiosField } from 'formcat/fields'

...

...
```

| Param | Type | Default value | Description |
| ----- | ---- | ------------- | --------------|
| **name** | String | `null` | Field name |
| **label** | String | `''` | A label for this field |
| **options** | Array | `[]` | A list of objects with `label`, `value` and `checked` |

*Obs: And all common props*

### SelectField

A simple `select` field

```js
import { SelectField } from 'formcat/fields'

...

...
```

| Param | Type | Default value | Description |
| ----- | ---- | ------------- | --------------|
| **name** | String | `null` | Field name |
| **label** | String | `''` | A label for this field |
| **options** | Array | `[]` | A list of objects with `label` and `value` |

*Obs: And all common props*

### TextField

A simple `textarea` field

```js
import { TextareaField } from 'formcat/fields'

...

...
```

| Param | Type | Default value | Description |
| ----- | ---- | ------------- | --------------|
| **name** | String | `null` | Field name |
| **label** | String | `''` | A label for this field |

*Obs: And all common props*

### Error styles

Invalid fields will receive a class: `className="formcat-error"`

## Examples

### Full form

A example with all fields, validation and a populate button

[![Edit Formcat](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/93465kmow?fontsize=14)

### Creating a custom fields

A example of the how create a custom field

[![Edit Creating custom fields](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/3rpxomlm15?fontsize=14)

---

## Contributing

If you want to contribute with this component:
[Contributing Documentation](https://github.com/guilouro/formcat/blob/master/.github/CONTRIBUTING.md).