• Next.js
  • TypeScript
  • Tailwind
  • D3.js
  • MongoDB
  • Cypress

Context management: useContext

    @pages/api/:

  • pairs_data:

    The line graph makes a fetch call to this endpoint, here the data is fetched from the server to avoid CORS errors

  • feedbacks:

    The anonymous feedback in the footer makes a post request to this endpoint, here the feedback is saved into a mongoDB and an SMS alert is sent to my phone with Twilio

  • testAPI:

    These endpoints return mock-data that is used for developement environment and testing with Cypress

@/components/AverageTicketValue

Average price between 3 different APIs

BTC/USD

Average Ticket Value

63893.47

@/components/BiggestMoversChart

Biggest Movers 24H / %

@/components/ButtonsContainer

@/components/PairValues

from bitstampData API, values displayed in children components

BitStamp Ticket Values: 20/06/2026, 21:03:06

BTC/USD: 63883.01 (1.22)

62994.45

Day's Range

64334.69

open

63487.34

volume

623.38178393

vwap

63620.88

bid

63883

ask

63883.01

side

0

open_24

63109.99

market_type

SPOT

market

BTC/USD

@/components/LineGraph

Serverless function @pages/api/pairs_data/[pair]

Graph updates every 10s