@nico2433/custom-components
v1.0.49
Published
Custom components package for personal FrontEnd projects
Downloads
51
Readme
Custom Components
This is a simple package I created for personal use. It contains some components that can be useful.
Add the package to your index file: To ensure that the package's styles integrate properly, add the package css to your index file:
import "@nico2433/custom-components/index.css";
Further customization with CSS: You can customize the components to some degree using css classes.
[!IMPORTANT] If you have @tailwindcss/forms in your tailwind plugins the default inputs styles probably will broke, so instead of importing the css in your index you will need to add the package route to your tailwind.config content.
Components
Inputs: DateInput FileInput FileDropInput SelectInput TextInput
To use these you will need react-hook-form.
UI: DocDelimiter (This component limits width of the page content).
How to use inputs
type InputType = "text" | "password" | "select" | "file" | "date";
interface SelectInputOptions {
label: string;
value: string;
}
interface InputConfig {
name: string;
type?: InputType;
label?: string;
placeholder?: string;
registerOptions?: RegisterOptions;
addBtn?: {
label: string,
className?: string,
onClick: (arg?: any) => any,
};
selectOptions?: SelectInputOptions[];
}
const useExampleFormConfig = () => {
const {
register,
handleSubmit,
formState: { errors },
} = useForm();
const fields: InputConfig[] = [
{
name: "example1",
registerOptions: {
required: "This field is required",
},
},
{
name: "example2",
registerOptions: {
maxLength: {
value: 10;
message: "This field accepts a max length of 10";
},
minLength: {
value: 5;
message: "This field field accepts a min length of 5";
},
}
}
];
return { fields, register, handleSubmit, errors }
};
const Component = () => {
const { fields, register, handleSubmit, errors } = useExampleFormConfig();
const onSubmit = (values: FieldValues) => {
console.log(values);
};
return (
<form onSubmit={handleSubmit(onSubmit)}>
<div>
{fields.map((field) => (
<TextInput
key={field.name}
config={field}
register={register}
errors={errors}
/>
))}
</div>
<button>Submit</button>
</form>;
)
};