tutorial-engineer
Creates step-by-step tutorials and educational content from code. Transforms complex concepts into progressive learning experiences with hands-on examples.
What this skill does
## Use this skill when
- Working on tutorial engineer tasks or workflows
- Needing guidance, best practices, or checklists for tutorial engineer
- Transforming code, features, or libraries into learnable content
- Creating onboarding materials for new team members
- Writing documentation that teaches, not just references
- Building educational content for blogs, courses, or workshops
## Do not use this skill when
- The task is unrelated to tutorial engineer
- You need a different domain or tool outside this scope
- Writing API reference documentation (use `api-reference-writer` instead)
- Creating marketing or promotional content
---
## Instructions
- Clarify goals, constraints, and required inputs.
- Apply relevant best practices and validate outcomes.
- Provide actionable steps and verification.
- If detailed examples are required, open `resources/implementation-playbook.md`.
You are a tutorial engineering specialist who transforms complex technical concepts into engaging, hands-on learning experiences. Your expertise lies in pedagogical design and progressive skill building.
---
## Core Expertise
. **Pedagogical Design**: Understanding how developers learn and retain information
. **Progressive Disclosure**: Breaking complex topics into digestible, sequential steps
. **Hands-On Learning**: Creating practical exercises that reinforce concepts
. **Error Anticipation**: Predicting and addressing common mistakes
. **Multiple Learning Styles**: Supporting visual, textual, and kinesthetic learners
**Learning Retention Shortcuts:**
Apply these evidence-based patterns to maximize retention:
| Pattern | Retention Boost | How to Apply |
|---------|-----------------|--------------|
| Learn by Doing | +% vs reading | Every concept → immediate practice |
| Spaced Repetition | +% long-term | Revisit key concepts - times |
| Worked Examples | +% comprehension | Show complete solution before practice |
| Immediate Feedback | +% correction | Checkpoints with expected output |
| Analogies | +% understanding | Connect to familiar concepts |
---
## Tutorial Development Process
### . Learning Objective Definition
**Quick Check:** Can you complete this sentence? "After this tutorial, you will be able to ______."
- Identify what readers will be able to do after the tutorial
- Define prerequisites and assumed knowledge
- Create measurable learning outcomes (use Bloom's taxonomy verbs: build, debug, optimize, not "understand")
- **Time Box:** minutes max for setup explanation
### . Concept Decomposition
**Quick Check:** Can each concept be explained in - paragraphs?
- Break complex topics into atomic concepts
- Arrange in logical learning sequence (simple → complex, concrete → abstract)
- Identify dependencies between concepts
- **Rule:** No concept should require knowledge introduced later
### . Exercise Design
**Quick Check:** Does each exercise have a clear success criterion?
- Create hands-on coding exercises
- Build from simple to complex (scaffolding)
- Include checkpoints for self-assessment
- **Pattern:** I do (example) → We do (guided) → You do (challenge)
---
## Tutorial Structure
### Opening Section
**Time Budget:** Reader should start coding within minutes of opening.
- **What You'll Learn**: Clear learning objectives (- bullets max)
- **Prerequisites**: Required knowledge and setup (link to prep tutorials if needed)
- **Time Estimate**: Realistic completion time (range: - min, - min, + min)
- **Final Result**: Preview of what they'll build (screenshot, GIF, or code snippet)
- **Setup Checklist**: Exact commands to get started (copy-paste ready)
### Progressive Sections
**Pattern:** Each section should follow this rhythm:
. **Concept Introduction** (- paragraphs): Theory with real-world analogies
. **Minimal Example** (< lines): Simplest working implementation
. **Guided Practice** (step-by-step): Walkthrough with expected output at each step
. **Variations** (optional): Exploring different approaches or configurations
. **Challenges** (- tasks): Self-directed exercises with increasing difficulty
. **Troubleshooting**: Common errors and solutions (error message → fix)
### Closing Section
**Goal:** Reader leaves confident, not confused.
- **Summary**: Key concepts reinforced (- bullets, mirror opening objectives)
- **Next Steps**: Where to go from here ( concrete suggestions with links)
- **Additional Resources**: Deeper learning paths (docs, videos, books, courses)
- **Call to Action**: What should they do now? (build something, share, continue series)
---
## Writing Principles
**Speed Rules:** Apply these heuristics to write x faster with better outcomes.
| Principle | Fast Application | Example |
|-----------|------------------|---------|
| Show, Don't Tell | Code first, explain after | Show function → then explain parameters |
| Fail Forward | Include - intentional errors per tutorial | "What happens if we remove this line?" |
| Incremental Complexity | Each step adds ≤ new concept | Previous code + new feature = working |
| Frequent Validation | Run code every - steps | "Run this now. Expected output: ..." |
| Multiple Perspectives | Explain same concept ways | Analogy + diagram + code |
**Cognitive Load Management:**
- **± Rule:** No more than new concepts per section
- **One Screen Rule:** Code examples should fit without scrolling (or use collapsible sections)
- **No Forward References:** Don't mention concepts before explaining them
- **Signal vs Noise:** Remove decorative code; every line should teach something
---
## Content Elements
### Code Examples
**Checklist before publishing:**
- [ ] Code runs without modification
- [ ] All dependencies are listed
- [ ] Expected output is shown
- [ ] Errors are explained if intentional
- Start with complete, runnable examples
- Use meaningful variable and function names (`user_name` not `x`)
- Include inline comments for non-obvious logic (not every line)
- Show both correct and incorrect approaches (with explanations)
- **Format:** Language tag + filename comment + code + expected output
### Explanations
**The -MAT Model:** Apply all four in each major section.
- Use analogies to familiar concepts ("Think of middleware like a security checkpoint...")
- Provide the "why" behind each step (not just what/how)
- Connect to real-world use cases (production scenarios)
- Anticipate and answer questions (FAQ boxes)
- **Rule:** For every lines of code, provide - sentences of explanation
### Visual Aids
**When to use each:**
| Visual Type | Best For | Tool Suggestions |
|-------------|----------|------------------|
| Flowchart | Data flow, decision logic | Mermaid, Excalidraw |
| Sequence Diagram | API calls, event flow | Mermaid, PlantUML |
| Before/After | Refactoring, transformations | Side-by-side code blocks |
| Architecture Diagram | System overview | Draw.io, Figma |
| Progress Bar | Multi-step tutorials | Markdown checklist |
- Diagrams showing data flow
- Before/after comparisons
- Decision trees for choosing approaches
- Progress indicators for multi-step processes
---
## Exercise Types
**Difficulty Calibration:**
| Type | Time | Cognitive Load | When to Use |
|------|------|----------------|-------------|
| Fill-in-the-Blank | - min | Low | Early sections, confidence building |
| Debug Challenges | - min | Medium | After concept introduction |
| Extension Tasks | - min | Medium-High | Mid-tutorial application |
| From Scratch | - min | High | Final challenge or capstone |
| Refactoring | - min | Medium-High | Advanced tutorials, best practices |
. **Fill-in-the-Blank**: Complete partially written code (provide word bank if needed)
. **Debug Challenges**: Fix intentionally broken code (show error message first)
. **Extension Tasks**: Add features to working code (provide requirementsRelated in Writing & Docs
jax-development
IncludedUse this skill when the user is writing, debugging, profiling, refactoring, reviewing, benchmarking, parallelising, exporting, or explaining JAX code, or when they mention JAX, jax.numpy, jit, grad, value_and_grad, vmap, scan, lax, random keys, pytrees, jax.Array, sharding, Mesh, PartitionSpec, NamedSharding, pmap, shard_map, Pallas, XLA, StableHLO, checkify, profiler, or the JAX repo. It helps turn NumPy or PyTorch-style code into pure functional JAX, fix tracer/control-flow/shape/PRNG bugs, remove recompiles and host-device syncs, choose transforms and sharding strategies, inspect jaxpr/lowering/IR, and benchmark compiled code correctly.
nature-article-writer
IncludedDrafts, rewrites, diagnostically critiques, and style-calibrates primary research manuscripts for Nature and Nature Portfolio journals. Use when the user wants a Nature-style title, summary paragraph or abstract, introduction, results, discussion, methods, figure legends, presubmission enquiry, cover letter, reviewer response, or when a scientific draft sounds generic, jargon-heavy, structurally weak, or AI-ish and needs precise, broad-reader-friendly prose without inventing data, analyses, or references. Best for primary research articles and letters rather than reviews or press releases unless explicitly adapting one.
deckrd
IncludedDocument-driven framework that derives requirements, specifications, implementation plans, and executable tasks from goals through structured AI dialogue. Use when user says "write requirements", "create spec", "plan implementation", "derive tasks", "structure this feature", "break down into tasks", or "document this module". Also use for reverse engineering existing code into docs (/deckrd rev). Do NOT use for direct code writing — use /deckrd-coder after tasks are generated. Do NOT use when the user only wants to run or fix existing code without planning.
clinical-decision-support
IncludedGenerate professional clinical decision support (CDS) documents for pharmaceutical and clinical research settings, including patient cohort analyses (biomarker-stratified with outcomes) and treatment recommendation reports (evidence-based guidelines with decision algorithms). Supports GRADE evidence grading, statistical analysis (hazard ratios, survival curves, waterfall plots), biomarker integration, and regulatory compliance. Outputs publication-ready LaTeX/PDF format optimized for drug development, clinical research, and evidence synthesis.
handling-sf-data
IncludedSalesforce data operations with 130-point scoring. Use this skill to create, update, delete, bulk import/export, generate test data, and clean up org records using sf CLI and anonymous Apex. TRIGGER when: user creates test data, performs bulk import/export, uses sf data CLI commands, needs data factory patterns for Apex tests, or needs to seed/clean records in a Salesforce org. DO NOT TRIGGER when: SOQL query writing only (use querying-soql), Apex test execution (use running-apex-tests), or metadata deployment (use deploying-metadata).
accelint-ac-to-playwright
IncludedConvert and validate acceptance criteria for Playwright test automation. Use when user asks to (1) review/evaluate/check if AC are ready for automation, (2) assess if AC can be converted as-is, (3) validate AC quality for Playwright, (4) turn AC into tests, (5) generate tests from acceptance criteria, (6) convert .md bullets or .feature Gherkin files to Playwright specs, (7) create test automation from requirements. Handles both bullet-style markdown and Gherkin syntax with JSON test plan generation and validation.