In this video, we will make a full Exercise Tracker Application using React.js and React Router. The features of the application that we will be building in this course are:
β± 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
ππ Course Links:
Complete Code - https://github.com/The-Nerdy-Dev
Visual Studio Code - https://code.visualstudio.com
Git - https://git-scm.com/downloads
#react #javascript #web-development