import Image from "next/image"; import { FadeIn } from "./fade-in"; const APPS = [ { title: "Inspannings Monitor", subtitle: "Wellness-first dagflow", description: "Een lichte app die helpt doseren en inzicht geeft zonder lange formulieren of overprikkeling.", screenshot: "/images/app-inspannings-monitor.png", screenshotMobile: "/images/app-inspannings-monitor-mobile.png", href: "https://inspannings-monitor.jp-visser.nl/dashboard", }, { title: "Scrum4Me", subtitle: "DevPlanner voor kleine teams", description: "Een desktop-first fullstack webapplicatie voor solo developers en kleine Scrum Teams die meerdere softwareprojecten parallel beheren. De app organiseert werk hierarchisch (product -> PBI -> story -> taak), biedt gesplitste planningsschermen met drag-and-drop, en integreert met Claude Code via een REST API.", screenshot: "/images/app-scrum4me.svg", href: "https://scrum4me.jp-visser.nl", }, ]; export function AppsSection() { return (

Portfolio

Apps & Projecten

Hier komen links naar mijn apps die ik op Vercel host.

{APPS.map((app, i) => ( {/* Screenshots */}
{/* Desktop screenshot */} {app.title} {/* Mobile screenshot overlay */} {app.screenshotMobile && (
{`${app.title}
)}
{/* Info */}

{app.subtitle}

{app.title}

{app.description}

))}
); }