Skip to content
Personal Portfolio Website
building
March 1, 2025

Personal Portfolio Website

Next.js
TypeScript
Tailwind CSS
MDX
Vercel

A modern, content-focused portfolio website built with Next.js, TypeScript, and Tailwind CSS

Project Overview

This portfolio website serves as a digital showcase of my work, skills, and experiences. Built with modern web technologies, it offers a responsive, performant, and aesthetically pleasing user experience.

Key Features

Content-First Architecture

All content is stored in separate MDX files in the content directory, making it easy to update and manage without touching the code. This separation of concerns allows for better maintainability and scalability.

Responsive Design

The website is fully responsive, ensuring a great experience on devices of all sizes - from mobile phones to large desktop displays.

Dark/Light Mode

A thoughtfully implemented theme system that respects user preferences while allowing manual toggling between light and dark modes.

SEO Optimization

Built with search engine visibility in mind, including proper metadata, structured data, and semantic HTML.

Modern Tech Stack

Leveraging the power of Next.js 14 with the App Router for optimal performance and developer experience.

Implementation Details

Frontend Architecture

The website follows a component-based architecture, with reusable UI components organized into logical categories:

// Component structure
/components
  /ui       // Basic UI components (buttons, inputs, etc.)
  /layout   // Layout components (header, footer, etc.)
  /cards    // Card components for listings
  /sections // Page section components

Content Management

Content is stored in MDX (Markdown with JSX) files, which are parsed and rendered at build time:

// Example of MDX content
import fs from 'fs';
import path from 'path';
import matter from 'gray-matter';

export async function getAllPosts() {
  const files = fs.readdirSync(postsDirectory);
  const posts = files
    .map((file) => {
      const fileContents = fs.readFileSync(
        path.join(postsDirectory, file),
        'utf8'
      );
      const { data, content } = matter(fileContents);
      
      return {
        slug: file.replace(/\.mdx$/, ''),
        frontmatter: data,
        content,
      };
    })
    .sort((a, b) => new Date(b.frontmatter.date) - new Date(a.frontmatter.date));
  
  return posts;
}

Styling Approach

The website uses Tailwind CSS for styling, with a custom theme configuration:

// tailwind.config.js
module.exports = {
  content: [
    './src/pages/**/*.{js,ts,jsx,tsx}',
    './src/components/**/*.{js,ts,jsx,tsx}',
  ],
  theme: {
    extend: {
      colors: {
        primary: {
          // Custom color palette
        },
        // Other theme extensions
      },
    },
  },
  plugins: [
    require('@tailwindcss/typography'),
    // Other plugins
  ],
}

Technical Challenges

Dynamic Routing with MDX

Implementing dynamic routes based on MDX files required careful consideration of the file structure and build process:

  1. Reading the file system during build time
  2. Generating static paths for all content pages
  3. Parsing frontmatter for metadata
  4. Rendering MDX content with proper syntax highlighting

Performance Optimization

Several techniques were employed to ensure optimal performance:

  • Image optimization with next/image
  • Component-level code splitting
  • Static generation for content pages
  • Font optimization with next/font

Responsive Design Implementation

Creating a truly responsive design that works well across all devices required:

  • Mobile-first approach
  • Careful breakpoint planning
  • Testing across multiple devices and viewport sizes
  • Custom component variants for different screen sizes

Future Enhancements

The portfolio website is designed to evolve over time. Planned future enhancements include:

  1. Authentication System - For the private section
  2. Interactive Project Showcases - More interactive demonstrations of projects
  3. Improved Analytics - Better tracking of user engagement
  4. Newsletter Integration - Allow visitors to subscribe for updates
  5. Internationalization - Support for multiple languages

Conclusion

This portfolio website project demonstrates my ability to design and implement a modern web application with attention to detail, performance, and user experience. It showcases not only my technical skills but also my approach to structuring projects and writing clean, maintainable code.

Related Projects

More projects coming soon...