
Explore tailwind setup, flexbox concepts, and component organization in a React app. Learn prop drilling, useState, useEffect, and Framer Motion for animation, with prep for CRUD in React.
Master the delete operation in a react redux app by wiring a delete button on each event card, filtering the events by id in the dashboard, and preserving immutable state.
Implement CRUD operations with React using uncontrolled forms, explore prop drilling, and introduce Redux to manage global state for easier data access.
Create a reusable login form with Zod validation and react-hook-form, integrate sign-in with Redux, set up the login route and navbar link, and prepare toast notifications for feedback.
Learn to integrate Firebase and Firestore, plug into your back end, and perform create, read, update, delete operations, while configuring a web app and starting in test mode.
Seed Firestore with sample data using the Firebase Admin SDK by configuring a service account, generating a private key, and initializing the app to manage Firestore and user authentication.
Update the account slice to map Firebase auth user data into an app user, resolve type issues, dispatch sign in, and enable login persistence for a seamless redux-driven experience.
* Re-mastered, re-imagined and re-recorded in full as at April 2025*
This course has been completely rewritten and re-recorded from scratch using the tools and techniques available to us to build an application as at April 2025.
Do you want to learn React and Redux in the context of building a complete application? Do you want to learn about Firestore, the new Database offering from Google that provides 'live data' to our application? Are you the type of learner who gets most out of actually building an application rather than watching endless slides about how something is supposed to work? If so then this course is for you!
In this course we build a complete application from start to finish.
Every line of code is demonstrated and explained. We warm up by building a CRUD application in React, we then enhance it by adding Redux and following that we add in Firestore to provide the persistence layer for the application.
Here are just some of the things you will learn about in this course:
Setting up the developer environment
Creating a React application using the create-react-app utility from Facebook
Login and Register functionality using Firebase authentication
Adding social login for Facebook and Google into the application
Google maps and Places autocomplete integration
Photo uploading using drag and drop, with resizing and cropping of the images before upload
Adding a live chat system
Paging, Sorting and Filtering with Firestore
Infinite scroll for the pagination
Firestore database design
Creating reusable form components with React hook forms
Building a great looking application with Tailwind CSS, DaisyUI and Framer Motion
Many more things as well
Tools you need for this course
In this course all lessons are demonstrated using Visual Studio Code, a free (and really good) cross platform code editor. You can of course use your preferred IDE or Code editor of choice and any operating system you like... well as long as it's either Max OSX, Windows or Linux.
Is this course for you?
This course is extremely practical. About 90% of our time is spent actually building the application. If you are the type of person who gets the most out of learning 'by doing', then this course will be for you.
Please note that we do not start from zero coding knowledge. Whilst this is aimed at beginner level, you will need to have some basic javascript knowledge (not a lot is needed) or if you are coming from another programming language then you should be fine with this course. It's designed to take you from beginner level to having the skills to build a much more significant application.
What do we do on this course
We are building a social events application, much like Facebook events or Meetup. Building a social application gives us opportunity to build more than just a simple CRUD application.