• 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

70381.65

@/components/BiggestMoversChart

Biggest Movers 24H / %

@/components/ButtonsContainer

@/components/PairValues

from bitstampData API, values displayed in children components

BitStamp Ticket Values: 21/03/2026, 20:12:28

BTC/USD: 70381 (0.23)

69741

Day's Range

71082

open

70498

volume

1249.48884512

vwap

70531

bid

70381

ask

70382

side

1

open_24

70218

market_type

SPOT

market

BTC/USD

@/components/LineGraph

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

Graph updates every 10s