blueprint-plugin/skills/document-detection/SKILL.md
Detect PRD/ADR/PRP opportunities in conversations and prompt for document creation. Use when the user discusses feature requirements, tech trade-offs, or implementation plans.
npx skillsauth add laurigates/claude-plugins document-detectionInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Proactively identify when conversations should become structured documents (PRDs, ADRs, or PRPs) and guide users through the documentation workflow.
| Use this skill when... | Use blueprint-derive-plans instead when... | |---|---| | Mid-conversation cues suggest a PRD/ADR/PRP should be captured | You're explicitly deriving plans (PRDs/ADRs/PRPs) from existing README/docs and git history | | The user says "I want to build...", "users should be able to..." | Use blueprint-derive-plans instead when the cue is a tech-choice decision worth an ADR | | The user compares trade-offs ("should we use X or Y?") | Use document-linking instead to wire IDs across already-created docs | | Implementation scope is being discussed and warrants a PRP | Use blueprint-prp-create instead when you've already decided to author a PRP |
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-plans 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-plans.
Launch appropriate documentation command:
For PRD:
Run /blueprint:derive-plans with context:
- Feature description from conversation
- User types identified
- Requirements enumerated
- Success criteria discussed
For ADR:
Run /blueprint:derive-plans 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-plans | docs/prds/{feature-name}.md |
| ADR | /blueprint:derive-plans | 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 |
tools
Scaffold a new ComfyUI custom-node repo (pyproject, CI, release-please, vitest+pytest, JS extension skeleton) in the picker/gesture vein. Use when bootstrapping or init-ing a comfyui node pack.
tools
Orchestrate a ComfyUI node pack from idea to registry: scaffold, create + seed the repo, open the gitops adoption PR. Use when releasing or spinning up a new comfyui node pack.
testing
macOS EndpointSecurity/EDR high CPU & battery drain. Use when Kandji ESF / XProtect pegs a core; trace the exec storm via powermetrics + eslogger.
development
odiff pixel-by-pixel image diffing. Use when comparing screenshots, detecting visual regressions, diffing before/after PNGs, asserting golden images.