pbi-mockup

star 1

[Project Management] Use when you need to generate an HTML mockup report from PBI and story artifacts.

duc01226 By duc01226 schedule Updated 6/8/2026

name: pbi-mockup version: 1.0.0 description: '[Project Management] Use when you need to generate an HTML mockup report from PBI and story artifacts.'

[BLOCKING] Execute skill steps in declared order. NEVER skip, reorder, or merge steps without explicit user approval. [BLOCKING] Before each step or sub-skill call, update task tracking: set in_progress when step starts, set completed when step ends. [BLOCKING] Every completed/skipped step MUST include brief evidence or explicit skip reason. [BLOCKING] If Task tools are unavailable, create and maintain an equivalent step-by-step plan tracker with the same status transitions.

Quick Summary

Goal: Give stakeholders a clickable, self-narrating MVP prototype of every story's main-flow UI — by generating a self-contained interactive HTML mock-up file (one per PBI covering all stories) from finalized PBI/story artifacts, styled from the project's reference design docs, existing UI, components, and real domain entity data — before implementation begins, so layout/UX/flow/state gaps surface while changes are still cheap.

Summary:

  • This is a PRE-implementation preview tool, not a UI builder: only run on finalized PBIs/stories (reviewed, gated); for backend-only PBIs with no UI sections, skip generation and tell the user — do NOT use it for production UI, design specs, or scratch wireframes.
  • Plan first, generate second: enumerate the PBI's main-story/MVP flows into flow-specs and create one todo per flow (Step 2b) BEFORE generating; sign off with a final Demo-Quality review gate (Step 8) auditing the generated prototype.
  • Output is exactly ONE self-contained HTML file per PBI (all stories as tabs/sections), inline CSS/JS, no external deps except Google Fonts, saved alongside the PBI artifact as {pbi-filename}-mockup.html.
  • The mock-up is a scripted clickable prototype — each main-story flow clicks through end-to-end ("click X → see Y → move to Z") with guided narration (▶ Play / ⏭ Next / ⏮ Prev / ↺ Reset / ⏏ Exit), an explanation panel, and a visible "⚠ Simulated" banner; interactivity is scripted/simulated only (canned transitions, illustrative data) — NEVER real auth, persistence, or backend.
  • Fidelity is the whole point — the mock-up must LOOK like the existing app: load the canonical + matched per-app design-system docs (NEW→canonical, REFACTOR→per-app), read real shared/module components for layout patterns, and populate with real domain entity fields and realistic sample data, never Lorem ipsum.
  • Render every defined component state (default/loading/empty/error) as toggleable, keep any accompanying prose/captions tech-agnostic (business terms, not framework/CSS class names) per the M1/M2 mandates, even though the rendered HTML may use real class names internally.

Workflow:

  1. Locate Artifacts — Find PBI and story files in team-artifacts/pbis/
  2. Extract UI Specs — Parse UI Layout, Wireframe, Components, States, Interaction Flow sections 2b. Plan the Demo Flows — enumerate main-story/MVP flows, author one flow-spec per flow, TaskCreate one todo per flow ([BLOCKING], before generating)
  3. Load Design System — Read module-specific design tokens, colors, typography
  4. Load Existing UI — Read existing components, page layouts, and patterns from the project
  5. Load Domain Entities — Read entity fields, relationships, and enums for realistic sample data
  6. Generate HTML — Create self-contained interactive prototype (scripted clickable flows + guided walkthrough) matching the current system's look and feel
  7. Save — Write HTML file alongside the PBI artifact
  8. Demo-Quality Review Gate — [BLOCKING] audit every flow clicks end-to-end, no dead controls, narration + banner, offline, iframe-safe

Key Rules:

  • Ask AI to generate an interactive HTML mock-up for UI PBIs; do not stop at an ASCII-only or static mockup — every main-story flow is a scripted clickable prototype with guided narration.
  • One HTML file per PBI (all stories shown as sections/tabs)
  • Plan the demo flows (Step 2b) BEFORE generating; sign off with the Demo-Quality gate (Step 8) AFTER
  • Interactivity is scripted/simulated only (canned transitions, illustrative data, "⚠ Simulated" banner) — NEVER real fetch/auth/persistence/backend; self-contained so it runs inside the deck's <iframe srcdoc>
  • Self-contained: inline CSS/JS, no external dependencies except Google Fonts
  • Must resemble the project's current UI — read existing component templates and page layouts
  • Design must be based on project reference design docs: docs/project-reference/design-system/README.md, docs/project-reference/design-system/design-system-canonical.md, and the matched per-app design-system doc from docs/project-config.json
  • Match project design system: colors, typography, spacing, BEM naming
  • Use real domain entity fields and realistic sample data — not Lorem ipsum
  • Include component states (default, loading, empty, error)
  • Responsive layout with mobile/desktop preview
  • Save in same directory as the PBI artifact
  • Tech-agnostic descriptive prose (M1/M2): See .claude/skills/shared/sdd-artifact-contract.md → "AI-SDD Mandates (M1-M6)" for BLOCKING criteria. Any narrative, captions, annotations, generation notes, or component/state descriptions accompanying the mock-up describe components and states by business/observable terms (e.g., "status indicator", "record list", "loading placeholder"), NOT by framework component names or CSS class names. The rendered HTML itself may use real class names internally (that is implementation, not prose), but the human-readable descriptions stay tech-agnostic per docs/project-reference/spec-principles.md §3.

Be skeptical. Apply critical thinking, sequential thinking. Every claim needs traced proof, confidence percentages (Idea should be more than 80%).

PBI HTML Mockup Generator

Generate visual HTML mockup reports from PBI and user story artifacts.


When to Use

  • After PBI and stories are finalized (reviewed, challenged, gated)
  • Before moving to implementation planning or design spec
  • When stakeholders need a visual preview of the feature
  • As the final step in workflow-idea-to-pbi and similar workflows

NOT for: Implementing production UI (use /feature-implement), creating design specs (use /design-spec), or wireframing from scratch (use /design-spec --mode=wireframe).


Quick Reference

Input

Source Path
PBI artifact team-artifacts/pbis/{YYMMDD}-pbi-{slug}.md
Story artifacts team-artifacts/pbis/stories/{YYMMDD}-us-{pbi-slug}.md
Explicit path User provides path as argument

Output

Type Path
HTML mockup {same-dir-as-pbi}/{pbi-filename}-mockup.html

Related

  • Input from: /refine, /story
  • Command: /pbi-mockup
  • Next Step: /prioritize, /design-spec, /plan

Detailed Workflow

Step 1: Locate PBI Artifact

  1. If argument provided, use it as path
  2. Otherwise, find most recent PBI: Glob("team-artifacts/pbis/*-pbi-*.md") sorted by modification time
  3. Read the PBI artifact fully
  4. Check for associated stories: Glob("team-artifacts/pbis/stories/*-us-{pbi-slug}*.md")
  5. Read all story artifacts if found

Step 2: Extract UI Specifications

From the PBI and story artifacts, extract:

Section What to Extract
## UI Layout / ## UI Wireframe ASCII wireframe, layout description
### Components Component names, behaviors, tiers
### States Default, Loading, Empty, Error states
### Interaction Flow User actions and system responses
## Acceptance Criteria GIVEN/WHEN/THEN scenarios for context
## Description User role, capability, business value
frontmatter priority / rank PBI priority label + numeric rank — render in the header (Step 4). MANDATORY when present; the mockup MUST carry the same priority info as the backlog.

If no UI sections exist (backend-only PBI), inform user and skip mockup generation:

"This PBI has no UI sections (marked as backend-only). No mockup generated."

Step 2b: [BLOCKING] Plan the Demo Flows (think → plan → many todos BEFORE generating)

[BLOCKING] Do NOT generate the mock-up until every main-story flow is planned as a flow-spec and a todo exists per flow. The mock-up is a clickable, self-narrating prototype of the PBI's main user-story happy paths — plan the journeys first, generate second.

  1. Enumerate the main-story / MVP flows — from ### Interaction Flow, the ## Acceptance Criteria GIVEN/WHEN/THEN scenarios, and each story's "As a / I want / So that". One flow per main user story (MVP happy path) — not every edge case.
  2. Author one flow-spec per flow — fill the references/interactive-demo.md §1 schema: id, business-language title, persona, trigger, ordered steps[] where each step = { action: "user clicks/selects/types X", result: "screen/state Y appears", explain: "plain-language why" }, and endState. The explain/title prose stays tech-agnostic (business terms, not class names) per M1/M2.
  3. TaskCreate one todo per flow — so each journey is generated and later verified (Step 8) individually; add the Step 8 Demo-Quality review as the final todo.

See references/interactive-demo.md §1 for the flow-spec schema + a worked example.

Step 3: Load Design System Context

  1. Read PBI module field from frontmatter

  2. Load design system docs dynamically (project-config.json + glob fallback). The HTML mock-up design must be based on these project reference design docs:

    • Mandatory baseline: Read docs/project-reference/design-system/README.md and docs/project-reference/design-system/design-system-canonical.md
    • Primary: Read top-level designSystem in docs/project-config.json: use designSystem.docsPath + designSystem.canonicalDoc, then match the PBI/app context against designSystem.appMappings[] to select the per-app doc. Do NOT look for designSystem on module entries.
    • Fallback: Glob("docs/project-reference/design-system/*.md") → match module name against discovered file names (case-insensitive substring match)
    • Default: If no match found, use docs/project-reference/design-system/README.md
    • Triage rule (NEW vs REFACTOR): For NEW pages/components → load designSystem.canonicalDoc from top-level project-config.json (single source of truth for new code). For REFACTOR of existing screens → load the matched per-app doc via top-level designSystem.appMappings (current-state inventory).
  3. Extract from design system docs (read enough of the canonical and matched per-app docs to apply the rules):

    • Colors: Primary, secondary, accent, background, text colors
    • Typography: Font families, sizes, weights
    • Spacing: Margin/padding scale
    • Border radius: Component roundness
    • Shadows: Elevation levels
  4. Optionally read docs/project-reference/scss-styling-guide.md (first 100 lines) for BEM patterns

Step 3b: [BLOCKING] Inventory Existing UI + Map Connected Flows (match current system UI)

[BLOCKING] Do NOT generate the mockup until this inventory + connected-flow map is done (canonical: SYNC:existing-ui-research). The mockup must faithfully match the current UI system, not generic HTML.

The mockup should resemble the project's actual UI, not generic HTML. Discover existing components AND map the flows that connect to this screen:

  1. Read docs/project-reference/frontend-patterns-reference.md (first 200 lines) — extract base component classes, common UI patterns, form patterns, table/grid patterns, dialog/modal patterns
  2. Glob the project's shared component library (if exists):
    • Glob("**/libs/*common*/**/*.component.ts") or Glob("**/shared/**/*.component.ts") — discover reusable components (buttons, tables, forms, dialogs, filters, status badges)
    • Read 2-3 key component files to understand their HTML template structure and CSS class naming
  3. Glob the module's own components (if PBI module detected):
    • Search for existing page components in the module to understand the current UI layout patterns
    • Read 1-2 existing page templates to capture the actual look and feel (sidebar layout, toolbar patterns, card grids, etc.)
  4. Extract from discovered components:
    • Layout patterns: Sidebar + content, full-width, split-panel, tabbed
    • Common components: Table with pagination, filter bar, action buttons, status chips, breadcrumbs
    • Form patterns: Form groups, validation display, multi-step forms
    • Navigation: Tab bars, breadcrumbs, sidebar menus
  5. Map connected feature flows — identify every existing feature/screen that links to, embeds, includes, or navigates to/from this new screen; note the entry/exit flows so the mockup fits the surrounding navigation, not just a standalone page.

Key principle: Mimic existing system UI. If the project has a table with specific column patterns, use that pattern. If it has card-based layouts, use cards. The mockup should feel like it belongs in the existing application.

Step 3c: Load Domain Entity Context

Use real domain entities and relationships for realistic mockup data:

  1. Read docs/project-reference/domain-entities-reference.md (if exists) — extract entities, fields, relationships for the PBI's module
  2. From the PBI artifact, extract referenced entities from ## Domain Context section
  3. Use entity field names and types to generate realistic sample data in the mockup:
    • Entity names → table column headers, form field labels
    • Entity relationships → navigation links, dropdowns, nested displays
    • Entity statuses/enums → status badges, filter options
    • Date fields → realistic date values
    • String fields → domain-appropriate sample text (customer names, invoice titles, etc.)

Key principle: Sample data should use actual entity field names and realistic domain values — not "Lorem ipsum" or "Item 1, Item 2".

Step 4: Generate HTML Mockup

Generate a single self-contained HTML file with the following structure:

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Mockup: {PBI Title}</title>
        <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet" />
        <style>
            /* Design system tokens as CSS variables */
            /* Component styles matching project BEM conventions */
            /* Responsive breakpoints */
            /* Dark/light theme support */
        </style>
    </head>
    <body>
        <!-- PBI Header: title, description, metadata -->
        <!-- Navigation tabs (one per story) -->
        <!-- Story sections with mockup UI -->
        <!-- Component state toggles (default/loading/empty/error) -->
        <!-- Interactive prototype: screens/states + hotspots + demo control bar + explanation panel + "⚠ Simulated" banner -->
        <script>
            /* Tab navigation */
            /* State toggles */
            /* Theme toggle */
            /* Responsive preview toggle */
            /* Prototype engine: goTo(stateId) router + hotspots + simulated submit — see references/interactive-demo.md §2 */
            /* Guided walkthrough: ▶ Play ⏭ Next ⏮ Prev ↺ Reset ⏏ Exit — see references/interactive-demo.md §3 */
        </script>
    </body>
</html>

Interactive Prototype + Guided Walkthrough

The mock-up is a scripted clickable prototype of each planned flow (Step 2b), not a still image. For EVERY flow-spec, render the journey so a stakeholder can click through it and watch it narrate. Mechanics are delegated — do NOT inline the engine here:

  1. Screen/state router + hotspots — render each flow's screens/states as DOM sections and wire clickable hotspots that goTo the next state (references/interactive-demo.md §2). Simulated submit → success toast → in-memory row insert; NO real fetch/persistence/backend.
  2. Demo controls + guided walkthrough — a control bar (▶ Play · ⏭ Next · ⏮ Prev · ↺ Reset · ⏏ Exit) auto-/step-walks the flow, spotlighting the active hotspot (references/interactive-demo.md §3).
  3. Explanation panel + "⚠ Simulated" banner — a persistent panel names the current flow + step (n / total) + the step's plain-language explain; a visible "⚠ Simulated — illustrative data, no real actions are performed" banner is the scope guard (references/interactive-demo.md §4).
  4. Affordances + a11y — hotspots visibly highlighted (pulse/outline), disabled controls show a tooltip, demo never traps the user, prefers-reduced-motion respected (references/interactive-demo.md §5).

Scope guard: interactivity is scripted/simulated only (canned transitions, illustrative data) — never real auth, persistence, or backend calls; self-contained so it runs inside the deck's <iframe srcdoc> sandbox (references/interactive-demo.md §6).

HTML Structure Requirements

  1. Header Section:

    • PBI ID and title
    • Module badge
    • Priority badge — the PBI's priority label + numeric rank from frontmatter (e.g. "Priority: Must Have · Rank #2"). MANDATORY when the PBI carries priority/rank; the mockup MUST surface the same priority info as the backlog so stakeholders see it on the prototype itself. Omit only when the PBI genuinely has no priority assigned yet.
    • Story count summary
    • Generation date
  2. Navigation:

    • Tab bar with one tab per story (or section per PBI acceptance criteria)
    • Active tab highlight using design system primary color
  3. Story Panels:

    • Story title and description ("As a... I want... So that...")
    • Visual mockup of the UI described in wireframe/layout sections
    • Component placeholders with realistic sample data
    • State toggle buttons (Default | Loading | Empty | Error)
  4. Footer:

    • "Generated from PBI {ID}" attribution
    • Link back to artifact path
    • Generation timestamp

Styling Rules

  • Base every visual decision on the loaded project reference design docs; cite the docs used in the generation notes when reporting the mock-up.
  • Use CSS custom properties (variables) from design system tokens
  • Follow BEM naming: mockup__header, mockup__nav, mockup__panel
  • Match the project's color palette, typography, and spacing
  • Include both light and dark theme (toggle button in header)
  • Responsive: mobile (< 768px) and desktop layout
  • Use realistic placeholder data (names, dates, numbers) — not "Lorem ipsum"

Component Rendering

Map wireframe components to HTML elements AND to their scripted demo interaction (the hotspot/transition that advances the flow — references/interactive-demo.md §2):

Wireframe Component HTML Rendering Demo Interaction (scripted/simulated)
Table/Grid <table> with design system styles Row click → goTo detail screen/state
Form <form> with labeled inputs Submit → simulated success toast + in-memory row insert
Button <button> with primary/secondary variants Hotspot → advances the demo to the next screen/state
Card <div class="card"> with shadow Card click → goTo the card's detail screen/state
List <ul> or data list Item click → goTo selected-item screen/state
Modal/Dialog Overlay <div> (toggleable) Trigger → open dialog state; confirm/cancel → goTo next
Tab panel Tab navigation with content panels Tab → switch panel (no nav away)
Search/Filter Input with icon Apply → simulated filtered result state
Status badge <span> with color coding Non-interactive (illustrative state indicator)
Empty state Centered message with icon Primary CTA → goTo the create/first-action screen/state
Loading state Skeleton placeholder or spinner Transient → auto-advances to the loaded screen/state
Error state Error banner with message Retry → goTo back to the prior screen/state

Step 5: Save HTML File

  • Path: Same directory as the PBI artifact
  • Name: {pbi-filename-without-ext}-mockup.html
  • Example: team-artifacts/pbis/260324-pbi-goal-tracking-mockup.html

Step 6: Report to User

After generation, output:

Mockup generated: {path}
- PBI priority: {priority label} · Rank #{rank}  (or "not yet prioritized")
- Stories covered: {count}
- Demo flows: {count} ({flow titles})
- Components rendered: {list}
- States included: {default, loading, empty, error}
- Fidelity vs existing UI: PASS | FAIL
- Demo quality: PASS | FAIL

Open in browser to preview. Click highlighted hotspots or press ▶ Play to walk a flow. Use theme toggle for dark/light mode.

Step 7: [BLOCKING] Fidelity Validation — Mockup Matches Existing UI

[BLOCKING] After the HTML is generated, validate it faithfully matches the existing UI inventoried in Step 3b before handing off. Do NOT report the mockup as done until this validation records a result — a mockup that does not match the current system is not done.

Validate the produced mockup against the inventoried existing UI and record an explicit pass/fail:

  1. Design tokens — colors, typography, spacing match the project design system (Step 3).
  2. Component patterns — tables, forms, dialogs, status chips, and navigation reuse the existing component patterns (Step 3b), not generic HTML.
  3. Layout/structure — the screen layout matches the existing pages of the related feature (sidebar / toolbar / card-grid conventions).
  4. Connected flows — entry/exit navigation matches the connected feature flows mapped in Step 3b.

Record the outcome in the Step 6 report:

Fidelity vs existing UI: PASS | FAIL — tokens / components / layout / flows matched? If FAIL: what diverged + the fix.

If FAIL, revise the mockup to match the existing UI and re-validate before handoff.


Step 8: [BLOCKING] Demo-Quality Review Gate

[BLOCKING] This is the final review todo (Step 2b created it). After fidelity passes, audit the GENERATED interactive prototype's demo quality before handoff. Do NOT report the mock-up as done until this records a result — a prototype with a dead control or a flow that does not click through is not done. Full checklist: references/interactive-demo.md §7.

First, confirm the result SATISFIES the PBI's intent (not merely that it renders): every main user story in the PBI's ## Acceptance Criteria / ### Interaction Flow is represented by a flow-spec demo (coverage — no main story missing), AND each prototype faithfully demonstrates that story's intended behavior end-to-end. Then audit the produced prototype against every planned flow-spec and record an explicit pass/fail:

  1. Satisfies the PBI intent — every main-story/MVP flow from the acceptance criteria is present and its demo conveys the intended behavior; if a story has no demo or the demo misrepresents it, this gate FAILS regardless of the items below.
  2. Every main-story flow clicks end-to-end — each flow's steps[] reach its endState via real hotspots; no path dead-ends.
  3. No dead controls — every button/hotspot advances the demo or is visibly disabled-with-tooltip.
  4. Narration present + tech-agnostic — every step shows its plain-language explain; copy is business-language (M1/M2), not class names; the "⚠ Simulated — illustrative data, no real actions are performed" banner is visible on every flow.
  5. Opens offline standalone — no external <script src>; Google Fonts CSS only; no JS console errors.
  6. Real domain data — screens/rows use real entity field names + realistic values, never Lorem ipsum.
  7. iframe-safe — works self-contained inside an <iframe srcdoc> sandbox (no parent-document or network dependency) so the deck can embed it.

Record the outcome in the Step 6 report:

Demo quality: PASS | FAIL — satisfies PBI intent (every main story demoed + faithful) / flows click end-to-end / no dead controls / narration tech-agnostic + banner / offline / real data / iframe-safe? If FAIL: what broke + the fix.

If FAIL, fix the prototype (re-author from the flow-spec — cheap) and re-audit before handoff.


Mockup Quality Checklist

Before completing:

  • HTML file is self-contained (opens correctly without a server)
  • All stories from PBI are represented as sections/tabs
  • Every main-story flow (Step 2b) is rendered as a scripted clickable prototype with guided narration
  • Design is based on design-system-canonical.md plus the matched per-app design-system doc when available
  • Design system colors and typography match the project
  • Component states are toggleable (where defined in artifact)
  • Responsive layout works for mobile and desktop
  • Realistic placeholder data used (not Lorem ipsum)
  • PBI metadata shown in header (ID, title, module, date)
  • PBI priority shown in header (priority label + numeric rank from frontmatter) when the PBI is prioritized — the mockup carries the same priority info as the backlog
  • File saved alongside the PBI artifact
  • Fidelity validation (Step 7) recorded PASS — mockup matches existing UI tokens, components, layout, and connected flows
  • Demo-Quality gate (Step 8) recorded PASS — every flow clicks end-to-end, no dead controls, narration + "⚠ Simulated" banner present, offline, iframe-safe

Edge Cases

Scenario Handling
Backend-only PBI (no UI sections) Skip mockup, inform user
No stories yet (PBI only) Generate HTML mock-up from PBI's UI Layout section only
Multiple modules Load primary module's design system
No design system docs Use sensible defaults (Inter font, neutral palette)
Very large PBI (10+ stories) Group stories into categories, use collapsible sections

Anti-Patterns

Anti-Pattern Correct Approach
Production-quality CSS framework Simple inline CSS matching design tokens
External dependencies (CDN libs) Self-contained except Google Fonts
Pixel-perfect implementation Approximate visual representation
Real backend/business logic (auth, live API, persistence) Scripted/simulated prototype interactivity only — clickable nav, simulated transitions, guided demo; NO real business logic or data writes
Dead / non-wired buttons Every control either advances the demo or is visibly disabled-with-tooltip
Lorem ipsum placeholder text Realistic domain-specific sample data

Workflow Recommendation

MANDATORY IMPORTANT MUST ATTENTION — NO EXCEPTIONS: If you are NOT already in a workflow, you MUST ATTENTION use AskUserQuestion to ask the user. Do NOT judge task complexity or decide this is "simple enough to skip" — the user decides whether to use a workflow, not you:

  1. Activate workflow-idea-to-pbi workflow (Recommended) — includes mockup as final step
  2. Execute /pbi-mockup directly — run this skill standalone on an existing PBI

Next Steps

MANDATORY IMPORTANT MUST ATTENTION — NO EXCEPTIONS after completing this skill, you MUST ATTENTION use AskUserQuestion to present these options. Do NOT skip because the task seems "simple" or "obvious" — the user decides:

  • "/prioritize (Recommended)" — Prioritize the PBI in the backlog
  • "/design-spec" — Create detailed design specification from mockup
  • "/plan" — Start implementation planning
  • "Skip, continue manually" — user decides

[IMPORTANT] Use TaskCreate to break ALL work into small tasks BEFORE starting.

Evidence Gate: MANDATORY IMPORTANT MUST ATTENTION — every claim, finding, and recommendation requires file:line proof or traced evidence with confidence percentage (>80% to act, <80% must verify first).

[BLOCKING] Understand the existing UI before you design or spec a new/updated screen. Before producing any wireframe, mockup, screen design, or UI spec:

  1. Inventory existing related UI — search the project for screens, pages, and components already serving this feature or its domain (consult design-system docs + the real component inventory).
  2. Map connected flows — identify every feature that links to, embeds, includes, or navigates to/from the new screen; trace its entry and exit flows so the new screen fits them.
  3. Reuse before invent — prefer existing components, patterns, and layout conventions; justify any new component against what already exists.
  4. Record findings — note the matched existing screens/components + connected flows in the artifact so downstream design faithfully matches the current UI system.

Skip ONLY when the feature is backend-only (no UI) — state that explicitly.

AI Mistake Prevention — Failure modes to avoid on every task:

Re-read files after context changes. Context compaction, resume, or long-running work can make memory stale; verify current files before acting. Verify generated content against source evidence. AI hallucinates APIs, names, claims, and document facts. Check the relevant source before documenting or referencing. Check downstream references before deleting or renaming. Removing an artifact can stale docs, generated mirrors, configs, and callers; map references first. Trace the full impact chain after edits. Changing a definition can miss derived outputs and consumers. Follow the affected chain before declaring done. Verify ALL affected outputs, not just the first. One green check is not all green checks; validate every output surface the change can affect. Assume existing values are intentional — ask WHY before changing. Before changing a constant, limit, flag, wording, or pattern, read nearby context and history. Surface ambiguity before acting — don't pick silently. Multiple valid interpretations require an explicit question or stated assumption with risk. Keep shared guidance role-relevant. Universal guidance must help every receiving skill or agent; code-specific obligations belong only in code-specific protocols.

Critical Thinking Mindset — Apply critical thinking, sequential thinking. Every claim needs traced proof, confidence >80% to act. Anti-hallucination: Never present guess as fact — cite sources for every claim, admit uncertainty freely, self-check output for errors, cross-reference independently, stay skeptical of own confidence — certainty without evidence root of all hallucination.

MUST ATTENTION apply critical + sequential thinking — every claim needs appropriate traced evidence (file:line for repo/code claims; source URL or artifact section for research, product, content, and docs claims); confidence >80% to act, <60% DO NOT recommend. Anti-hallucination: never present guess as fact, admit uncertainty freely, cross-reference independently, stay skeptical of own confidence.

MUST ATTENTION apply AI mistake prevention — verify generated content against evidence, trace downstream references before deleting or renaming, verify all affected outputs, re-read files after context loss, and surface ambiguity before acting.

Prompt-Enhance Closing Anchors

IMPORTANT MUST ATTENTION follow declared step order for this skill; NEVER skip, reorder, or merge steps without explicit user approval IMPORTANT MUST ATTENTION for every step/sub-skill call: set in_progress before execution, set completed after execution IMPORTANT MUST ATTENTION every skipped step MUST include explicit reason; every completed step MUST include concise evidence IMPORTANT MUST ATTENTION if Task tools unavailable, maintain an equivalent step-by-step plan tracker with synchronized statuses

Closing Reminders

IMPORTANT MUST ATTENTION Goal: Give stakeholders a clickable, self-narrating MVP prototype of every story's main-flow UI — built from real domain data and the project's actual design system — before implementation begins, so layout/UX/flow/state gaps surface while changes are still cheap.

Protocols in force (concise digest of the SYNC/shared blocks this skill carries):

  • AI Mistake Prevention: verify generated content against evidence, trace downstream references, verify all affected outputs, re-read after context loss, surface ambiguity.
  • Critical Thinking: MUST ATTENTION traced proof per claim, confidence >80% to act, NEVER guess.

IMPORTANT MUST ATTENTION run ONLY on finalized PBIs/stories (reviewed, challenged, gated); for a backend-only PBI with no UI sections, SKIP generation and tell the user — never fabricate UI — why: a mock-up of an unfinished or UI-less PBI previews the wrong thing. IMPORTANT MUST ATTENTION PLAN the demo flows BEFORE generating — Step 2b enumerates the PBI's main-story/MVP flows into flow-specs and TaskCreates one todo per flow; Step 8 [BLOCKING] Demo-Quality gate signs off AFTER — why: think → plan → many todos → generate → final review is the discipline that makes the prototype complete and click-through-verified. IMPORTANT MUST ATTENTION render each main-story flow as a scripted clickable prototype with guided narration (▶ Play · ⏭ Next · ⏮ Prev · ↺ Reset · ⏏ Exit), an explanation panel, and a visible "⚠ Simulated — illustrative data, no real actions are performed" banner; interactivity is scripted/simulated only (canned transitions) — NEVER real fetch/auth/persistence/backend; self-contained so it runs inside the deck's <iframe srcdoc> (mechanics: references/interactive-demo.md §2–§4) — why: a clickable prototype conveys behavior at the lowest cost, but a real backend breaks the offline preview-before-code purpose. IMPORTANT MUST ATTENTION emit exactly ONE self-contained HTML file per PBI (all stories as tabs/sections), inline CSS/JS, no external deps except Google Fonts, saved as {pbi-filename}-mockup.html beside the PBI artifact — why: stakeholders open one file with no server, no build step.

IMPORTANT MUST ATTENTION render the PBI's priority in the header (priority label + numeric rank from frontmatter) whenever the PBI is prioritized — why: the mockup is a stakeholder-facing prototype and MUST carry the same priority info as the backlog, not just the title; downstream feature-presentation reuses it.

MANDATORY IMPORTANT MUST ATTENTION break work into small todo tasks using TaskCreate BEFORE starting; add a final review todo to verify quality. MANDATORY IMPORTANT MUST ATTENTION validate route/next-step decisions with the user via AskUserQuestion — never auto-decide complexity for the user.

Domain rules this skill must not skip:

IMPORTANT MUST ATTENTION fidelity is the whole point — the mock-up must LOOK like the existing app: load the mandatory baseline + matched per-app design-system docs (NEW→designSystem.canonicalDoc, REFACTOR→matched designSystem.appMappings per-app doc), read real shared/module components for layout patterns — why: a generic-HTML mock-up previews a system that does not exist. IMPORTANT MUST ATTENTION populate with real domain entity field names and realistic sample data — NEVER Lorem ipsum or "Item 1, Item 2" — why: fake data hides the real layout/overflow/state gaps the preview exists to surface. IMPORTANT MUST ATTENTION render every defined component state (default/loading/empty/error) as a toggleable view — why: stakeholders must see how the UI degrades, not only the happy path. IMPORTANT MUST ATTENTION keep all accompanying prose/captions/notes tech-agnostic (business/observable terms, NOT framework or CSS class names) per the M1/M2 mandates in .claude/skills/shared/sdd-artifact-contract.md; the rendered HTML MAY use real class names internally (implementation, not prose) — why: tech-coupled descriptions break the spec-principles §3 contract while the rendered markup stays free to be concrete. IMPORTANT MUST ATTENTION read design-system docs, existing components, and domain-entities reference (docs/project-reference/*) BEFORE generating — grep/read 2-3 real components first — why: skipping the read produces a mock-up that looks nothing like the app.

IMPORTANT MUST ATTENTION cite file:line evidence for every claim/finding (confidence >80% to act, <80% verify first) — NEVER speculate about entity fields, design tokens, or component patterns without reading the source — why: hallucinated fields and class names produce a misleading preview.

Anti-Rationalization:

Evasion Rebuttal
"PBI looks ready, skip the gated/finalized check" Run only on reviewed-and-gated PBIs. An unfinished PBI previews the wrong thing.
"A static mockup is faster than a clickable one" Static conveys layout only, not behavior — the user asked for an MVP demo. Render each flow as a scripted clickable prototype (regenerated from the §1 flow-spec — cheap).
"Skip the flow planning, just generate" Step 2b (flow-specs + one todo per flow) is BLOCKING; planning the journeys first is what makes the prototype complete and click-through-verifiable.
"Wire it to a real endpoint so it feels real" Interactivity is scripted/simulated only — canned transitions, illustrative data, "⚠ Simulated" banner. NO real fetch/auth/persistence/backend.
"Lorem ipsum is faster" Fake data hides real overflow/state gaps. Use real entity field names + realistic values.
"Generic clean HTML is good enough" Fidelity is the point — read design-system docs + 2-3 real components, mimic the actual UI.
"Class names in the notes are fine" Prose stays tech-agnostic (M1/M2). Real class names live in the rendered HTML, not captions.
"Only need the default state" Render every defined state (default/loading/empty/error) as toggleable.
"Already know the entity fields" Show file:line from the domain-entities reference. No proof = no read.

[TASK-PLANNING] Before acting, analyze task scope and systematically break it into small todo tasks and sub-tasks using TaskCreate.

IMPORTANT MUST ATTENTION Goal: clickable, self-narrating MVP prototype of every story's main-flow UI from real domain data + the actual design system, BEFORE implementation — so flow/UX/state gaps surface while cheap. IMPORTANT MUST ATTENTION PLAN flows first (Step 2b flow-specs + one todo per flow), then the Demo-Quality gate signs off (Step 8); each flow is a scripted clickable prototype with guided narration + "⚠ Simulated" banner — interactivity scripted/simulated only, NEVER real backend. IMPORTANT MUST ATTENTION ONE self-contained HTML per PBI (Google Fonts only), real domain data not Lorem ipsum, every component state toggleable, prose tech-agnostic (M1/M2). IMPORTANT MUST ATTENTION read design-system docs + real components + domain-entities reference first; cite file:line (>80% confidence) — NEVER guess fields or tokens.

Install via CLI
npx skills add https://github.com/duc01226/easy-claude --skill pbi-mockup
Repository Details
star Stars 1
call_split Forks 0
navigation Branch main
article Path SKILL.md
More from Creator