![Oracle Drags Its Feet in the JavaScript Trademark Dispute](https://cdn.sanity.io/images/cgdhsj6q/production/919c3b22c24f93884c548d60cbb338e819ff2435-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Oracle Drags Its Feet in the JavaScript Trademark Dispute
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
@codegateinc/react-form-builder-v2
Advanced tools
React-form-builder-v2 is a library that allows you to create highly customizable forms by rendering your own components and storing the state. It works perfectly with ReactJS, React Native, and monorepo with React Native Web.
Create your own components and simply pass callbacks, errors, and values. You can store any type of value in the useField. It can be a string, boolean, number, array, or even an object.
yarn add @codegateinc/react-form-builder-v2
or npm install --save @codegateinc/react-form-builder-v2
type ValidationRule<T> = {
errorMessage: string,
validate(value: T): boolean
}
useField(config)
Property | Type | Description |
---|---|---|
key | string | Default: undefined .This field is required, must be a unique within whole form. |
label | string | Default: undefined .The label value that will be passed through the field. |
initialValue | generic (T) | Default: undefined .This field is required. This will define the initial value of the field. |
isRequired | boolean | Default: false .Defines if the field is required and should be mandatory. With validation rules it can be additionally validated. |
placeholder | string | Default: undefined .Placeholder value that will be passed via the field |
validateOnBlur | boolean | Default: false .Defines if the field should be validated when blurred. If false, validation will be checked on each change. |
validationRules | Array<ValidationRule<T> > | Default: undefined .Array of validation objects that will define if the field is valid |
liveParser | (value: T) => T | Default: undefined .Function that, if defined, will be invoked every time the value changes. |
submitParser | (value: T) => T | Default: undefined .Function that, if defined, will be invoked after the submit function is invoked. |
hasError | boolean | Default: false .This value indicates if the field has an error. |
validationRule: [
{
errorMessage: 'this field should be at least 2 chars',
validate: (value: string) => value.length >= 2
}
]
const statesAndFunctions = useForm(config, callbacks)
Property | Type | Description |
---|---|---|
form | Record<string, T> | Form with all values. |
hasError | boolean | Indicates if the form has an error. |
isFilled | boolean | Determines whether or not all fields have changed. |
formHasChanges | () => boolean | Returns a boolean indicating whether any fields have changed. |
setError | (key: string, errorMessage: string) => void | Sets an error to a field, even if the field is valid. After revalidation, this error disappears. It can be useful for server-side validation. |
setFieldValue | (key: string, value: T) => void | Sets the field value. |
setFieldInitialValue | (key: string, initialValue: string) => void | Sets a field's initial value. The value of the field will change if it is pristine. |
addFields | (fields: Array<Field<any>> ) => void | Adds new fields to the form. It allows users to create recurring forms or add new fields during runtime. |
removeFieldIds | (ids: Array<string> ) => void | Removes fields from the form at runtime. Deletes only fields that were added with the "addFields" function. Fields passed in by configuration cannot be removed. |
resetForm | () => void | Resets all fields and forms to their initial values and states. |
submit | () => void | Submits the form, validating all the fields that are required. |
validateAll | () => void | Validates all fields. |
Let's create our first component
import React from 'react'
import { ReactSmartScroller } from '@codegateinc/react-form-builder-v2'
const getConfig = () => {
const name = useField({
key: 'name',
initialValue: '',
isRequired: true,
placeholder: 'name'
})
const surname = useField({
key: 'surname',
initialValue: '',
isRequired: true,
placeholder: 'surname'
})
return {
name,
surname
}
}
export const FormBuilder: React.FunctionComponent = () => {
const { form, submit } = useForm(getConfig(), {
onSuccess: validForm => console.log(validForm)
})
return (
<Container>
<Input {...form.name}/>
<Input {...form.surname}/>
<Button onClick={submit}>
save
</Button>
</Container>
)
}
const Container = styled.div`
display: flex;
flex-direction: column;
padding: 100px;
align-items: center;
input {
margin-bottom: 20px;
}
`
const Button = styled.div`
background-color: green;
padding: 10px 15px;
color: white;
border-radius: 20px;
cursor: pointer;
`
Here is a sandbox with 3 simple types of different components to show how it works https://codesandbox.io/embed/fragrant-bush-4gpqkl?fontsize=14&hidenavigation=1&theme=dark
Below you can find some usage examples
<Button onClick={() => setError('input', 'custom error')}>
set error
</Button>
<Button onClick={() => setInitialValue('input', 'this is new initial value')}>
set initial value
</Button>
<Button onClick={() => setFieldvalue('input', 'this is new value')}>
set field value
</Button>
<Button
onClick={() => addFields([{
key: 'second input',
placeholder: 'second input'
}])}
>
add field
</Button>
<Button
onClick={() => addFields([{
key: 'second input',
placeholder: 'second input'
}])}
>
add field
</Button>
<Button
onClick={() => removeFieldIds(['second input'])}
>
remove field
</Button>
Library created by Jacek Pudysz and Grzegorz Tarnopolski
FAQs
Unknown package
The npm package @codegateinc/react-form-builder-v2 receives a total of 64 weekly downloads. As such, @codegateinc/react-form-builder-v2 popularity was classified as not popular.
We found that @codegateinc/react-form-builder-v2 demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.