Join me for an action-packed live stream series where we’ll go step-by-step through building and deploying a scalable, production-ready application using Next.js. This hands-on workshop dives deep into project setup, best practices for performance optimization, infrastructure management, and continuous deployment. Whether you’re a startup developer, a team lead, or a coding enthusiast, this series will help you level up your web development skills and build robust applications with real-world scalability.
Join me for an epic live stream workshop, “Next.js Workshop Finale: Setting Up Production-Ready Infrastructure for Scalable Apps.”
In this hands-on session, we’ll cover everything you need to know about building production-grade infrastructure with Next.js. From project setup and code organization to implementing best practices for scalability and performance, this workshop is designed to help you create apps that are ready for the real world.
Whether you’re working on a startup, a team project, or building your portfolio, this workshop is packed with actionable tips, real-world examples, and expert guidance to help you level up your skills.
Join me for an exciting multi-day live stream series where we’ll build and deploy a scalable, real-time production grade chat application using React, NestJS, GraphQL and MongoDB! This full-stack course will guide you step-by-step through creating a production-grade web app, complete with continuous delivery on AWS.
In this tutorial we are going to build a COVID or The Corona Virus Disease Tracker, a modern scalable React Application using React JS framework and four advanced React tools: Redux, Thunks, Selectors and Styled Components. Just React JS is enough for creating simple applications but if you want to build large, high performance applications, your job will be much more simplified if you know how to use these additional tools.
For the Application concept, I thought I would create something that might be useful for me in the current situation. The current situation in World is not good. COVID-19 or The Corona Virus Disease has affected lives of people in many countries. I am currently staying in Singapore and have been working from home since last two weeks. As a developer I thought it would be better to use my time during this weekend to create a Tutorial to build an App for tracking Corona Virus reports from different countries.
Search Country Report: Country Codes you can use for testing: GB (United Kingdom), US (USA), SG (Singapore), GE (Georgia), IN (India), IT (Italy), ES (Spain).
Pin Country Result to move a result to very top.
Remove a Country from the list.
Persisting the result on reload as well. Note: The results are not being saved in any Database. We will save them in localStorage since our only focus here is Frontend development with React.
Prerequisites for this Tutorial:
To get the most of this tutorial, it will be better if you already know the following:
Introduction, and Project Setup: We will setup the project and understand the project structure.
Build the Application view by creating components in React JS. Important Sections:
Manage state of the application with Redux.
Handle API/Asynchronous calls with Thunks.
Selectors: A middle layer between API layer and Component View.
Styled Components: For handling CSS in a smart way, from JS file instead of creating separate CSS file.
Build app for Production deployment.
Why use the Advanced React Tools?
Every Application mainly consists of 3 important layers. API layer to get data from the APIs. A data layer where we can handle the data from API and modify it to our requirements, and last but not the least, a view layer to show the data.
React JS framework was basically designed to mainly take care of the views only. Which means React JS is powerful to show data but when it comes to the other tasks such as calling APIs and handling or managing data, although React can do the job, React is not that good. Because, React does not have any specific sets of standards on how to manage state and perform API calls etc. That is ok when we are creating a small application but if you are working on a large application with a team, each developer will have their own ways of handling the code. And thus not having a set of rules will clutter the code and it will be extremely difficult to debug the code in future. So that’s where all these tools are helpful. They provide extra sets of rules on how to do things. For example: Redux takes care of data or state management by adding some extra standard rules. Similarly Thunks have a standard way of calling the APIs. And styled components have a specific way of handling CSS.
So in summary, these extra tools help us organise the application in a much standard way by separating the responsibilities among different tools instead of handling everything with React. Thus, the Application is easy to manage and expand.
Tasks for you after Tutorial:
Create Unpin Country Button, clicking which The pinned Countries can come back to the Not Pinned Countries Section.
Create another React Component to show the Global Stats of total cases, from API: https://api.thevirustracker.com/free-api?global=stats. Use the same flow of first creating a GlobalStats.js component, add redux globalstats reducer, add selectors and finally adding styles with styled components.
Modify the reducer code to remove isLoading reducer and add isLoading as a property of state.countries instead of direct child of the state. Because now we are adding a new API. and we will need isLoading property for individual API. So also we need to add another isLoading prop for state.globalstats.
React is a JavaScript framework created by Facebook to help web developers build single page applications quickly. In this tutorial we are going to create a full stack to do or task manager application from scratch with react.