Talmage Bergeson

Portfolio Site

Next.jsReactTypeScriptPostgreSQLDrizzle ORMShadcnTailwind CSS

Modern personal portfolio website built with Next.js 15, featuring a customized UI with Shadcn components, remote MDX content management, and TypeScript. Includes project showcases and a PostgreSQL database with Drizzle ORM.

Portfolio Site

Portfolio Website Limitations

As a developer showcasing my skills and projects, I faced several challenges with existing portfolio solutions:

  • Template limitations restricted my ability to demonstrate the full range of my technical capabilities
  • Performance issues plagued many portfolio templates, creating poor first impressions
  • Lack of database integration made content management tedious and inflexible
  • Accessibility concerns were often overlooked in existing templates
  • Outdated technology stacks failed to demonstrate familiarity with modern web practices

Most importantly, using a template or generic solution would be a missed opportunity to demonstrate my development skills through the portfolio itself. I needed a solution that would serve both as a showcase for my projects and as a project itself—showing my attention to detail, technical capabilities, and commitment to quality.

Modern Stack Implementation

I approached this project as an opportunity to showcase best practices in web development while creating a highly performant showcase for my work:

Frontend Framework Selection:

  • Next.js 15 with App Router was chosen for its server components, optimized rendering, and improved development experience
  • TypeScript provided type safety throughout the codebase, preventing common errors and improving maintainability
  • Shadcn UI components offered a foundation of accessible, customizable UI elements that could be tailored to my specific design needs

Database and Content Strategy:

  • PostgreSQL database provided a robust foundation for storing project and case study information
  • Drizzle ORM offered type-safe database operations with excellent TypeScript integration
  • Database seeding scripts enabled easy deployment and content updates

Design Philosophy:

The design approach balanced several key priorities:

  • Showcasing projects and skills as the primary focus
  • Creating a distinct visual identity that reflected my personal brand
  • Ensuring accessibility for all users regardless of devices or abilities
  • Optimizing for performance without sacrificing visual appeal

Comprehensive Portfolio Platform

Core Features

  • Server Components Architecture Leveraging Next.js 15's server components for optimal loading performance and reduced client-side JavaScript.

  • Dynamic Project Filtering Interactive filtering system allowing visitors to sort projects by technology, type, and other attributes.

  • Detailed Case Studies Rich, MDX-powered case studies with comprehensive project details, challenges, and outcomes.

  • Contact Integration Secure contact form with email integration and validation.

  • Responsive Design Thoughtfully crafted layouts that provide optimal experiences across all device sizes.

Technical Implementation

  • Type-Safe Database Operations Drizzle ORM provides end-to-end type safety from database schema to frontend components.

  • Image Optimization Next.js Image component with careful configuration for optimal loading performance and visual quality.

  • Content Management Structured content in the database with seeding scripts for easy updates and maintenance.

  • Accessibility Features Implementation of ARIA attributes, keyboard navigation, sufficient color contrast, and semantic HTML.

  • Performance Optimization Strategic component splitting, font optimization, and asset loading prioritization.

Technologies Used

Next.jsReactTypeScriptPostgreSQLDrizzle ORMShadcn UITailwind CSS

Design and Technical Hurdles

Balancing Aesthetics and Performance

Creating a visually impressive portfolio while maintaining performance required solving several challenges:

  • Image Optimization Trade-offs High-quality project screenshots and illustrations needed to load quickly without sacrificing visual impact. This required implementing:

    • Responsive image sizing based on viewport
    • Strategic quality settings for different image types
    • Modern image formats with fallbacks
    • Careful loading prioritization
  • Animation Performance Smooth animations and transitions needed to enhance the experience without causing layout shifts or performance issues. This involved:

    • Using CSS transforms over property animations
    • Implementing will-change hints judiciously
    • Measuring and optimizing frame rates
  • Font Loading Strategy Custom typography needed to be available immediately without causing content shifts, requiring:

    • Optimized font subset loading
    • Strategic font display settings
    • Fallback font matching

Database Schema Design

Creating a maintainable structure for case studies and projects required careful consideration:

  • Relationship Modeling Designing the right relationships between projects, skills, and case studies while keeping queries efficient.

  • Content Flexibility Building a schema that accommodated various project types without becoming overly complex.

  • Query Optimization Ensuring database operations remained efficient as content grew over time.

Performance and User Experience Achievements

Technical Metrics

The portfolio achieves exceptional performance across all key metrics:

  • Lighthouse Scores

    • 100/100 Performance
    • 96/100 Accessibility
    • 100/100 Best Practices
    • 100/100 SEO
  • Loading Performance

    • Near-instant page transitions using App Router and prefetching
    • Optimized assets reducing total page weight
    • Efficient caching strategy for repeat visits

User Experience Benefits

Beyond raw performance metrics, the portfolio delivers several qualitative improvements:

  • Intuitive Navigation Visitors can quickly find relevant projects and information with minimal friction.

  • Progressive Enhancement Core functionality works even with JavaScript disabled, with enhanced features layered in when available.

  • Accessibility Compliance Accessibility compliance ensures all users can access and navigate the portfolio regardless of abilities.

Development Showcase

As a demonstration of modern web development practices, the portfolio successfully showcases:

  • Type Safety throughout the entire application
  • Component-Based Architecture with clear separation of concerns
  • Database Integration with efficient querying patterns
  • Modern Styling Approaches using CSS modules and utility classes
  • Performance-First Mindset evident in every implementation decision

This project serves as both a functional tool for showcasing my work and a testament to my commitment to quality, performance, and user experience in web development.