From blueprint-plugin
Detects PRD/ADR/PRP opportunities in conversations about features, architecture decisions, or implementation planning and prompts for document creation via blueprint workflow.
npx claudepluginhub laurigates/claude-plugins --plugin blueprint-pluginThis skill is limited to using the following tools:
Proactively identify when conversations should become structured documents (PRDs, ADRs, or PRPs) and guide users through the documentation workflow.
Creates isolated Git worktrees for feature branches with prioritized directory selection, gitignore safety checks, auto project setup for Node/Python/Rust/Go, and baseline verification.
Executes implementation plans in current session by dispatching fresh subagents per independent task, with two-stage reviews: spec compliance then code quality.
Dispatches parallel agents to independently tackle 2+ tasks like separate test failures or subsystems without shared state or dependencies.
Proactively identify when conversations should become structured documents (PRDs, ADRs, or PRPs) and guide users through the documentation workflow.
This skill is loaded when conversation context suggests documentation opportunities:
Document detection requires:
docs/blueprint/manifest.json exists)has_document_detection: true in manifest structuredocs/ directory structure createdCheck prerequisites before prompting:
# Verify blueprint is initialized with document detection enabled
jq -r '.structure.has_document_detection // false' docs/blueprint/manifest.json 2>/dev/null
Primary triggers (confidence +0.5 each):
Confidence boosters (+0.1-0.2 each):
Example triggers:
"I want to build a user authentication system with OAuth2 support, password reset, and MFA"
"As an admin, I want to manage user permissions so that I can control access"
"We need to implement: 1) user registration, 2) email verification, 3) profile management"
Primary triggers (confidence +0.5 each):
Confidence boosters (+0.1-0.2 each):
Example triggers:
"Should we use PostgreSQL or MongoDB for the user data? We need to consider query patterns and scalability"
"The pros of using microservices are scalability and team independence, but the cons are operational complexity"
"Why did we choose React over Vue? Let me document the decision"
Primary triggers (confidence +0.5 each):
Confidence boosters (+0.1-0.2 each):
Example triggers:
"Let's implement the payment processing module with Stripe integration"
"We need to create PaymentService.ts, add routes in /api/payments, and write integration tests"
"Time to build the dashboard - it needs charts, filters, and export functionality"
Threshold for prompting: >= 0.7
Base confidence: 0.0
+ Primary trigger matched: +0.5
+ Additional primary trigger: +0.3
+ Each booster matched: +0.1 to +0.2
Total >= 0.7 → Prompt user
Total < 0.7 → Continue without prompting
Examples:
When confidence >= 0.7, execute this flow:
Use AskUserQuestion to confirm document creation:
question: "This looks like a [PRD/ADR/PRP] opportunity. Would you like to document it?"
options:
- label: "Yes, create [document type]"
description: "I'll gather context and create the document"
- label: "Add to backlog"
description: "Record this topic for later documentation"
- label: "Not now, remind me later"
description: "Continue conversation, prompt again if topic expands"
- label: "No, just continue"
description: "Skip documentation for this topic"
For ADR opportunities, append the decision topic to the Proposed ADRs section in docs/adrs/README.md:
docs/adrs/README.md exists (create from template if missing)- [ ] {Decision topic} — {brief context from conversation} (identified {YYYY-MM-DD})
_No proposed ADRs at this time._ placeholder if present/blueprint:derive-adr when ready to document it fully."For PRD/PRP opportunities, note the topic in the conversation and suggest revisiting later. No persistent backlog file exists for these types yet.
Ask context-specific questions based on document type:
For PRD:
question: "Who are the primary users for this feature?"
options:
- label: "End users"
description: "Regular users of the application"
- label: "Administrators"
description: "Admin users with elevated access"
- label: "Developers"
description: "Internal development team"
- label: "Multiple types"
description: "I'll specify the user types"
For ADR:
question: "What constraints should I consider for this decision?"
options:
- label: "Performance requirements"
description: "Speed, latency, throughput constraints"
- label: "Team expertise"
description: "Team familiarity with technologies"
- label: "Budget/cost"
description: "Financial or resource constraints"
- label: "Timeline"
description: "Delivery deadline constraints"
- label: "All of the above"
description: "Consider all constraint types"
For PRP:
question: "What's the priority and scope for this implementation?"
options:
- label: "High priority, narrow scope"
description: "MVP implementation, ship quickly"
- label: "High priority, full scope"
description: "Complete implementation needed soon"
- label: "Normal priority"
description: "Standard development timeline"
- label: "Exploratory"
description: "Spike or proof of concept"
Extract from conversation:
docs/prds/, docs/adrs/, docs/prps/)For ADR: Infer Domain
Map discussion topics to ADR domains:
| Topic Keywords | Inferred Domain |
|---|---|
| Redux, Zustand, MobX, useState, signals, store | state-management |
| Prisma, Drizzle, PostgreSQL, MongoDB, ORM, database | data-layer |
| REST, GraphQL, tRPC, OpenAPI, endpoints, API | api-design |
| OAuth, JWT, auth0, session, tokens, login | authentication |
| Vitest, Jest, Playwright, Cypress, coverage, testing | testing |
| Tailwind, styled-components, CSS modules, SCSS | styling |
| React, Vue, Svelte, Next.js, Nuxt, Angular | frontend-framework |
| Vite, Webpack, esbuild, turbopack, bundler | build-tooling |
| Docker, Kubernetes, Vercel, serverless, deploy | deployment |
| Sentry, DataDog, logging, metrics, monitoring | monitoring |
Include inferred domain in context package for /blueprint:derive-adr.
Launch appropriate documentation command:
For PRD:
Run /blueprint:derive-prd with context:
- Feature description from conversation
- User types identified
- Requirements enumerated
- Success criteria discussed
For ADR:
Run /blueprint:derive-adr with context:
- Decision being made
- Options compared
- Constraints identified
- Trade-offs discussed
- Inferred domain (for conflict analysis)
For PRP:
Run /blueprint:prp-create with context:
- Feature scope
- Implementation approach
- Test strategy discussed
- Files/components planned
After document creation:
docs/prds/, docs/adrs/, or docs/prps/)/blueprint:generate-rules to create implementation patterns"/blueprint:prp-execute when ready to implement"To avoid duplicate prompts, track detected topics:
Track declined topics: Don't re-prompt for explicitly declined documentation Track deferred topics: Re-prompt if significant new context is added (new requirements, new trade-offs, etc.) Track created documents: Don't re-prompt for topics with existing documents
Session tracking uses conversation memory - no persistent storage needed.
Document detection integrates with existing commands:
| Detection Type | Command Triggered | Document Location |
|---|---|---|
| PRD | /blueprint:derive-prd | docs/prds/{feature-name}.md |
| ADR | /blueprint:derive-adr | docs/adrs/{number}-{title}.md |
| PRP | /blueprint:prp-create | docs/prps/{feature-name}.md |
Document detection is controlled by manifest flag:
{
"structure": {
"has_document_detection": true
}
}
Enable during /blueprint:init or /blueprint:upgrade.
To minimize interruptions:
| Document | Key Triggers | Confidence Threshold |
|---|---|---|
| PRD | Feature descriptions, user stories, requirements lists | >= 0.7 |
| ADR | Technology comparisons, trade-off discussions, "why" questions | >= 0.7 |
| PRP | Implementation intent, file planning, specific feature scope | >= 0.7 |
| User Response | Action |
|---|---|
| "Yes, create" | Gather clarification, delegate to command |
| "Not now" | Track topic, re-prompt if expanded |
| "No, continue" | Mark declined, never re-prompt |