import Link from 'next/link' import Image from 'next/image' import { cookies } from 'next/headers' import { getIronSession } from 'iron-session' import { AppIcon } from '@/components/shared/app-icon' import { SessionData, sessionOptions } from '@/lib/session' import packageJson from '@/package.json' const buildDate = process.env.NEXT_PUBLIC_BUILD_DATE ? new Date(process.env.NEXT_PUBLIC_BUILD_DATE).toLocaleDateString('nl-NL', { day: 'numeric', month: 'short', year: 'numeric', }) : '—' const version = process.env.NEXT_PUBLIC_APP_VERSION ?? packageJson.version export default async function LandingPage() { const session = process.env.SESSION_SECRET ? await getIronSession(await cookies(), sessionOptions) : null const isLoggedIn = Boolean(session?.userId) return (
{/* ── Header ─────────────────────────────────────────────────── */}
Scrum4Me
{/* ── Hero ───────────────────────────────────────────────────── */}

Scrum planner voor solo developers en kleine teams

Houd meerdere projecten bij in één overzicht. Plan Product Backlogs, beheer Sprints met drag-and-drop en laat Claude Code taken oppakken via een REST API.

Account aanmaken Demo bekijken

Demo-login: gebruikersnaam demo · wachtwoord demo1234

Beta-versie

Scrum4Me is nog in actieve ontwikkeling. Accounts en ingevoerde gegevens kunnen tijdens deze fase worden aangepast, gereset of verwijderd.

{/* ── Tour (screenshots) ─────────────────────────────────────── */}

Bekijk Scrum4Me in actie

Drie schermen die de kern van Scrum4Me afdekken — van Product Backlog tot persoonlijk Kanban-bord. Elke weergave is desktop-first en gebouwd op MD3-tokens en shadcn-componenten.

{[ { src: '/screenshots/sprint-board.jpg', alt: 'Sprint Board met drie panelen: Product Backlog, Sprint Backlog en Taken', title: 'Sprint Board', caption: 'Drie panelen op één scherm: Product Backlog links, Sprint Backlog in het midden, taken van de geselecteerde story rechts. Stories slepen tussen panelen werkt via dnd-kit.', }, { src: '/screenshots/product-backlog.jpg', alt: 'Product Backlog met PBIs gegroepeerd op prioriteit en stories per PBI', title: 'Product Backlog', caption: 'PBIs gegroepeerd op prioriteit (Kritiek → Laag) in het linkerpaneel. Klik op een PBI om de stories rechts te zien, gerangschikt per urgentie en versleepbaar.', }, { src: '/screenshots/solo-paneel.jpg', alt: 'Solo Paneel — persoonlijk Kanban-bord met drie statuskolommen', title: 'Solo Paneel', caption: 'Persoonlijk Kanban-bord per product. Toont alleen taken van stories die jij hebt geclaimd, in drie kolommen (To Do, Bezig, Klaar). Drag-and-drop tussen kolommen verandert de status.', }, ].map((s) => (
{s.alt}
{s.title}

{s.caption}

))}
{/* ── Wat is Scrum4Me ────────────────────────────────────────── */}

Wat is Scrum4Me?

Scrum4Me is een desktop-first webapplicatie die Scrum lichtgewicht maakt — zonder de overhead van grote tools als Jira of Linear. Ontworpen voor developers die zelf de regie willen houden over hun planning.

Hiërarchisch plannen

Organiseer werk in producten, Product Backlog Items, stories en taken. Alles op één plek, gegroepeerd op prioriteit.

Sprint Board

Drie-panelen layout: Product Backlog, Sprint Backlog en taken per story op één scherm. Slepen, sorteren en statussen wisselen via dnd-kit.

Solo Paneel

Persoonlijk Kanban-bord per product. Claim stories vanuit de Sprint en werk je taken af in drie kolommen — To Do, Bezig, Klaar.

Claude Code-integratie

Maak een API-token aan en laat Claude Code de volgende story ophalen, taken uitvoeren en resultaten vastleggen via de REST API.

{/* ── Scrum samenvatting ─────────────────────────────────────── */}

Scrum in Scrum4Me

Scrum4Me past een lichtgewicht versie van Scrum toe — de essentie zonder ceremony-overhead. Hieronder staat hoe de kernbegrippen zijn vertaald naar de app.

{/* Hiërarchie */}

Hiërarchie

{[ { label: 'Product', sub: 'Een softwareproject of codebase' }, { label: 'PBI', sub: 'Product Backlog Item — een feature of verbetering' }, { label: 'Story', sub: 'Concrete user story binnen een PBI' }, { label: 'Taak', sub: 'Implementatiestap binnen een story' }, ].map((item, i, arr) => (
{item.label}
{item.sub}
{i < arr.length - 1 && ( )}
))}
{/* Terminologie */}

Terminologie

{[ { term: 'Product Backlog', def: 'Geordende lijst van alle PBI\'s per product, gesorteerd op prioriteit (kritiek → laag) en positie.' }, { term: 'Sprint', def: 'Actief tijdblok met een Sprint Goal. Per product is er maximaal één actieve Sprint tegelijk.' }, { term: 'Sprint Backlog', def: 'De stories die voor deze Sprint zijn geselecteerd. Stories worden vanuit de Product Backlog gesleept.' }, { term: 'Sprint Board', def: 'Drie-panelen scherm op één view: Product Backlog, Sprint Backlog en taken per geselecteerde story. Vervangt het oude losse Sprint Planning-scherm.' }, { term: 'Solo Paneel', def: 'Persoonlijk Kanban-bord per product. Toont taken van geclaimde stories in drie kolommen (To Do, Bezig, Klaar) — drag-and-drop wijzigt de status.' }, { term: 'Story-claim', def: 'Een developer claimt een story uit de Sprint en wordt assignee. Pull-systeem (zelf-organisatie) — niet pushed door een Scrum Master.' }, { term: 'Story-status', def: 'OPEN → IN_SPRINT → DONE. Bepaalt zichtbaarheid in backlogs en Sprint-schermen.' }, { term: 'Taakstatus', def: 'TO_DO → IN_PROGRESS → DONE. Wordt bijgehouden via UI of REST API door Claude Code.' }, { term: 'Activiteitenlog', def: 'Per story worden implementatieplan, testresultaat en commit vastgelegd via de API of UI.' }, { term: 'Sprint afronden', def: 'Bij afsluiting wordt per story gekozen: markeer als Done of zet terug naar Backlog.' }, ].map(({ term, def }) => (
{term}
{def}
))}
{/* Rollen */}

Rollen

{[ { role: 'Product Owner', desc: 'Bepaalt prioriteit van PBI\'s en beheert de Product Backlog.' }, { role: 'Scrum Master', desc: 'Bewaakt het Scrum-proces en verwijdert obstakels.' }, { role: 'Developer', desc: 'Voert stories en taken uit; werkt via UI of Claude Code.' }, ].map(({ role, desc }) => (
{role}
{desc}
))}

In v1 is één account gelijk aan één gebruiker met alle rollen. Teamgebruik met rolscheiding volgt in v2.

{/* ── Gebruikershandleiding ─────────────────────────────────── */}

Gebruikershandleiding

Volg deze stappen om van een leeg account naar een volledig ingeplande Sprint te gaan.

{[ { step: '1', title: 'Account aanmaken', desc: 'Ga naar Registreren en kies een gebruikersnaam en wachtwoord. Na registratie word je direct doorgestuurd naar het dashboard. Wil je eerst rondkijken? Log in met de demo-account (alleen leesrechten).', }, { step: '2', title: 'Product aanmaken', desc: 'Klik op "Nieuw product" op het dashboard. Vul naam, optionele beschrijving, repo-URL en je Definition of Done in. Het product wordt zichtbaar op het dashboard.', }, { step: '3', title: 'Product Backlog opbouwen', desc: 'Open het product en voeg PBI\'s toe via het linkerpaneel. Geef elk PBI een prioriteit (Kritiek / Hoog / Gemiddeld / Laag). Klik op een PBI om in het rechterpaneel stories toe te voegen. Versleep PBI\'s en stories om de volgorde aan te passen.', }, { step: '4', title: 'Sprint starten', desc: 'Klik op "Sprint starten" op de productpagina en voer een Sprint Goal in. Per product is er maximaal één actieve Sprint tegelijk. Het Sprint-scherm wordt zichtbaar via de navigatie.', }, { step: '5', title: 'Sprint Board — stories slepen en taken aanmaken', desc: 'Open het Sprint-scherm. Drie panelen verschijnen op één view: Product Backlog links, Sprint Backlog in het midden, taken rechts. Sleep stories vanuit links naar het midden om ze in de Sprint te plaatsen. Selecteer een story in het middenpaneel om de taken rechts te tonen en aan te maken.', }, { step: '6', title: 'Solo Paneel — claim stories en werk persoonlijk', desc: 'Open Solo via de navigatie. Claim openstaande stories uit de actieve Sprint (knop "Toon openstaande stories") en werk je taken af in drie statuskolommen via drag-and-drop. Klik op een taak voor het detail-dialoog met implementatieplan.', }, { step: '7', title: 'API-token aanmaken voor Claude Code', desc: 'Ga naar Instellingen → Tokens. Maak een nieuw token aan en kopieer de waarde direct — die is daarna niet meer zichtbaar. Gebruik het token als Bearer-token in Claude Code of je eigen scripts.', }, { step: '8', title: 'Claude Code koppelen', desc: 'Configureer Claude Code met je API-token. Claude haalt via GET /api/products/:id/next-story de hoogst geprioriteerde open story op, werkt taken bij via PATCH /api/tasks/:id en legt het implementatieplan, testresultaten en commits vast via POST /api/stories/:id/log.', }, { step: '9', title: 'Sprint afronden', desc: 'Klik op "Sprint afronden" op het Sprint Board. Voor elke story kies je: markeer als Done of zet terug naar de Product Backlog. Daarna is een nieuwe Sprint aanmaakbaar.', }, ].map(({ step, title, desc }) => (
{step}
{title}
{desc}
))}
{/* ── API-overzicht ─────────────────────────────────────────── */}

REST API voor Claude Code

Alle API-endpoints vereisen een Authorization: Bearer <token> header. Tokens beheer je via Instellingen → Tokens.

{[ { method: 'GET', path: '/api/products', desc: 'Lijst van actieve producten' }, { method: 'GET', path: '/api/products/:id/next-story', desc: 'Hoogst geprioriteerde open story van de actieve Sprint' }, { method: 'GET', path: '/api/sprints/:id/tasks?limit=10', desc: 'Eerste N taken van de Sprint op volgorde' }, { method: 'PATCH', path: '/api/stories/:id/tasks/reorder', desc: 'Taakvolgorde aanpassen (body: { task_ids: string[] })' }, { method: 'POST', path: '/api/stories/:id/log', desc: 'Activiteit vastleggen: implementatieplan, testresultaat of commit' }, { method: 'PATCH', path: '/api/tasks/:id', desc: 'Taakstatus of implementatieplan bijwerken' }, { method: 'POST', path: '/api/todos', desc: 'Todo aanmaken (body: { title, product_id })' }, ].map(({ method, path, desc }) => (
{method} {path} {desc}
))}
{/* ── Footer ─────────────────────────────────────────────────── */}
) }