Here is a React Project that you should build in the journey of becoming a PRO. This project is an Exercise Planner Application that is built using React.js, React Router and Hooks.
The features of the application that we will be building in this course are:
- Fetching the list of exercises from a local JSON Server
- Create a New Exercise
- Update an already existing exercise
- Delete an existing exercise
- Toggling the completion status of an exercise and showing it in visually.
- Creating a filter component to filter the exercises based on the completion status - pending, all, completed. and more.
β± Timestamps β±
π let's start (0:00)
π demo of our exercise tracker project (0:20)
π a quick glance over the starter files (1:37)
π setting up our starter project and installation (2:00)
π whiteboard : deciding about the components for our project (2:15)
π starting the project (7:20)
π installation of json-server package & running it (7:36)
π creating our first page component - homepage (9:05)
π bringing our first hook into action - useState (9:23)
π fetching data from our data source using another hook - useEffect (10:25)
π installation and setting up react-router (13:50)
π defining our first route : home page route(14:57)
π seeing our fetched exercises in react-dev-tools extension (17:16)
π starting with exercise list component (18:00)
π passing our fetched exercises to the exercises list component as a prop (21:10)
π creating an exercise item component (22:16)
π using the exercise item in exercises list and passing exercise as a prop (25:15)
π starting with delete exercise functionality (28:28)
π whiteboard: understanding the process for deletion of item (29:35)
π defining our delete exercise handler in home page component (32:16)
π passing a pointer to our delete exercise handler as a prop to exercises list component (33:29)
π forwarding the pointer to delete exercise handler as a prop further down to exercise item component (33:29)
π ensuring the deletion of item gets reflected in our local JSON store (35:20)
π starting with toggling the exercise completion status functionality (37:10)
π defining our toggle exercise completion handler in home page component (38:29)
π forwarding a pointer to our toggle exercise handler as a prop to exercises list component (41:45)
π forwarding the pointer to our toggle exercise handler further down to our exercise item component (42:57)
π invoking our toggle exercise completion handler via the on toggle exercise prop (43:08)
π ensuring the toggling of the completion status gets reflected in our local JSON store (45:34)
π laying out our create exercise form (49:44)
π handling form submission for creating a new exercise (58:07)
π using the useHistory hook to push the user back to home page on exercise creation (1:02:50)
π creating the navbar component (1:04:37)
π starting with edit exercise component (1:07:50)
π creating a route for the edit exercise component using dynamic segment (1:09:20)
π adding a router link for editing an exercise for an exercise item (1:09:53)
π extracting the id of an exercise from the router params using the useParams hook (1:11:30)
π using the id that we get from router params to load the exercise in our edit exercise component (1:13:19)
π handling form submission for updating the populated exercise (1:16:41)
π filtering the exercises based on their completion status (1:20:57)
π creating our base filter component (1:21:40)
π setting up a current filter state in our home page component (1:25:20)
π creating an update exercise handler in our home page component (1:25:55)
π passing a pointer to our update exercise handler down to base filter (1:26:56)
π passing the current filter down to base filter (1:27:42)
π using the current filter prop in base filter component to give extra styles to our navlinks (1:28:26)
π using the filter to show exercises based on their completion status on home page (1:29:32)
π end of the project (1:31:20)
ππ Starter Files:
https://github.com/The-Nerdy-Dev/Starter-Files-React-Exercise-Tracker-Project
ππ Component Styles:
https://github.com/The-Nerdy-Dev/CSS-Files-For-React-Exercise-Tracker-Project
Support my channel:
π Join the Discord community π¨βπ©βπ§βπ¦: https://discord.gg/fgbtN2a
π One time donations via PayPal
Thank you! π
Follow me on:
π My Blog: https://the-nerdy-dev.com
π Twitter: https://twitter.com/The_Nerdy_Dev
π Instagram: https://instagram.com/thenerdydev
Top comments (0)