بنقرة واحدة
policyengine-dashboard-workflow
Reference for the /create-dashboard and /deploy-dashboard orchestrated AI workflow
التثبيت باستخدام Codex أو Claude انسخ هذا Prompt والصقه في Codex أو Claude أو مساعد آخر ليراجع صفحة Skill ويثبّتها لك.
القائمة
Reference for the /create-dashboard and /deploy-dashboard orchestrated AI workflow
التثبيت باستخدام Codex أو Claude انسخ هذا Prompt والصقه في Codex أو Claude أو مساعد آخر ليراجع صفحة Skill ويثبّتها لك.
استنادا إلى تصنيف SOC المهني
Recharts chart patterns, formatting, and styling for PolicyEngine apps
PolicyEngine code writing style guide - formula optimization, direct returns, eliminating unnecessary variables
PolicyEngine parameter patterns - YAML structure, naming conventions, metadata requirements, federal/state separation
PolicyEngine code review patterns - validation checklist, common issues, review standards
PolicyEngine testing patterns - YAML test structure, naming conventions, period handling, and quality standards
PolicyEngine variable patterns - variable creation, no hard-coding principle, federal/state separation, metadata standards
| name | policyengine-dashboard-workflow |
| description | Reference for the /create-dashboard and /deploy-dashboard orchestrated AI workflow |
How to use the orchestrated AI workflow for creating PolicyEngine dashboards from natural-language descriptions.
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.
| 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 |
| 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 |
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)
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 until status: COMPLETEDresult from completed responseAvailable 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.
Use only when the dashboard needs something v2 alpha cannot provide:
Pattern: FastAPI on Modal with policyengine-us or policyengine-uk packages.
The plan MUST document why v2 alpha is insufficient before selecting this pattern.
| 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.
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.
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>
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 }]
All dashboards are built to embed in policyengine.org via iframe:
#country= from URL hashpostMessage to parentpolicyengine.org/{country}/{slug}, not Vercel URLSee policyengine-interactive-tools-skill for full embedding documentation.
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.
After the user merges the feature branch to main:
/deploy-dashboard
This handles:
When the API v2 alpha is production-ready, an alignment agent will:
api_v2_integration sectionclient.ts with real v2 alpha HTTP callsThis is a planned future addition, not yet implemented.