Skip to content

kocheck/folio

Repository files navigation

Kyle Kochanek's Portfolio

Netlify Status

A personal portfolio website showcasing work and thoughts on design and development.

Features

  • Responsive design
  • Fast loading and optimized performance
  • Project showcase with filtering capabilities
  • Blog/thoughts section
  • Contact form integration
  • Dark/light mode support

Development Setup

Prerequisites

  • Hugo Extended (v0.110.0 or later)
  • Node.js (v16 or later)
  • npm (v8 or later)

Local Development

  1. Clone the repository:

    git clone https://github.com/yourusername/folio.git
    cd folio
  2. Install dependencies:

    npm install
  3. Start the development server:

    npm run dev
  4. View the site at http://localhost:1313

Building for Production

npm run build

The built files will be in the public/ directory.

Project Structure

folio/
├── archetypes/     # Content templates
├── assets/         # Source files (SCSS, JS)
│   ├── scss/      # Styling files
│   └── js/        # JavaScript files
├── content/        # Markdown content
│   ├── work/      # Project posts
│   └── blog/      # Blog posts
├── data/          # Site data files
├── layouts/       # Hugo templates
├── static/        # Static files
│   ├── assets/    # Images and other assets
│   └── admin/     # CMS admin panel
└── config.toml    # Site configuration

Content Management

Adding a New Project

hugo new work/your-project-name/index.md

Project front matter template:

---
title: "Project Title"
date: 2024-03-21
draft: false
description: "Brief project description"
tags: ["web", "design", "development"]
technologies: ["React", "Node.js"]
thumbnail: "/assets/images/projects/thumbnail.jpg"
---

Adding a Blog Post

hugo new blog/post-name.md

Adding Images

  1. Place images in the page bundle directory alongside your content
  2. Reference in markdown using the image shortcode: {{< image src="filename.jpg" alt="Alt text" >}}
  3. Images will be automatically converted to WebP with JPEG fallback
  4. Original images should be high quality (they will be automatically optimized)

Image Guidelines

Thumbnails

  • Width: 600px
  • Aspect Ratio: 16:9
  • File Format: WebP (with JPEG fallback)
  • Quality: 80%
  • File Size: Aim for under 50KB after optimization

Hero Images

For work/project pages, use these specifications for hero images:

  • Width: 3840px (minimum 2400px)
  • Height: 1920px (minimum 1200px)
  • Aspect Ratio: 2:1 or 16:9
  • File Format: WebP (with JPEG fallback)
  • Quality: 85%
  • File Size: Aim for under 1MB after optimization

The hero images will be automatically resized to:

  • 3840px (4K displays)
  • 2880px (Retina 5K)
  • 1920px (Full HD)
  • 1200px (Mobile/Tablet)

Configuration

Environment Variables

Create a .env file in the root directory:

HUGO_ENVIRONMENT="development"
CONTACT_FORM_ENDPOINT="your-endpoint"
GA_TRACKING_ID="UA-XXXXXXXXX-X"

Custom Styling

  1. Modify variables in assets/scss/_variables.scss
  2. Add custom styles in assets/scss/custom.scss

Deployment

Netlify

  1. Connect your GitHub repository
  2. Build command: npm run build
  3. Publish directory: public
  4. Set environment variables in Netlify dashboard

GitHub Pages

  1. Update config.toml baseURL
  2. Enable GitHub Actions workflow
  3. Configure GitHub Pages settings

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Commit changes
  4. Push to the branch
  5. Create a Pull Request

License

This project is licensed under the MIT License - see the LICENSE.md file for details

Support

For support, email [email protected] or create an issue in the GitHub repository.

Advanced Configuration

Theme Configuration

The portfolio supports both light and dark themes with CSS custom properties. Theme colors are defined in:

startLine: 1
endLine: 13

Performance Optimizations

  1. Service Worker
  • Implements offline functionality
  • Caches critical assets
  • Handles failed network requests Reference implementation in:
startLine: 1
endLine: 50
  1. Image Optimization
  • Automatic WebP conversion
  • Responsive image sizing
  • Lazy loading implementation
  • Image optimization settings defined in hugo.toml:
startLine: 37
endLine: 41

Typography System

The portfolio uses a sophisticated typography system with:

  • Responsive font scaling
  • Optimized line lengths
  • Dark mode adjustments
  • Proper heading hierarchy

Reference implementation in:

startLine: 134
endLine: 265

Page Transitions

Smooth page transitions are implemented using:

  • CSS transitions
  • History API
  • Fixed element handling Reference implementation in:
startLine: 1
endLine: 37

Accessibility Features

  1. Color Contrast Testing
  • Automated contrast ratio checking
  • WCAG 2.1 compliance testing Reference implementation in:
startLine: 1
endLine: 71
  1. Keyboard Navigation
  • Skip links
  • Focus management
  • ARIA attributes

Development Scripts

Additional npm scripts available:

startLine: 5
endLine: 11

Security Headers

Security headers are configured in the Netlify configuration:

startLine: 16
endLine: 23

Component Guidelines

Image Components

The portfolio includes several image-related components:

  1. Basic Images
  • Standard image with lightbox support
  • Caption support
  • Lazy loading
  1. Image Grids
  • 2-column grid
  • 4-column grid
  • Responsive breakpoints

Reference implementation in:

startLine: 1
endLine: 22

Content Layout

Content follows a structured layout system:

  • Maximum width constraints
  • Responsive padding
  • Proper content hierarchy

Reference implementation in:

startLine: 1
endLine: 12

Contributing

[Previous contributing section remains]

Testing

  1. Run contrast tests:
npm run test:contrast
  1. Validate HTML:
npm run test:html
  1. Check performance:
npm run lighthouse

Browser Support

  • Chrome (last 2 versions)
  • Firefox (last 2 versions)
  • Safari (last 2 versions)
  • Edge (last 2 versions)
  • iOS Safari (last 2 versions)
  • Android Chrome (last 2 versions)