• 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

64234.27

@/components/BiggestMoversChart

Biggest Movers 24H / %

@/components/ButtonsContainer

@/components/PairValues

from bitstampData API, values displayed in children components

BitStamp Ticket Values: 20/06/2026, 23:38:37

BTC/USD: 64229.36 (1.48)

63133.21

Day's Range

64334.69

open

63487.34

volume

644.67667471

vwap

63725.16

bid

64229.36

ask

64229.37

side

1

open_24

63292.32

market_type

SPOT

market

BTC/USD

@/components/LineGraph

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

Graph updates every 10s