Agent skill
policyengine-dashboard-workflow
Reference for the /create-dashboard and /deploy-dashboard orchestrated AI workflow
Install this agent skill to your Project
npx add-skill https://github.com/PolicyEngine/policyengine-claude/tree/main/skills/tools-and-apis/policyengine-dashboard-workflow-skill
SKILL.md
PolicyEngine Dashboard Workflow
How to use the orchestrated AI workflow for creating PolicyEngine dashboards from natural-language descriptions.
Overview
The dashboard workflow is a multi-agent pipeline that takes a few paragraphs describing a desired dashboard and produces a working, deployable application in a new GitHub repository.
Commands
| Command | Purpose |
|---|---|
/create-dashboard |
Full pipeline: init repo → plan → scaffold → implement → validate → review → commit |
/deploy-dashboard |
Deploy a completed dashboard to Vercel (and optionally Modal) |
/dashboard-overview |
List all dashboard builder ecosystem components |
Agents
| Agent | Phase | Role |
|---|---|---|
dashboard-planner |
1 | Produces structured plan YAML from description |
dashboard-scaffold |
2 | Generates Next.js + Tailwind project structure into the current repo |
backend-builder |
3 | Builds API stubs or custom Modal backend |
frontend-builder |
3 | Builds React components with Tailwind + ui-kit design tokens |
dashboard-integrator |
4 | Wires frontend to backend, handles data flow |
dashboard-build-validator |
5 | Runs build and test suite |
dashboard-design-validator |
5 | Checks design tokens, typography, sentence case, responsive |
dashboard-architecture-validator |
5 | Checks Tailwind v4, Next.js, ui-kit, package manager |
dashboard-plan-validator |
5 | Checks API contract, components, embedding, states vs plan |
dashboard-overview-updater |
Post | Updates dashboard-overview command if ecosystem changed |
Workflow Phases
Phase 0: Init repo (or use existing with --repo/--skip-init)
Phase 1: Plan ──→ [HUMAN APPROVAL] ──→ Phase 2: Scaffold + quality gates
──→ Phase 3: Implement (backend + frontend IN PARALLEL)
──→ Phase 4: Integrate
──→ Phase 5: Validate (4 validators in parallel) ──→ [fix loop, max 3 cycles]
──→ Phase 6: [HUMAN REVIEW] ──→ commit and push
──→ Phase 7: Update overview (silent)
Separately: /deploy-dashboard (after user merges to main)
Data Patterns
API v2 Alpha (default)
The dashboard is built against the PolicyEngine API v2 alpha interface. During development, the backend-builder creates typed stubs that return fixture data matching the v2 alpha response shapes.
When v2 alpha alignment agent is built (future): Stubs will be replaced with real API calls using the async job pattern:
POST /endpoint→ returns{ job_id, status }GET /endpoint/{job_id}→ poll untilstatus: COMPLETED- Extract
resultfrom completed response
Available v2 alpha endpoints (from DESIGN.md):
| Endpoint | Purpose |
|---|---|
POST /simulate/household |
Single household calculation |
POST /simulate/economy |
Population simulation |
POST /analysis/decile-impact/economy |
Income decile breakdown |
POST /analysis/budget-impact/economy |
Tax/benefit programme totals |
POST /analysis/winners-losers/economy |
Who gains and loses |
POST /analysis/compare/economy |
Multi-scenario comparison |
POST /analysis/compare/household |
Household scenario comparison |
Switching from stubs to real API: Set NEXT_PUBLIC_API_V2_URL environment variable. The client code checks this and switches from fixture returns to real HTTP calls.
Custom Backend (escape hatch)
Use only when the dashboard needs something v2 alpha cannot provide:
- Custom reform parameters not exposed by the API
- Non-standard entity structures
- Combining PolicyEngine with external models
- Microsimulation with custom reform configurations
Pattern: FastAPI on Modal with policyengine-us or policyengine-uk packages.
The plan MUST document why v2 alpha is insufficient before selecting this pattern.
Tech Stack (fixed)
| Layer | Technology | Source |
|---|---|---|
| Framework | Next.js (App Router) + React 19 + TypeScript | Fixed |
| UI tokens | @policyengine/ui-kit/theme.css |
Single CSS import |
| Styling | Tailwind CSS v4 with ui-kit theme | Fixed |
| Font | Inter (via next/font/google) |
Fixed |
| Charts | Recharts | Following app-v2 patterns |
| Maps | react-plotly.js | Following app-v2 patterns |
| Data fetching | TanStack React Query | Fixed |
| Testing | Vitest + React Testing Library | Fixed |
| Deployment | Vercel (frontend) + Modal (backend) | Fixed |
See policyengine-frontend-builder-spec-skill for the full mandatory technology specification.
Design Token Usage
All visual values come from @policyengine/ui-kit/theme.css, accessed via Tailwind utility classes:
// Colors — use Tailwind semantic classes from ui-kit theme
<div className="bg-teal-500 text-white"> {/* Primary teal */}
<div className="hover:bg-teal-600"> {/* Hover state */}
<span className="text-foreground"> {/* Body text */}
<span className="text-muted-foreground"> {/* Muted text */}
<div className="bg-background"> {/* Backgrounds */}
<div className="border border-border"> {/* Borders */}
// Spacing — standard Tailwind classes
<div className="p-4 gap-3 m-6">
// Typography (font sizes from ui-kit theme — use standard text-xs, text-sm, etc.)
<span className="font-sans text-sm font-medium">
// Border radius
<div className="rounded-lg">
Never hardcode hex colors, pixel spacing, or font values. The Phase 5 validators check for violations.
Chart Patterns
Charts use CSS variables directly from the ui-kit theme:
// Standard Recharts pattern
import { LineChart, Line, XAxis, YAxis, CartesianGrid, Tooltip, ResponsiveContainer } from 'recharts';
<ResponsiveContainer width="100%" height={400}>
<LineChart data={data}>
<CartesianGrid strokeDasharray="3 3" stroke="var(--border)" />
<XAxis dataKey="x" tickFormatter={formatCurrency} />
<YAxis tickFormatter={formatCurrency} />
<Tooltip contentStyle={{ background: 'var(--background)', border: '1px solid var(--border)' }} />
<Line type="monotone" dataKey="income_tax" stroke="var(--chart-1)" />
</LineChart>
</ResponsiveContainer>
Plan YAML Schema
The plan is the contract between the planner and all other agents:
dashboard:
name: string # kebab-case, becomes repo name
title: string # Human-readable title
description: string # One paragraph
country: string # us, uk, or both
audience: string # public, researchers, legislators, internal
data_pattern: string # api-v2-alpha or custom-backend
api_v2_integration: # Only if api-v2-alpha
endpoints_needed: [{ endpoint, purpose, variables_requested }]
stub_fixtures: [{ name, description, expected_outputs }]
custom_backend: # Only if custom-backend
reason: string # WHY v2 alpha is insufficient
framework: string
policyengine_package: string
endpoints: [{ name, method, inputs, outputs, policyengine_variables }]
tech_stack: # Fixed values, included for documentation
framework: react-nextjs
ui: "@policyengine/ui-kit"
styling: tailwind-with-ui-kit-theme
charts: recharts
testing: vitest
components: # What to build
- type: input_form | chart | metric_card | data_table
id: string
# Type-specific fields...
embedding:
register_in_apps_json: boolean
display_with_research: boolean
slug: string
tags: string[]
tests:
api_tests: [{ name, description, input, expected }]
frontend_tests: [{ name, description }]
design_compliance: [{ name, description }]
embedding_tests: [{ name, description }]
Embedding
All dashboards are built to embed in policyengine.org via iframe:
- Country detection: Read
#country=from URL hash - Hash sync: Update hash on input change,
postMessageto parent - Share URLs: Point to
policyengine.org/{country}/{slug}, not Vercel URL - Country toggle: Hidden when embedded (country comes from route)
See policyengine-interactive-tools-skill for full embedding documentation.
Validation Checklist
Phase 5 runs four validators in parallel:
Build validator: Build compiles, all tests pass.
Design validator: No hardcoded colors/spacing/fonts, no pe-* classes, no getCssVar, Inter font loaded, sentence case headings, responsive at 768px and 480px, chart ResponsiveContainer wrappers.
Architecture validator: Tailwind CSS v4 (@import "tailwindcss", no config files), Next.js App Router (no Vite, no Pages Router), @policyengine/ui-kit installed and imported, bun as package manager.
Plan validator: API contract matches plan, all plan components implemented, embedding features (country detection, hash sync, share URLs), loading and error states handled.
Deployment
After the user merges the feature branch to main:
/deploy-dashboard
This handles:
- Vercel frontend deployment
- Modal backend deployment (if custom-backend)
- Registration in policyengine-app-v2's apps.json (via PR)
- Smoke testing
Future: API v2 Alpha Alignment
When the API v2 alpha is production-ready, an alignment agent will:
- Read the plan's
api_v2_integrationsection - Replace stub functions in
client.tswith real v2 alpha HTTP calls - Implement the async job polling pattern
- Run the full validation suite against live API responses
- Update fixture data with real response shapes
This is a planned future addition, not yet implemented.
Didn't find tool you were looking for?