Aller au contenu principal
logoYvan Kerdanet
Retour

Portfolio v2

En cours

Refonte complète du portfolio en Next.js 16 App Router et TypeScript. L'API GitHub alimente en temps réel les pages /projects et /skills. Design system cohérent (tokens CSS, thème clair/sombre persisté sans flash), page à propos avec intro terminal typewriter.

Next.js 16React 19TypeScriptTailwind CSS v4Three.jsFramer Motion
mars 2025· dernier push mai 2026

// langages

TypeScript99.3%CSS0.6%JavaScript0.1%

// fonctionnalités

  • Page projets alimentée par l'API GitHub (repos propres + contributions)
  • Page compétences avec stats GitHub par technologie et détection de frameworks via package.json
  • Page à propos avec animation terminal typewriter
  • Formulaire de contact avec états animés et anti-spam honeypot
  • Thème clair/sombre persisté via cookie (sans flash SSR)

// défis

  • Détection des frameworks JS via parsing du package.json de chaque repo (API Contents GitHub)
  • Zéro flash de thème au chargement sans JavaScript côté client au premier rendu
  • Migration TypeScript complète depuis une base JavaScript

// axes d'amélioration

  • Dashboard privé avec suivi financier multi-banques
  • Authentification NextAuth v5 pour les routes /dashboard
  • Blog avec éditeur privé et persistance en base de données

// README

Portfolio — Yvan Kerdanet

Portfolio personnel construit avec Next.js 16 App Router. Présente les projets récupérés en direct depuis GitHub, les compétences avec statistiques d'usage, une page à propos avec intro façon terminal, un formulaire de contact branché en base de données, et un dashboard d'administration privé.

Version actuelle : v2.1.4


Pages

RouteDescription
/Accueil — hero + points forts
/projectsDépôts GitHub (API live), filtrables par langage
/projects/[owner]/[repo]Détail d'un dépôt
/skillsGrille de compétences avec stats GitHub + Currently Learning (BDD)
/aboutIntro terminal + timeline, méthodes de travail, loisirs
/contactFormulaire de contact branché en base de données
/legalMentions légales
/loginConnexion admin (GitHub OAuth via Supabase)
/dashboardHome dashboard — résumé messages, statut, apprentissages, relances
/dashboard/cvDonnées CV master (profil, expériences, compétences, projets…)
/dashboard/candidaturesSuivi des candidatures avec timeline, entretiens, relances
/dashboard/candidatures/[id]/cvGénérateur de CV personnalisé par candidature + export PDF
/dashboard/personnalizeCRUD statuts de disponibilité + Currently Learning
/dashboard/contact_messageInbox messages reçus (3 colonnes, filtres, actions)

/blog est désactivé — redirige vers /.


Stack

Front-end

  • Framework : Next.js 16 (App Router) + React 19
  • Langage : TypeScript — uniquement .ts / .tsx
  • Styles : Tailwind CSS v4 (configuré via globals.css, sans tailwind.config.js)
  • Thème : next-themes — clair/sombre, class-based, persisté en cookie (sans flash)
  • 3D : Three.js + @react-three/fiber + @react-three/drei
  • Animations : Framer Motion
  • Icônes : lucide-react + react-icons

Back-end & données

  • ORM : Drizzle — schémas dans db/schemas/, migrations dans db/migrations/
  • Base de données : Supabase (PostgreSQL managé) — schémas portfolio, cv, applications
  • Auth : Supabase Auth + GitHub OAuth — mono-utilisateur, whitelist par UUID
  • Storage : Supabase Storage — bucket privé cv-pdfs, accès via signed URLs
  • PDF : PDFShift (SaaS, fetch natif) — isolé dans lib/cv/pdf-service.ts
  • API GitHub : REST API (repos, contents) pour /projects et /skills

Observabilité

  • Analytics : Vercel Web Analytics — cookieless, RGPD-compliant, exclu sur /dashboard/*
  • Performance : Vercel Speed Insights — Core Web Vitals en production

Démarrage

# 1. Cloner git clone https://github.com/KerdanetYvan/portfolio.git cd portfolio # 2. Installer les dépendances npm install # 3. Configurer les variables d'environnement cp .env.local.example .env.local # 4. Lancer le serveur de développement npm run dev # http://localhost:3000

Variables d'environnement

# .env.local # GitHub — PAT pour l'API repos/skills (scopes : public_repo, read:user) GITHUB_TOKEN=ghp_xxxxxxxxxxxxxxxxxxxxx # Supabase — connexion base de données DATABASE_URL=postgresql://... # Pooler URL (runtime) DIRECT_URL=postgresql://... # Direct URL (migrations Drizzle uniquement) # Supabase — Auth NEXT_PUBLIC_SUPABASE_URL=https://xxx.supabase.co NEXT_PUBLIC_SUPABASE_ANON_KEY=eyJ... SUPABASE_SERVICE_ROLE_KEY=eyJ... # Jamais exposée côté client (Storage PDF) # Dashboard — UUID de l'utilisateur admin (Auth > Users dans Supabase) ADMIN_USER_ID=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx # PDFShift — génération PDF (https://pdfshift.io) PDF_BUILD_URL=https://api.pdfshift.io/v3/convert/pdf PDF_BUILD_KEY=sk_xxxxxxxxxxxxxxxxxxxx

Commandes

npm run dev # Serveur de développement (Turbopack) — http://localhost:3000 npm run build # Build de production npm run start # Serveur de production npm run lint # ESLint npm run db:generate # Génère les fichiers de migration depuis les schémas Drizzle npm run db:migrate # Applique les migrations sur la base de données npm run db:studio # Interface Drizzle Studio locale

Contact

kerdanety@gmail.com · LinkedIn · GitHub