Handling Forms in React with Formik, Yup, Chakra UI
What is this blog about?
This blog is about handling forms in react, how to abstract the form functionalities into little pieces and make it, umm lets say modular?
What will we be doing here?
We are gonna look at basic form fields like the input field for Text and Email, Radio button, Drop Down fields
Steps
Step 1 : Project setup
create the basic structure of the react app using vite, select react and js as when prompted
npm create vite@latest
move into the folder you just created and install the dependencies
npm install
npm install formik yup
install chakra ui dependencies and configure your application to be styles with chakra ui
npm i @chakra-ui/react @emotion/react @emotion/styled framer-motion @chakra-ui/icons
now change the code in the main.jsx file so that your application has the styles specified by chakra ui and so as to use the utilities it provides
import React from "react";
import ReactDOM from "react-dom/client";
import App from "./App.jsx";
import "./index.css";
import { ChakraProvider } from "@chakra-ui/react";
ReactDOM.createRoot(document.getElementById("root")).render(
<React.StrictMode>
<ChakraProvider>
<App />
</ChakraProvider>
</React.StrictMode>
);
Step 2 : Creating components
Now lets create a components folder in the src folder of out project and also make sure to create fields folder in the components directory
these just to organize our files better
now the basic idea is that we create bare field components for each of the required field and build an intermediate called 'FormikControl' components which when rendered by passing the appropriate props we want for a specific field
the form fields error handling is taken care by chakra ui and formik combined and the handling of form values is taken care by formik itself
yup is used for schema validation
Later on, I'll be adding some complex fields like array field, and conditional selects to the repo and will be writing a post for those too, perhaps this time in a little detail
You can find the code here in this github repository
Here is the resource i used to learn these, credits to the creator