COVID-19 tracker in LWC
What's the best way to spend the weekend when the country is in lockdown mode - write some cool Lightning components. Over the weekend, I have created a single page application in LWC which gives you the live numbers of how many people are affected by the COVID-19 pandemic worldwide. In a single view, the application gives you an overview of how many people are affected globally. It also gives you the breakdown of the numbers on a per-country basis. You can filter the information by providing the desired country name. Also, besides each country's name is an info icon, which gives you more details for that specific country.
You can install this application using the following unmanaged package: https://login.salesforce.com/packaging/installPackage.apexp?p0=04t6F000004LDId
A live demo of the application is hosted on the following force.com site: https://covid19-info-developer-edition.ap17.force.com/statistics . Please note that this is a developer account and it allows only a limited number of hits per day, so you may get an exception if the limit is already consumed for the day.
The source of data is a web service that is created by a group of developers and hosted on Github.
Now let us look at the architecture of the application. I have followed a design pattern in which the parent component (sometimes called a container component) is responsible for fetching the data. The child components have minimal logic and are mainly used to display the data. Any required data manipulation is done by the parent component and the modified data is again passed back to the child component which re-renders itself on change of data. The need for data change by child components is communicated with the parent component using events. The application is composed of 3 components:
covidInfo.js
When the element is inserted into the document, the connectedCallback method is automatically called. We make a web service call in this method using the fetch API provided by JavaScript. On completion of the web service call, we iterate over the response array and aggregate the information which is being passed to the child component covidCounts in the form of an object. covidCounts.html
This component displays the data which is fed by the parent component covidInfo. covidCounts.js
covidCounts.css covidTable.html
This table displays the country wise data in a tabular format. I have used an HTML table styled with custom CSS to display the data. covidTable.js
The handleChange method is called when user types in the search box. I have debounced the method so that it does not throw an event with the change of each keystroke. Instead, the method waits for 1000ms and then throws an event that is handled by the parent component - covidInfo. The debouncing allows us to have a better performing app and you should always consider debouncing methods which perform some action on change event. covidTable.css
covidCountryInfo.html
This component is conditionally rendered. When the user clicks on the info icon present next to each country's name is the covidTable component, this component will render. covidCountryInfo.js
covidCountryInfo.css
I hope you have enjoyed reading this article. If you have any questions, please feel free to drop a comment or message me on LinkedIn.
A live demo of the application is hosted on the following force.com site: https://covid19-info-developer-edition.ap17.force.com/statistics . Please note that this is a developer account and it allows only a limited number of hits per day, so you may get an exception if the limit is already consumed for the day.
The source of data is a web service that is created by a group of developers and hosted on Github.
Now let us look at the architecture of the application. I have followed a design pattern in which the parent component (sometimes called a container component) is responsible for fetching the data. The child components have minimal logic and are mainly used to display the data. Any required data manipulation is done by the parent component and the modified data is again passed back to the child component which re-renders itself on change of data. The need for data change by child components is communicated with the parent component using events. The application is composed of 3 components:
- covidInfo: This is the top-level component of the application whose role is to do a web service call and fetch the required data. Once the data is fetched, it massages the data and feeds it the child components.
- covidCounts: This component displays the aggregated count. This is a display only component and does not contain any business logic.
- covidTable: This component displays the data on a per-country basis in a tabular format. This component also has the functionality to filter the table.
- covidCountryInfo: This component is displayed when the info icon present next to a country's name is clicked. This component displays the counts specific to a given country.
Let's have a look at the code and try to understand how this application works.
covidInfo.html
When the element is inserted into the document, the connectedCallback method is automatically called. We make a web service call in this method using the fetch API provided by JavaScript. On completion of the web service call, we iterate over the response array and aggregate the information which is being passed to the child component covidCounts in the form of an object. covidCounts.html
This component displays the data which is fed by the parent component covidInfo. covidCounts.js
covidCounts.css covidTable.html
This table displays the country wise data in a tabular format. I have used an HTML table styled with custom CSS to display the data. covidTable.js
The handleChange method is called when user types in the search box. I have debounced the method so that it does not throw an event with the change of each keystroke. Instead, the method waits for 1000ms and then throws an event that is handled by the parent component - covidInfo. The debouncing allows us to have a better performing app and you should always consider debouncing methods which perform some action on change event. covidTable.css
covidCountryInfo.html
This component is conditionally rendered. When the user clicks on the info icon present next to each country's name is the covidTable component, this component will render. covidCountryInfo.js
covidCountryInfo.css
I hope you have enjoyed reading this article. If you have any questions, please feel free to drop a comment or message me on LinkedIn.
Such a very useful article. Very interesting to read this article. I would like to thank you for the efforts you had made for writing this awesome article. After reading your article I was amazed. I know that you explain it very well. And I hope that other readers will also experience how I feel after reading your article .Check out our website also we are one of the best salesforce marketing cloud implementation service in . We are register salesforce consulting and ISV Partner.
ReplyDelete