ePortfolio Website

2023-12-07

Introduction

In this blog post, I'll discuss the journey of building my ePortfolio website, highlighting the tools and methods used to showcase my projects. This project marks my first step into website development, transitioning from scripting in Python to full-fledged web development.

The goal was to create a sleek, modern, and responsive portfolio to effectively display my projects while gaining hands-on experience with cutting-edge web development technologies.


Key Tools and Technologies

To build the ePortfolio, I used the following technologies:

  • Next.js 13: A React-based framework that provides features like server-side rendering and dynamic routing.
  • TailwindCSS: A utility-first CSS framework to streamline styling and create responsive layouts.
  • Gray Matter: A library to extract metadata from Markdown files.
  • Vercel: A platform for deploying and hosting the site with ease.

Setting Up the Project

I began by setting up a Next.js project. Next.js provided a perfect balance between simplicity and advanced features, allowing me to focus on building the website without getting bogged down in configuration. Its built-in support for static site generation (SSG) and server-side rendering (SSR) greatly improved the performance and SEO of my site.

To ensure a visually appealing and professional design, I opted to use TailwindCSS. Its utility-first approach allowed me to quickly create responsive and reusable styles while maintaining consistency throughout the site.


Dynamic Routing and Markdown Integration

One of the standout features of this ePortfolio is its ability to dynamically route each portfolio post. This was achieved using Next.js's dynamic route generation, which allows each project to have its dedicated page.

Each portfolio post is stored in a Markdown file, making it easy to manage and update projects without altering the site’s core code. Using Gray Matter, I extracted metadata from these files to create context and improve organization.

This metadata is used for:

  • Displaying project details such as title, date, and description.
  • Generating a list of portfolio entries dynamically.

The integration of Markdown ensured that adding or updating a project was as simple as editing a Markdown file, making the workflow highly efficient.


Styling with TailwindCSS

To achieve a cohesive and visually appealing design, I leveraged TailwindCSS for all styling needs.

Benefits of TailwindCSS:

  1. Rapid Prototyping: Its pre-built utility classes allowed me to quickly build layouts without writing custom CSS.
  2. Consistency: A unified design system was easy to maintain across pages and components.
  3. Responsiveness: TailwindCSS made it straightforward to implement responsive designs for various screen sizes.

Additionally, I tailored typography styles specifically for rendering Markdown content, enhancing readability and aligning with the overall aesthetics of the site.


Deployment with Vercel

To make the ePortfolio publicly accessible, I deployed it on Vercel. Vercel provided an effortless deployment process directly integrated with my GitHub repository.

Why Vercel?

  • Global CDN: Ensures fast loading times for users around the world.
  • Ease of Use: Automated builds and deployments made the hosting experience smooth.
  • Reliable Infrastructure: Minimal downtime and excellent performance guaranteed a seamless user experience.

The deployment process was simple: every time I pushed changes to the main branch, Vercel automatically rebuilt and redeployed the application.


Conclusion

Building my ePortfolio website using Next.js, TailwindCSS, and Vercel has been an enriching experience. This project not only provided a platform to showcase my work but also gave me a deeper understanding of modern web development practices.

Key takeaways from this project include:

  • The power of combining static site generation with dynamic features for enhanced performance.
  • The simplicity and efficiency of using a utility-first CSS framework like TailwindCSS.
  • The seamless integration and deployment capabilities provided by Vercel.

This project is a testament to how modern tools and technologies can simplify the development of robust, scalable, and visually appealing web applications.


Sources:

  1. React
  2. TypeScript
  3. TailwindCSS
  4. Vercel