Tech stack: TypeScript, JavaScript, Next.js, HTML, TailwindCSS, FastAPI, Vercel, AWS (Elastic Beanstalk, EC2), MongoDB Atlas, Strava's API, D3.js, Jest, React Testing Library
Project Links
Gallery
data:image/s3,"s3://crabby-images/cfa49/cfa4978e5d62bcc9d1567e9c1604cd94464e4da4" alt="Project screenshot 1"
data:image/s3,"s3://crabby-images/1d388/1d3886181128905a356689afd87c53754b04967b" alt="Project screenshot 2"
data:image/s3,"s3://crabby-images/5be26/5be2693ed54d3b68b9a2ec8b9ec2b8b7127a7b6c" alt="Project screenshot 3"
This is the second iteration of my website. The first version was built with React alone, which restricted navigation to the home page due to a lack of proper routing. I was also dissatisfied with the styling, so I decided to rebuild the site to improve accessibility and update the design.
When redesigning the website, I focused on automation and scalability. The front end is built with Next.js and TypeScript. Project pages are generated dynamically using a template and a structured project data file. The same approach is used to create the project 'cards' displayed on the main projects page.
For the running page, I set up a Node.js server to fetch my running data from a MongoDB database. D3.js then visualizes this data as a scatter plot. The server updates the database twice daily with new running data. To ensure scalability, I deployed the server to the cloud using AWS Elastic Beanstalk.