* feat: add DX framework resolver for shared principles and scoring rubric
New {{DX_FRAMEWORK}} resolver provides compact (~150 lines) shared content
for /plan-devex-review and /devex-review: Addy Osmani's 8 DX principles,
7 characteristics table, 10 cognitive patterns, scoring rubric, and TTHW
benchmarks. Hall of Fame examples loaded on-demand per pass to avoid bloat.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
* feat: add DX Review row to review dashboard
Adds plan-devex-review and devex-review schema entries to the review
dashboard resolver and placeholder table in the preamble. All existing
SKILL.md files regenerated to include the new DX Review row.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
* feat: /plan-devex-review skill — DX plan review with Osmani framework
Plan-stage developer experience review. Rates 8 DX dimensions 0-10:
getting started, API/CLI/SDK design, error messages, docs, upgrade path,
dev environment, community, and DX measurement. Includes developer empathy
simulation, auto-detect product type with applicability gate, DX scorecard
with trend tracking, and a conditional Claude Code Skill DX checklist.
Hall of Fame examples loaded on-demand per pass from dx-hall-of-fame.md.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
* feat: /devex-review skill — live DX audit with browse
Live-system developer experience audit using browse tool. Tests all 8
dimensions aligned with /plan-devex-review for boomerang comparison
(plan said 3 min TTHW, reality says 8). Each dimension marked TESTED,
INFERRED, or N/A with evidence. Scope-aware: declares what browse can
and cannot test, falls back to file artifacts for untestable dimensions.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
* chore: bump version and changelog (v0.15.3.0)
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
7.1 KiB
DX Hall of Fame Reference
Read ONLY the section for the current review pass. Do NOT load the entire file.
Pass 1: Getting Started
Gold standards:
- Stripe: 7 lines of code to charge a card. Docs pre-fill YOUR test API keys when logged in. Stripe Shell runs CLI inside docs page. No local install needed.
- Vercel:
git push= live site on global CDN with HTTPS. Every PR gets preview URL. One CLI command:vercel. - Clerk:
<SignIn />,<SignUp />,<UserButton />. 3 JSX components, working auth with email, social, MFA out of the box. - Supabase: Create a Postgres table, auto-generates REST API + Realtime + self-documenting docs instantly.
- Firebase:
onSnapshot(). 3 lines for real-time sync across all clients with offline persistence built-in. - Twilio: Virtual Phone in console. Send/receive SMS without buying a number, no credit card. Result: 62% improvement in activation.
Anti-patterns:
- Email verification before any value (breaks flow)
- Credit card required before sandbox
- "Choose your own adventure" with multiple paths (decision fatigue; one golden path wins)
- API keys hidden in settings (Stripe pre-fills them into code examples)
- Static code examples without language switching
- Separate docs site from dashboard (context switching)
Pass 2: API/CLI/SDK Design
Gold standards:
- Stripe prefixed IDs:
ch_for charges,cus_for customers. Self-documenting. Impossible to pass wrong ID type. - Stripe expandable objects: Default returns ID strings.
expand[]gets full objects inline. Nested expansion up to 4 levels. - Stripe idempotency keys: Pass
Idempotency-Keyheader on mutations. Safe retries. No "did I double-charge?" anxiety. - Stripe API versioning: First call pins account to that day's version. Test new versions per-request via
Stripe-Versionheader. - GitHub CLI: Auto-detects terminal vs pipe. Human-readable in terminal, tab-delimited when piped.
gh pr <tab>shows all PR actions. - SwiftUI progressive disclosure:
Button("Save") { save() }to full customization, same API at every level. - htmx: HTML attributes replace JS. 14KB total.
hx-get="/search" hx-trigger="keyup changed delay:300ms". Zero build step. - shadcn/ui: Copy source code into your project. You own every line. No dependency, no version conflicts.
Anti-patterns:
- Chatty API: requiring 5 calls for one user-visible action
- Inconsistent naming:
/users(plural) vs/user/123(singular) vs/create-order(verb in URL) - Implicit failure: 200 OK with error nested in response body
- God endpoint: 47 parameter combinations with different behavior per subset
- Documentation-required API: 3 pages of docs before first call = too much ceremony
Pass 3: Error Messages & Debugging
Three tiers of error quality:
Tier 1, Elm (Conversational Compiler):
-- TYPE MISMATCH ---- src/Main.elm
I cannot do addition with String values like this one:
42| "hello" + 1
^^^^^^^
Hint: To put strings together, use the (++) operator instead.
First person, complete sentences, exact location, suggested fix, further reading.
Tier 2, Rust (Annotated Source):
error[E0308]: mismatched types
--> src/main.rs:4:20
help: consider borrowing here
|
4 | let name: &str = &get_name();
| +
Error code links to tutorial. Primary + secondary labels. Help section shows exact edit.
Tier 3, Stripe API (Structured with doc_url):
{"error":{"type":"invalid_request_error","code":"resource_missing","message":"No such customer: 'cus_nonexistent'","param":"customer","doc_url":"https://stripe.com/docs/error-codes/resource-missing"}}
Five fields, zero ambiguity.
The formula: What happened + Why + How to fix + Where to learn more + Actual values that caused it.
Anti-pattern: TypeScript buries "Did you mean?" at the BOTTOM of long error chains. Most actionable info should appear FIRST.
Pass 4: Documentation & Learning
Gold standards:
- Stripe docs: Three-column layout (nav / content / live code). API keys injected when logged in. Language switcher persists across ALL pages. Hover-to-highlight. Stripe Shell for in-browser API calls. Built and open-sourced Markdoc. Features don't ship until docs are finalized. Docs contributions affect performance reviews.
- 52% of developers blocked by lack of documentation (Postman 2023)
- Companies with world-class docs see 2.5x increase in adoption
- "Docs as product": ships with the feature or the feature doesn't ship
Pass 5: Upgrade & Migration Path
Gold standards:
- Next.js:
npx @next/codemod upgrade major. One command upgrades Next.js, React, React DOM, runs all relevant codemods. - AG Grid: Every release from v31+ includes a codemod.
- Stripe API versioning: One codebase internally. Version pinning per account. Breaking changes never surprise you.
- Martin Fowler's pipeline pattern: Compose small, testable transformations rather than one monolithic codemod.
- 21.9% of breaking changes in Maven Central were undocumented (Ochoa et al., 2021)
Pass 6: Developer Environment & Tooling
Gold standards:
- Bun: 100x faster than npm install, 4x faster than Node.js runtime. Speed IS DX.
- 87 interruptions per day average; 25 minutes to recover from each. Devs code only 2-4 hours/day.
- Each 1-point DXI improvement = 13 minutes saved per developer per week.
- GitHub Copilot: 55.8% faster task completion. PR time from 9.6 days to 2.4 days.
Pass 7: Community & Ecosystem
- Dev tools require ~14 exposures before purchase (Matt Biilmann, Netlify). Incompatible with quarterly OKR cycles.
- 4-5x performance multiplier for teams with strong developer experience (DevEx framework).
Pass 8: DX Measurement
Three academic frameworks:
- SPACE (Microsoft Research, 2021): Satisfaction, Performance, Activity, Communication, Efficiency. Measure at least 3 dimensions.
- DevEx (ACM Queue, 2023): Feedback Loops, Cognitive Load, Flow State. Combine perceptual + workflow data.
- Fagerholm & Munch (IEEE, 2012): Cognition, Affect, Conation. The psychological "trilogy of mind."
Claude Code Skill DX Checklist
Use when reviewing plans for Claude Code skills, MCP servers, or AI agent tools.
- AskUserQuestion design: One issue per call. Re-ground context (project, branch, task). Browser handoff for visual feedback.
- State storage: Global (~/.tool/) vs per-project ($SLUG/) vs per-session. Append-only JSONL for audit trails.
- Progressive consent: One-time prompts with marker files. Never re-ask. Reversible.
- Auto-upgrade: Version check with cache + snooze backoff. Migration scripts. Inline offer.
- Skill composition: Benefits-from chains. Review chaining. Inline invocation with section skipping.
- Error recovery: Resume from failure. Partial results preserved. Checkpoint-safe.
- Session continuity: Timeline events. Compaction recovery. Cross-session learnings.
- Bounded autonomy: Clear operational limits. Mandatory escalation for destructive actions. Audit trails.
Reference implementations: gstack's design-shotgun loop, auto-upgrade flow, progressive consent, hierarchical storage.