Skip to content

Latest commit

 

History

History
145 lines (82 loc) · 6.39 KB

readme.md

File metadata and controls

145 lines (82 loc) · 6.39 KB

logo_ironhack_blue 7

LAB | Financial Data Graphing



Introduction



CoinDesk is the world leader in news and information on digital currencies such as bitcoin, and its underlying technology - the blockchain.

They cover news and analysis on the trends, price movements, technologies, companies, and people in bitcoin as well as the digital currency world.

In this exercise, we will be using one of their data repositories: the Bitcoin Price Index. CoinDesk provides a simple API to make its Bitcoin Price Index data programmatically, and we are going to use it to represent the values in a chart.

The Bitcoin Price Index is the value that has bitcoin in different currencies. So we are going to show these variations in a graphic with Chart.js.

👀 ChartJS (also known as chart.js) is an open-source library that allows us to create amazing static and animated charts through HTML5 canvas and JavaScript.

Requirements

  • Fork this repo
  • Then clone this repo.

Submission

  • Upon completion, run the following commands
$ git add .
$ git commit -m "done"
$ git push origin master
  • Create Pull Request so your TAs can check up your work.

Instructions

We have already created a JavaScript file to add all your AJAX code: public/js/financial-data.js

The app will be a super simple exercise where we are going to represent some data in a line chart.

Let's start!


Iteration #1: Get the data

The first thing we need to do is to get the data we are going to represent in our chart. To do that, we will use the CoinDesk API Documentation.

Since we want to present historical data on the chart, as you can see, you have to make a GET request to the http://api.coindesk.com/v1/bpi/historical/close.json URL. The response will be a JSON with the data we want to represent.

As you can see in the image above, the Y-axis will represent the bitcoin value, while the X-axis will represent the date of each value.

We are going to use Axios to make the AJAX Request, so we have to import Axios through its CDN.

Tasks

  • Add the Axios reference in the HTML through CDN to be able to use it.
  • You have to create an Axios Request to this URL and get the data. Use a console.log() to be sure that we are getting the correct data.

Iteration #2: Create the chart

Once we have the desired data, we have to show it as a chart. We are going to use Chart.js to do that. So we have to add the library through CDN.

Once we have added the CDN reference in the HTML file, we have to represent the values we got in Iteration 1 in a Line Chart.

Note: Before you ask for help in the chart representation, try to read the documentation and figure out how it works. :)

Tasks

  • Add Chart.js reference through CDN.
  • Give the correct format to the data we get in the Iteration 1 to show it in a line chart.
  • Practice reading documentation with the Chart line documentation.
  • Create a line chart and show the data.

Iteration #3: Dates Filter

As you can see, by default, the API response gives us the last month's Price Index. In this iteration, we are going to add two date input to be able to filter these dates.

Use the following API endpoint to filter the data and get the values between two dates:

http://api.coindesk.com/v1/bpi/historical/close.json?start=${fromDate}&end=${toDate}&currency=${currency}

To finish up this iteration, remember that the data has to be loaded every time we select a date, so you must add a listener and trigger the load data function every time that the date selector changes its value.

Tasks

  • Add two <input type="date"> fields to indicate the dates between which you are going to search: from date - to date.
  • Add a listener to this input to search the data every time that its values change.
  • Add the dates to the API URL to get the correct data.

Iteration #4 (Bonus): Currency

Another option that the API gives us is to get the bitcoin index in a specific currency. By default, the currency is the US Dollar (USD). We are going to change that by adding another filter.

We are going to create a <select> input to allow the user to indicate which currency they want to get the results in. By default, we are going to add two different currencies: USD and EUR.

Feel free to add as many currencies as you like.

As in the dates filter, the data has to be reloaded every time the currency changes. Again, in the CoinDesk API documentation, you can find how to indicate a specific currency.

Tasks

  • Add a dropdown to indicate which currency will be shown in the application.
  • Add a listener to the select field to reload the data every time its value changes.
  • Add the currency to the API URL to load the correct values in our application.

Iteration #5 (Bonus): Max/Min Values

To finish up with the exercise, let's add an information box where we are going to show which are the maximum and minimum values in the indicated filters.

To do that, we have to get the prices from the response we got in the first iteration and select the max and min values. Once we have these values, we have to show them in the view.

Tasks

  • Add an information box in the HTML to show the max/min values from the chart.
  • Create an array with the price values from the response.
  • Use Math.min() and Math.max() to filter the array and get the min/max values.
  • Show these values in the information box we have added to the view.



Happy coding! ❤️