native-form
v2.1.4
Published
This is a React Native component library for creating forms with various input fields such as text input, number input, password input, checkbox, and radio button. It provides a convenient way to manage form state, validation, and submission.
Downloads
46
Maintainers
Readme
Native Form
This is a React Native package that provides a simple and customizable form component with various field types such as text, textbox, number, password, checkbox, and radio buttons. It supports features like validation, error handling, and custom styling. It also provides a set of utility functions for validating form input values in JavaScript or TypeScript.
Table of Contents
- Installation
- Usage
- Form Options
- Field Options
- Field Select
- Validation Utility Functions
- Contributing
- License
Installation
You can install the package using npm or yarn:
npm install native-form
or
yarn add native-form
Usage
Import the necessary components and use them in your React Native app:
import { ReactNativeForm, Field, FieldRadioGroup, FieldCheckboxGroup } from 'native-form';
const MyForm = () => {
const handleSubmit = (values) => {
console.log('Form values:', values);
};
const radioOptions = [
{ label: 'Option 1', value: 'option1' },
{ label: 'Option 2', value: 'option2' },
{ label: 'Option 3', value: 'option3' },
];
const checkboxOptions=[
{value: 1, label: 'one checkbox'},
{value: 2, label: 'two checkbox'},
{value: 3, label: 'three checkbox'},
{value: 4, label: 'four checkbox'},
]
return (
<ReactNativeForm onSubmit={handleSubmit} onRender={({ onSubmit }) => (
<>
<Field
name="username"
type="text"
label="Username"
placeholder="Enter your username"
/>
<Field
name="password"
type="password"
label="Password"
placeholder="Enter your password"
enableTogglePasswordOption={true}
togglePasswordType="classic"
fillOnCheck={true}
/>
<Field
name="gender"
type="radio"
label="Male"
value="male"
/>
<Field
name="gender"
type="radio"
label="Female"
value="female"
/>
<FieldRadioGroup
name="radio"
options={radioOptions}
renderChildrenAs="row"
/>
<FieldCheckboxGroup
name="checkbox"
options={checkboxOptions}
fillOnCheck={true}
/>
<Field
name="interests"
type="checkbox"
label="Reading"
value="reading"
/>
<Field
name="interests"
type="checkbox"
label="Coding"
value="coding"
/>
<Button onPress={onSubmit} title="Submit" />
</>
)} />
);
};
In this example, we create a form with various field types, including text, password, radio buttons, and checkboxes. The ReactNativeForm
component provides the form context and handles state management, while the Field
component renders the individual fields based on the provided props.
When the form is submitted, the handleSubmit
function will be called with the form values as an argument.
Form Options
The ReactNativeForm
component accepts the following props:
| Prop | Type | Description |
| --- | --- | --- |
| initialValues
| Record<string, unknown>
| Optional. The initial values for the form fields. |
| formStyle
| Record<string, unknown>
| Optional. Additional styles for the form container. |
| submitting
| boolean
| Optional. Whether the form is currently submitting. |
| onSubmit
| (value: Record<string, unknown>) => void
| Required. A callback function that is called when the form is submitted. |
| onRender
| (arg: { invalid: boolean, submitting: boolean, active: string \| undefined, values: Record<string, unknown>, initialValues: Record<string, unknown>, touched: Record<string, boolean>, errors: Record<string, unknown>, changeFormValues: (name: string, type: string, value: string \| undefined) => void, onSubmit: (event: GestureResponderEvent) => void }) => React.JSX.Element, submitError?: Record<string, any> \| null,extra: Record<string, any>,prinstine: boolean
| Required. A render prop that receives form state and helper functions as arguments and returns the form content. The prinstine
is a boolean value that indicates whether the form values have been changed or not since the initial render. It is initialized as false
and is set to true
whenever the form values are changed and again set to false
after form submit.|
| submitError
| Record<string, any> \| null
|(optional): An object containing any submission errors.|
| extra
| Record<string, any>
|(optional): An object to pass additional data to the onRender function.
Field Options
Text Fields
| Prop | Type | Description |
| --- | --- | --- |
| name
| string
| Required. The unique identifier for the field. |
| type
| 'text'
, 'textBox'
, 'number'
, 'password'
,'email'
| Required. The type of the text field. |
| label
| string
| Optional. The label to be displayed for the field. |
| placeholder
| string
| Optional. The placeholder text for the field. |
| mainContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the main container view. |
| contentContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the content container view. |
| textStyle
| Record<string, unknown>
| Optional. Additional styles for the text input. |
| labelStyle
| Record<string, unknown>
| Optional. Additional styles for the label. |
| shouldUseScaleAnimation
| boolean
| Optional. Default: true
. Whether to use a scale animation for the label when focused. |
| disabled
| boolean
| Optional. Default: false
. Whether the field should be disabled. |
|enableTogglePasswordOption
| boolean
| Optional. Default false
. A boolean indicating whether to show a toggle password option for password fields.|
|togglePasswordType
| string
| Optional. A string representing the type of toggle password option (classic
or modern
).|
| fillOnCheck
| boolean
| Optional. A boolean indicating whether to fill the checkbox on check. Applicable only when togglePasswordType
= classic
.
| formatValue
| <T>(value: T) => T
| Optional. A function to format the value before setting it. |
| onChange
| (name: string, value: string \| undefined) => void
| Optional. A callback function that is called when the value changes. |
| onFocus
| (name: string) => void
| Optional. A callback function that is called when the field gets focused. |
| onBlur
| (name: string) => void
| Optional. A callback function that is called when the field loses focus. |
| validate
| (value: string \| undefined) => string \| undefined
| Optional. A function to validate the field value and return an error message if invalid. |
Radio Fields
| Prop | Type | Description |
| --- | --- | --- |
| name
| string
| Required. The unique identifier for the field. |
| type
| 'radio'
| Required. The type of the field. |
| label
| string
| Required. The label to be displayed for the radio option. |
| value
| string
| number
| Required. The value of the radio option. |
| required
| boolean
| Optional. Whether the field is required. |
| iconFillColor
| string
| Optional. The color to be used for the radio icon. |
| fillOnCheck
| boolean
| Optional. Whether to fill the radio icon when checked. |
| mainContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the main container view. |
| contentContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the content container view. |
| labelStyle
| Record<string, unknown>
| Optional. Additional styles for the label. |
| radioStyle
| Record<string, unknown>
| Optional. Additional styles for the radio icon. |
| onSelect
| (name: string, value: string \| number) => void
| Optional. A callback function that is called when a radio option is selected. |
| renderItem
| (props: { isChecked: boolean, label: string, value: string \| number }) => JSX.Element
| Optional. A render prop to customize the rendering of the radio option. |
Checkbox Fields
| Prop | Type | Description |
| --- | --- | --- |
| name
| string
| Required. The unique identifier for the field. |
| type
| 'checkbox'
| Required. The type of the field. |
| label
| string
| Required. The label to be displayed for the checkbox option. |
| value
| string
| number
| Required. The value of the checkbox option. |
| required
| boolean
| Optional. Whether the field is required. |
| fillOnCheck
| boolean
| Optional. Whether to fill the checkbox icon when checked. |
| iconFillColor
| string
| Optional. The color to be used for the checkbox icon. |
| mainContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the main container view. |
| contentContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the content container view. |
| labelStyle
| Record<string, unknown>
| Optional. Additional styles for the label. |
| checkboxStyle
| Record<string, unknown>
| Optional. Additional styles for the checkbox icon. |
| onSelect
| (name: string, value: string \| number) => void
| Optional. A callback function that is called when a checkbox |
renderItem
| (props: { isChecked: boolean, label: string, value: string \| number }) => JSX.Element
| Optional. A render prop to customize the rendering of the checkbox option. |
Field Radio Group
| Prop | Type | Description |
| --- | --- | --- |
| name
| String
| A string representing the name of the field group. |
| options
| Array
| An array of objects representing the radio button options. Each object should have a label
and a value
property. |
| renderChildrenAs
| String
| Optional. Default 'column'
. A string that determines the layout of the radio buttons. It can be either 'row'
or 'column'
. |
| required
| boolean
| Optional. Whether the field group is required. |
| iconFillColor
| string
| Optional. The color to be used for the radio icon. |
| fillOnCheck
| boolean
| Optional. Whether to fill the radio icon when checked. |
| mainContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the main container view. |
| contentContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the content container view. |
| labelStyle
| Record<string, unknown>
| Optional. Additional styles for the label. |
| radioStyle
| Record<string, unknown>
| Optional. Additional styles for the radio icon. |
| onSelect
| (name: string, value: string \| number) => void
| Optional. A callback function that is called when a radio option is selected. |
| renderItem
| (props: { isChecked: boolean, label: string, value: string \| number }) => JSX.Element
| Optional. A render prop to customize the rendering of the radio option. |
Field Checkbox Group
| Prop | Type | Description |
| --- | --- | --- |
| name
| String
| A string representing the name of the field group. |
| options
| Array
| An array of objects representing the checkbox options. Each object should have a label
and a value
property. |
| renderChildrenAs
| String
| Optional. Default 'column'
. A string that determines the layout of the checkbox. It can be either 'row'
or 'column'
. |
| required
| boolean
| Optional. Whether the field group is required. |
| iconFillColor
| string
| Optional. The color to be used for the checkbox icon. |
| fillOnCheck
| boolean
| Optional. Whether to fill the checkbox icon when checked. |
| mainContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the main container view. |
| contentContainerStyle
| Record<string, unknown>
| Optional. Additional styles for the content container view. |
| labelStyle
| Record<string, unknown>
| Optional. Additional styles for the label. |
| checkboxStyle
| Record<string, unknown>
| Optional. Additional styles for the checkbox icon. |
| onSelect
| (name: string, value: string \| number) => void
| Optional. A callback function that is called when a checkbox option is selected. |
| renderItem
| (props: { isChecked: boolean, label: string, value: string \| number }) => JSX.Element
| Optional. A render prop to customize the rendering of the checkbox option. |
Field Select
The FieldSelect
component is a reusable React Native component that provides a dropdown-like input field for single or multi-select options. It supports various customization options and includes animations for a smooth user experience.
Features
- Single and multi-select options
- Label or placeholder support
- Customizable styles for various elements
- Animations for smooth transitions
- Option to close the modal or show a confirm button after selection
- Optional custom rendering for items and selected values
Usage
Here's an example of how to use the FieldSelect
component:
import React from 'react';
import { View } from 'react-native';
import {FieldSelect} from 'native-form';
const options = [
{ value: 1, label: 'Option 1' },
{ value: 2, label: 'Option 2' },
{ value: 3, label: 'Option 3' },
];
const MyComponent = () => {
return (
<View>
<FieldSelect
name="myField"
label="Select an option"
options={options}
multiple={false} // Set to true for multi-select
closeOnSelect={false} // Close the modal after selection
confirmButtonText="Done" // Text for the confirm button
/>
</View>
);
};
export default MyComponent;
Props
The FieldSelect
component accepts the following props:
| Prop | Type | Description |
| ---------------------- | ------------------------------------------------------------------------ | ------------------------------------------------------------------------------ |
| name
| string
| Required. The name of the field. |
| label
| string
| The label text for the input field. |
| placeholder
| string
| The placeholder text for the input field. |
| multiple
| boolean
| Whether to allow multi-select or not. Default is false
. |
| options
| SingleItemType[]
| Required. The array of options to display. |
| mainContainerStyle
| Record<string, unknown>
| Custom styles for the main container. |
| itemContentStyle
| Record<string, unknown>
| Custom styles for the individual item containers. |
| itemsContainerStyle
| Record<string, unknown>
| Custom styles for the items container in the modal. |
| closeOnSelect
| boolean
| Whether to close the modal after selection or not. Default is false
. |
| confirmButtonText
| string
| The text for the confirm button in the modal. Default is 'Confirm'
. |
| confirmButtonStyle
| Record<string, unknown>
| Custom styles for the confirm button. |
| confirmButtonTextStyle
| Record<string, unknown>
| Custom styles for the confirm button text. |
| required
| boolean
| Whether the field is required or not. |
| renderItem
| (props: {isSelected: boolean, label: string, value: string \| number}) => React.JSX.Element
| Custom render function for the individual items. |
| renderValue
| (values: {value: string \| number, label: string}[] \| {value: string \| number, label: string}) => React.JSX.Element
| Custom render function for the selected values. |
| onSelect
| (item: itemType) => void
| Callback function when an option is selected. |
Validation Utility Functions
required
Checks if a value is provided. Returns an error message if the value is undefined
or null
, otherwise returns undefined
.
Usage:
const validator = required("This field is required");
const error = validator(value); // Returns an error message or undefined
minLength
Checks if a string value meets a minimum length requirement. Returns an error message if the length is less than the specified minimum, otherwise returns undefined
.
Usage:
const validator = minLength("Must be at least 5 characters long", 5);
const error = validator(value); // Returns an error message or undefined
maxLength
Checks if a string value meets a maximum length requirement. Returns an error message if the length exceeds the specified maximum, otherwise returns undefined
.
Usage:
const validator = maxLength("Must be at most 10 characters long", 10);
const error = validator(value); // Returns an error message or undefined
emailFormatValid
Checks if a string value is a valid email address format using a regular expression. Returns an error message if the format is invalid, otherwise returns undefined
.
Usage:
const validator = emailFormatValid("Invalid email address");
const error = validator(value); // Returns an error message or undefined
compareTwoValues
compare value against a reference value. It provides a flexible and configurable way to perform value comparisons with different options and behaviors.Returns an error message if the two values are not equal, otherwise returns undefined
.You can also configure such that it returns error messages if values are equal.
Usage:
// If require to configure different options
const extraOptions={ showMessageOnEqual?: boolean;compareOnlyIfRefValueExist?: boolean;}
const validator = compareTwoValues("Values not Equal",10,extraOptions);
const error = validator(value);
// Returns an error message or undefined
composeValidators
Composes multiple validators into a single validator function. It runs each validator in sequence until an error is encountered, returning the first error message, or undefined
if all validators pass.
Usage:
const validator = composeValidators(
required("This field is required"),
minLength("Must be at least 5 characters long", 5),
maxLength("Must be at most 10 characters long", 10)
);
const error = validator(value); // Returns an error message or undefined
Contributing
Contributions are welcome! If you find any issues or want to add new features, feel free to open an issue or submit a pull request.
License
This project is licensed under the MIT License.