Portfolio and personal website built with Next.js
- Production: carlohcs.me
- GitHub Pages: carlohcs.github.io
- Framework: Next.js (v9.0.5)
- React: Class Components with Context API
- Styling: Styled JSX
- Routing: Next.js Routes + Custom Express Server
- PWA: Service Worker + Web App Manifest
- Internationalization: Custom i18n implementation (PT/EN)
- Theme: Dark/Light mode
- Analytics: Google Analytics
- Deployment: GitHub Pages
- Node.js 18.18.x
- npm or yarn
# Clone the repository
git clone https://github.com/carlohcs/carlohcs.github.io.git
# Enter the directory
cd carlohcs.github.io
# Install dependencies
npm install
# Run in development mode
npm run dev# Development
npm run dev          # Start development server
# Build and Deploy
npm run build        # Build the application
npm run export       # Generate static files
npm run start        # Production server
# Deploy to GitHub Pages
npm run deploy:github
# Linting
npm run lint         # Run ESLint
npm run lint:fix     # Fix issues automatically├── components/         # React Components
│   ├── Header.js
│   ├── Menu.js
│   ├── AppProvider.js  # Context API
│   └── helpers/        # Utilities
├── layouts/           # Main layouts
│   └── main.js
├── pages/             # Next.js pages
│   ├── _app.js
│   ├── _document.js
│   ├── index.js
│   └── ...
├── static/            # Static files
│   ├── img/
│   ├── video/
│   └── manifest.json
├── etc/
│   └── messages.json  # PT/EN translations
└── docs/              # Build for GitHub Pages
The site supports Portuguese and English:
- PT: /(default)
- EN: /en/*
Translations are managed in the etc/messages.json file.
Support for light and dark mode:
- Automatic system preference detection
- Manual toggle available
- localStorage persistence
- Web App Manifest
- Optimized icons for different devices
- Custom splash screen
- Installable app
Custom configuration with support for:
- React/JSX
- Styled JSX
- Formatting rules
- Unused variables (except those prefixed with _)
- Image optimization
- CSS/PostCSS
- Static export
- Custom server with Express
npm run deploy:githubThis command:
- Builds the application
- Exports static files to /docs
- Adds .nojekyll
- Automatic commit and push
The site is configured for:
- Automatic redirect to main domain
- SSL/HTTPS
- Asset compression
- Optimized cache headers
- Lighthouse Score: 90+ in all metrics
- Lazy loading of images
- Code splitting automatic (Next.js)
- Preload of critical resources
- Service Worker for caching
- Build error: Clean .nextandnode_modules
- ESLint errors: Run npm run lint:fix
- Favicon not showing: Clear browser cache
- Scroll issues: Temporarily disable smooth scroll
# Check dependencies
npm ls
# Clear cache
rm -rf .next node_modules package-lock.json
npm install
# Build with debug
NODE_ENV=development npm run buildISC
Carlos Henrique Carvalho de Santana
- GitHub: @carlohcs
- LinkedIn: Carlos Henrique
- Website: carlohcs.me
⚡ Tip: Use npm run dev for local development with hot reload!