From rav-town
Convert PRDs to prd.json format for the Ralph autonomous agent system. Use when you have an existing PRD and need to convert it to Ralph's JSON format. Triggers on: convert this prd, turn this into ralph format, create prd.json from this, ralph json.
How this skill is triggered — by the user, by Claude, or both
Slash command
/rav-town:ralph-prdThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Converts existing PRDs to the prd.json format that Ralph uses for autonomous execution.
Converts existing PRDs to the prd.json format that Ralph uses for autonomous execution.
Take a PRD markdown file from docs/prds/ and convert it to a prd-<date>-<feature-name>.json in the same directory.
The suffix is derived from the source PRD filename. For example, prd-2026-03-15-task-status.md produces prd-2026-03-15-task-status.json.
Also initialize a corresponding progress-<date>-<feature-name>.txt file in the same directory.
{
"project": "[Project Name]",
"branchName": "ralph/[feature-name-kebab-case]",
"description": "[Feature description from PRD title/intro]",
"dependsOn": [],
"userStories": [
{
"id": "US-001",
"title": "[Story title]",
"description": "As a [user], I want [feature] so that [benefit]",
"acceptanceCriteria": [
"Criterion 1",
"Criterion 2",
"Typecheck passes"
],
"priority": 1,
"passes": false,
"notes": ""
}
]
}
Each story must be completable in ONE Ralph iteration (one context window).
Ralph spawns a fresh Copilot instance per iteration with no memory of previous work. If a story is too big, the LLM runs out of context before finishing and produces broken code.
Rule of thumb: If you cannot describe the change in 2-3 sentences, it is too big.
Stories execute in priority order. Earlier stories must not depend on later ones.
Correct order:
Wrong order:
Each criterion must be something Ralph can CHECK, not something vague.
status column to tasks table with default 'pending'""Typecheck passes"
For stories with testable logic, also include:
"Tests pass"
"Verify in browser using dev-browser skill"
Frontend stories are NOT complete until visually verified. Ralph will use the dev-browser skill to navigate to the page, interact with the UI, and confirm changes work.
passes: false and empty notesralph/. For example, source file prd-2026-03-15-task-status.md → branchName: "ralph/task-status"## Dependencies section from the source PRD. Map each listed PRD filename to its corresponding branch name (e.g., prd-2026-03-15-friend-search.md → ralph/friend-search). If no dependencies, use an empty array [].prd-<date>-<feature-name>.json — matching the source PRD filename suffix (e.g., prd-2026-03-15-task-status.md → prd-2026-03-15-task-status.json)docs/prds/)If a PRD has big features, split them:
Original:
"Add user notification system"
Split into:
Each is one focused change that can be completed and verified independently.
Input PRD (docs/prds/prd-2026-03-15-task-status.md):
# Task Status Feature
Add ability to mark tasks with different statuses.
## Requirements
- Toggle between pending/in-progress/done on task list
- Filter list by status
- Show status badge on each task
- Persist status in database
Output (docs/prds/prd-2026-03-15-task-status.json):
{
"project": "TaskApp",
"branchName": "ralph/task-status",
"description": "Task Status Feature - Track task progress with status indicators",
"dependsOn": [],
"userStories": [
{
"id": "US-001",
"title": "Add status field to tasks table",
"description": "As a developer, I need to store task status in the database.",
"acceptanceCriteria": [
"Add status column: 'pending' | 'in_progress' | 'done' (default 'pending')",
"Generate and run migration successfully",
"Typecheck passes"
],
"priority": 1,
"passes": false,
"notes": ""
},
{
"id": "US-002",
"title": "Display status badge on task cards",
"description": "As a user, I want to see task status at a glance.",
"acceptanceCriteria": [
"Each task card shows colored status badge",
"Badge colors: gray=pending, blue=in_progress, green=done",
"Typecheck passes",
"Verify in browser using dev-browser skill"
],
"priority": 2,
"passes": false,
"notes": ""
},
{
"id": "US-003",
"title": "Add status toggle to task list rows",
"description": "As a user, I want to change task status directly from the list.",
"acceptanceCriteria": [
"Each row has status dropdown or toggle",
"Changing status saves immediately",
"UI updates without page refresh",
"Typecheck passes",
"Verify in browser using dev-browser skill"
],
"priority": 3,
"passes": false,
"notes": ""
},
{
"id": "US-004",
"title": "Filter tasks by status",
"description": "As a user, I want to filter the list to see only certain statuses.",
"acceptanceCriteria": [
"Filter dropdown: All | Pending | In Progress | Done",
"Filter persists in URL params",
"Typecheck passes",
"Verify in browser using dev-browser skill"
],
"priority": 4,
"passes": false,
"notes": ""
}
]
}
Each PRD gets its own uniquely-named files. The suffix matches the source PRD filename pattern <date>-<feature-name>:
docs/prds/prd-<date>-<feature-name>.jsondocs/prds/progress-<date>-<feature-name>.txtWhere <date> is YYYY-MM-DD and <feature-name> is kebab-case.
Example:
docs/prds/prd-2026-03-15-task-status.mddocs/prds/prd-2026-03-15-task-status.jsondocs/prds/progress-2026-03-15-task-status.txtralph/task-statusAfter saving the prd.json, initialize the progress file:
# Ralph Progress Log — <feature name>
Started: <current date>
---
Before writing prd.json, verify:
dependsOn correctly maps PRD dependencies to branch namesprd-<date>-<feature-name>.json (matching source PRD suffix)docs/prds/progress-<date>-<feature-name>.txt is initialized in docs/prds/npx claudepluginhub patelr3/agents --plugin rav-townConverts PRDs to prd.json for Ralph autonomous agent, splitting into small, dependency-ordered user stories with verifiable acceptance criteria.
Converts PRDs from markdown files or text to prd.json format for Ralph autonomous agent system. Useful for transforming existing PRDs into Ralph's structured JSON with schema-defined features, categories, and acceptance criteria.
Generates PRDs from task descriptions, manages parallel story execution with dependency resolution, and provides context-filtered agents for multi-story development.