In this project, let's build a Cryptocurrency Tracker by applying the concepts we have learned till now.
Refer to the image below:
Design Files
Click to view
Set Up Instructions
Click to view
- Download dependencies by running
npm install
- Start up the app using
npm start
Completion Instructions
Functionality to be added
The app must have the following functionalities
- When the page is opened,
- Make HTTP GET request to the cryptocurrenciesApiUrl
- loader should be displayed while fetching the data
- After fetching the data, the updated list of cryptocurrencies should be displayed
API Requests & Responses
cryptocurrenciesApiUrl
https://apis.ccbp.in/crypto-currency-converter
API: GET
Method: Description:
Returns a response containing the list of cryptocurrencies
Response
[
{
"currency_name": "Bitcoin",
"usd_value": "46750.63",
"euro_value": "39596.07",
"id": "6e937df9-1345-4c2f-8ace-babff0e5108f",
"currency_logo": "https://www.cryptocompare.com/media/19633/btc.png"
},
...
]
Implementation Files
Use these files to complete the implementation:
src/components/CryptocurrencyTracker/index.js
src/components/CryptocurrencyTracker/index.css
src/components/CryptocurrenciesList/index.js
src/components/CryptocurrenciesList/index.css
src/components/CryptocurrencyItem/index.js
src/components/CryptocurrencyItem/index.css
Quick Tips
Click to view
-
To display the animated loader, we need to import the
Loader
component using the below statementimport Loader from 'react-loader-spinner'
-
In order to display the given animated loader, pass the
type
andcolor
props to theLoader
component with values as Rings and #ffffff, respectively<Loader type="Rings" color="#ffffff" height={80} width={80} />
Important Note
Click to view
The following instructions are required for the tests to pass
-
The cryptocurrencies should have the alt as the value of the key
currency_name
from each cryptocurrency object received in response -
Wrap the
Loader
component with an HTML container element and add thetestid
attribute value asloader
to it as shown below<div testid="loader"> <Loader type="Rings" color="#ffffff" height={80} width={80} /> </div>
Resources
Image URLs
- https://assets.ccbp.in/frontend/react-js/cryptocurrency-bg.png alt should be cryptocurrency
Colors
Font-families
- Roboto
Things to Keep in Mind
- All components you implement should go in the
src/components
directory.- Don't change the component folder names as those are the files being imported into the tests.
- Do not remove the pre-filled code
- Want to quickly review some of the concepts you’ve been learning? Take a look at the Cheat Sheets.