feat: terminal-noir redesign — widget system + design token overhaul
Replace cyan-green modern theme with terminal-noir aesthetic aligned to style-guide.md. Hard edges, monospace-first, linear transitions, no gradients. Introduce Widget component as the single repeatable section primitive: title bar with horizontal rule, optional badge/meta — all pages and sections now use this pattern (Glance-inspired data-driven layout). Design system changes (globals.css): - Palette: #0a0a0a bg, #111111 surface, #00cc44 status green, #cc2200 alert red - Drop Montserrat; Source Code Pro primary, system sans for prose only - Transitions: linear 120ms; no eased animations, no border-radius Component changes: - Nav: flat, border-bottom only, lowercase links - Hero: 56px square photo, status dot, @ email glyph - ProjectCard: flat bordered card, 2-col grid, no gradient tile - Skills: key-value rows with dot-separated values - Footer: minimal text links Pages: all sections wrapped in Widget; homelab uses gap-px grid for at-a-glance, services, and ADRs sections. Archive uses flat list layout. Data: remove gradient field from Project type; add optional year field
This commit is contained in:
@@ -4,9 +4,9 @@ export type Project = {
|
||||
description: string;
|
||||
tags: string[];
|
||||
githubUrl: string;
|
||||
gradient: string; // Tailwind gradient classes for placeholder image tile
|
||||
tier: "featured" | "archive";
|
||||
stats?: string;
|
||||
year?: number;
|
||||
};
|
||||
|
||||
export const projects: Project[] = [
|
||||
@@ -18,7 +18,6 @@ export const projects: Project[] = [
|
||||
"Offline-first mobile app for tracking golf rounds, managing your 14-club bag, and getting AI-powered club recommendations from a Smart Caddie. Covers 7 shot types per hole with full scorecard history.",
|
||||
tags: ["React Native", "Expo", "Zustand", "AI", "Mobile"],
|
||||
githubUrl: "https://github.com/lerko96/golf-book-mobile",
|
||||
gradient: "from-[var(--color-green-darkest)] via-[var(--color-bg)] to-[var(--color-bg-deep)]",
|
||||
tier: "featured",
|
||||
stats: "211 commits",
|
||||
},
|
||||
@@ -29,7 +28,6 @@ export const projects: Project[] = [
|
||||
"Cross-platform desktop AI chat app for developers. Supports OpenAI, Anthropic Claude, and Google Gemini in a single interface with real-time cost tracking, conversation export, and automatic code explanation.",
|
||||
tags: ["Electron", "Node.js", "OpenAI", "Claude", "Gemini"],
|
||||
githubUrl: "https://github.com/lerko96/plaiground",
|
||||
gradient: "from-[var(--color-green-darker)] via-[var(--color-surface)] to-[var(--color-bg-deep)]",
|
||||
tier: "featured",
|
||||
},
|
||||
{
|
||||
@@ -39,7 +37,6 @@ export const projects: Project[] = [
|
||||
"Web dashboard for tracking uptime across multiple services with 30-second polling, status history visualization, JWT-authenticated API, and Docker + nginx deployment.",
|
||||
tags: ["React 18", "Vite", "Express", "SQLite", "Docker", "JWT"],
|
||||
githubUrl: "https://github.com/lerko96/service-monitor",
|
||||
gradient: "from-[var(--color-bg)] via-[var(--color-green-darkest)] to-[var(--color-bg-deep)]",
|
||||
tier: "featured",
|
||||
},
|
||||
{
|
||||
@@ -49,7 +46,6 @@ export const projects: Project[] = [
|
||||
"3D visualization platform for exploring and organizing thoughts using a radio-tuning metaphor. Filter ideas by frequency and bandwidth in an instanced Three.js scene with persistent local storage.",
|
||||
tags: ["React", "TypeScript", "Three.js", "React Three Fiber", "Zustand"],
|
||||
githubUrl: "https://github.com/lerko96/tht-1.2",
|
||||
gradient: "from-[var(--color-surface)] via-[var(--color-green-darkest)] to-[var(--color-bg-deep)]",
|
||||
tier: "featured",
|
||||
},
|
||||
|
||||
@@ -61,8 +57,8 @@ export const projects: Project[] = [
|
||||
"Chrome extension (Manifest V3) that captures entire Twitter/X threads and exports them as HTML, Markdown, PDF, or image — with metadata preservation and preview before export.",
|
||||
tags: ["Chrome Extension", "Manifest V3", "JavaScript", "jsPDF"],
|
||||
githubUrl: "https://github.com/lerko96/twitter-thread-ext",
|
||||
gradient: "from-[var(--color-bg)] to-[var(--color-bg-deep)]",
|
||||
tier: "archive",
|
||||
year: 2023,
|
||||
},
|
||||
{
|
||||
slug: "notes-app-1.0",
|
||||
@@ -71,8 +67,8 @@ export const projects: Project[] = [
|
||||
"Lightweight canvas drawing app with color picker, adjustable brush size, and PNG export. Runs in the browser, no dependencies.",
|
||||
tags: ["HTML5 Canvas", "JavaScript", "CSS"],
|
||||
githubUrl: "https://github.com/lerko96/notes-app-1.0",
|
||||
gradient: "from-[var(--color-bg)] to-[var(--color-bg-deep)]",
|
||||
tier: "archive",
|
||||
year: 2022,
|
||||
},
|
||||
{
|
||||
slug: "were-hooked",
|
||||
@@ -81,8 +77,8 @@ export const projects: Project[] = [
|
||||
"Fishing location discovery app built as a team of 5 during bootcamp. Java/Spring MVC backend with Thymeleaf templates.",
|
||||
tags: ["Java", "Spring", "Thymeleaf", "HTML", "CSS"],
|
||||
githubUrl: "https://github.com/lerko96/were-hooked-repo",
|
||||
gradient: "from-[var(--color-bg)] to-[var(--color-bg-deep)]",
|
||||
tier: "archive",
|
||||
year: 2022,
|
||||
},
|
||||
{
|
||||
slug: "mystery-educator",
|
||||
@@ -91,8 +87,8 @@ export const projects: Project[] = [
|
||||
"Single-page app mashup of the MET Museum and NASA public APIs. Built as a team of 4 during bootcamp.",
|
||||
tags: ["JavaScript", "REST APIs", "HTML", "CSS"],
|
||||
githubUrl: "https://github.com/lerko96/mystery-educator",
|
||||
gradient: "from-[var(--color-bg)] to-[var(--color-bg-deep)]",
|
||||
tier: "archive",
|
||||
year: 2022,
|
||||
},
|
||||
];
|
||||
|
||||
|
||||
Reference in New Issue
Block a user