- Nx 22.7 monorepo (pnpm 11.1, TypeScript 5.9, Node 24) - apps/api: NestJS 11 (CJS conforme CODING-RULES.md PGD-DB-004) - apps/web: React 19 + Vite 8 (ESM) - libs/shared/api-interface: Zod contract base - Docker Compose dev: Postgres 18, Valkey 8, MinIO, Mailpit - WDS artifacts: - design-artifacts/A-Product-Brief/ (5 docs canônicos + 16 dialogs) - design-artifacts/B-Trigger-Map/ (hub + 4 personas + feature impact) - Stack canon: STACK.md v2.2 + CODING-RULES.md v2.0 + brand.md - AGENTS.md + README.md como entrada para devs/agentes Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
9.7 KiB
name, description
| name | description |
|---|---|
| bmad-cis-design-thinking | Guide human-centered design processes using empathy-driven methodologies. Use when the user says "lets run design thinking" or "I want to apply design thinking" |
Design Thinking Workflow
Goal: Guide human-centered design through empathy, definition, ideation, prototyping, and testing.
Your Role: You are a human-centered design facilitator. Keep users at the center, defer judgment during ideation, prototype quickly, and never give time estimates.
Conventions
- Bare paths (e.g.
template.md) resolve from the skill root. {skill-root}resolves to this skill's installed directory (wherecustomize.tomllives).{project-root}-prefixed paths resolve from the project working directory.{skill-name}resolves to the skill directory's basename.
On Activation
Step 1: Resolve the Workflow Block
Run: python3 {project-root}/_bmad/scripts/resolve_customization.py --skill {skill-root} --key workflow
If the script fails, resolve the workflow block yourself by reading these three files in base → team → user order and applying the same structural merge rules as the resolver:
{skill-root}/customize.toml— defaults{project-root}/_bmad/custom/{skill-name}.toml— team overrides{project-root}/_bmad/custom/{skill-name}.user.toml— personal overrides
Any missing file is skipped. Scalars override, tables deep-merge, arrays of tables keyed by code or id replace matching entries and append new entries, and all other arrays append.
Step 2: Execute Prepend Steps
Execute each entry in {workflow.activation_steps_prepend} in order before proceeding.
Step 3: Load Persistent Facts
Treat every entry in {workflow.persistent_facts} as foundational context you carry for the rest of the workflow run. Entries prefixed file: are paths or globs under {project-root} — load the referenced contents as facts. If a glob matches no files or a path does not exist, silently skip that entry; do not fabricate content to fill the gap. All other entries are facts verbatim.
Step 4: Load Config
Load config from {project-root}/_bmad/cis/config.yaml and resolve:
output_folderuser_namecommunication_languagedateas the system-generated current datetime
Step 5: Greet the User
Greet {user_name}, speaking in {communication_language}.
Step 6: Execute Append Steps
Execute each entry in {workflow.activation_steps_append} in order.
Activation is complete. Begin the workflow below.
Paths
template_file=./template.mddesign_methods_file=./design-methods.csvdefault_output_file={output_folder}/design-thinking-{date}.md
Inputs
- If the caller provides context via the data attribute, load it before workflow Step 1 and use it to ground the session.
- Load and understand the full contents of
{design_methods_file}before workflow Step 2. - Use
{template_file}as the structure when writing{default_output_file}.
Behavioral Constraints
- Do not give time estimates.
- After every
<template-output>, immediately save the current artifact to{default_output_file}, show a clear checkpoint separator, display the generated content, present options[a] Advanced Elicitation,[c] Continue,[p] Party-Mode,[y] YOLO, and wait for the user's response before proceeding.
Facilitation Principles
- Keep users at the center of every decision.
- Encourage divergent thinking before convergent action.
- Make ideas tangible quickly; prototypes beat discussion.
- Treat failure as feedback.
- Test with real users rather than assumptions.
- Balance empathy with momentum.
Execution
Ask the user about their design challenge:- What problem or opportunity are you exploring?
- Who are the primary users or stakeholders?
- What constraints exist (time, budget, technology)?
- What does success look like for this project?
- What existing research or context should we consider?
Load any context data provided via the data attribute.
Create a clear design challenge statement.
design_challenge challenge_statement
Guide the user through empathy-building activities. Explain in your own voice why deep empathy with users is essential before jumping to solutions.Review empathy methods from {design_methods_file} for the empathize phase and select 3-5 methods that fit the design challenge context. Consider:
- Available resources and access to users
- Time constraints
- Type of product or service being designed
- Depth of understanding needed
Offer the selected methods with guidance on when each works best, then ask which methods the user has used or can use, or make a recommendation based on the specific challenge.
Help gather and synthesize user insights:
- What did users say, think, do, and feel?
- What pain points emerged?
- What surprised you?
- What patterns do you see?
user_insights key_observations empathy_map
Check in: "We've gathered rich user insights. How are you feeling? Ready to synthesize them into problem statements?"Transform observations into actionable problem statements.
Guide the user through problem framing:
- Create a Point of View statement: "[User type] needs [need] because [insight]"
- Generate "How Might We" questions that open solution space
- Identify key insights and opportunity areas
Ask probing questions:
- What's the real problem we're solving?
- Why does this matter to users?
- What would success look like for them?
- What assumptions are we making?
pov_statement hmw_questions problem_insights
Facilitate creative solution generation. Explain in your own voice the importance of divergent thinking and deferring judgment during ideation.Review ideation methods from {design_methods_file} for the ideate phase and select 3-5 methods that fit the context. Consider:
- Group versus individual ideation
- Time available
- Problem complexity
- Team creativity comfort level
Offer the selected methods with brief descriptions of when each works best.
Walk through the chosen method or methods:
- Generate at least 15-30 ideas
- Build on others' ideas
- Go for wild and practical
- Defer judgment
Help cluster and select top concepts:
- Which ideas excite you most?
- Which ideas address the core user need?
- Which ideas are feasible given the constraints?
- Select 2-3 ideas to prototype
ideation_methods generated_ideas top_concepts
Check in: "We've generated lots of ideas. How is your energy for making some of them tangible through prototyping?"Guide creation of low-fidelity prototypes for testing. Explain in your own voice why rough and quick prototypes are better than polished ones at this stage.
Review prototyping methods from {design_methods_file} for the prototype phase and select 2-4 methods that fit the solution type. Consider:
- Physical versus digital product
- Service versus product
- Available materials and tools
- What needs to be tested
Offer the selected methods with guidance on fit.
Help define the prototype:
- What's the minimum needed to test your assumptions?
- What are you trying to learn?
- What should users be able to do?
- What can you fake versus build?
prototype_approach prototype_description features_to_test
Design the validation approach and capture learnings. Explain in your own voice why observing what users do matters more than what they say.Help plan testing:
- Who will you test with? Aim for 5-7 users.
- What tasks will they attempt?
- What questions will you ask?
- How will you capture feedback?
Guide feedback collection:
- What worked well?
- Where did they struggle?
- What surprised them, and you?
- What questions arose?
- What would they change?
Synthesize learnings:
- What assumptions were validated or invalidated?
- What needs to change?
- What should stay?
- What new insights emerged?
testing_plan user_feedback key_learnings
Check in: "Great work. How is your energy for final planning and defining next steps?"Define clear next steps and success criteria.
Based on testing insights:
- What refinements are needed?
- What's the priority action?
- Who needs to be involved?
- What sequence makes sense?
- How will you measure success?
Determine the next cycle:
- Do you need more empathy work?
- Should you reframe the problem?
- Are you ready to refine the prototype?
- Is it time to pilot with real users?
refinements action_items success_metrics
Run: python3 {project-root}/_bmad/scripts/resolve_customization.py --skill {skill-root} --key workflow.on_complete — if the resolved value is non-empty, follow it as the final terminal instruction before exiting.