blog-post-writer
Transform brain dumps into polished blog posts in Nick Nisi's voice. Use when the user says "write a blog post," "draft a post," "write about [topic]," "turn my notes into a blog post," or provides scattered ideas, talking points, or conclusions that need shaping into a cohesive narrative.
What this skill does
# Nick Nisi Blog Writer Transform unstructured brain dumps into polished blog posts that sound like Nick Nisi. ## Process ### 1. Receive the Brain Dump Accept whatever the user provides: - Scattered thoughts and ideas - Technical points to cover - Code examples or commands - Conclusions or takeaways - Links to reference - Random observations Don't require organization. The mess is the input. **Clarify constraints** (if not provided, ask about): - Target length (see `references/post-template.md` for word count ranges) - Target audience (if different from general developer peers) - Whether this is a first draft or revision of existing content - Any specific sections, topics, or angles to include or exclude ### 2. Read Voice and Tone Load `references/voice-tone.md` as the baseline voice guide. **Then calibrate against recent writing:** 1. Fetch `https://nicknisi.com/posts` to find the 2-3 most recent posts 2. Fetch and read those posts 3. Note any patterns that extend or differ from the static reference — new phrases, tone shifts, topic-specific voice adjustments The static reference captures established patterns. The live fetch catches evolution. When they conflict, prefer the recent posts — voice is a living thing. If the site cannot be fetched, rely on the static voice guide alone. Key characteristics (read the full reference for details and examples): - Conversational yet substantive - Vulnerable and authentic - Journey-based narrative - Mix of short and long sentences - Specific examples and real details - Self-aware humor ### 3. Choose a Narrative Framework Match the content to the best framework. Read the corresponding reference file before writing. **Quick-match shortcuts** (covers ~80% of posts): - Personal journey → **Story Circle** (`references/story-circle.md`) - Teaching a concept → **Progressive Disclosure** (`references/progressive-disclosure.md`) - Bug fix story → **PAS** (`references/problem-agitation-solution.md`) - Tool comparison → **Compare & Contrast** (`references/compare-contrast.md`) - Something broke → **Post-mortem** (`references/post-mortem.md`) - Technical decision → **SCQA** (`references/scqa.md`) - Contrarian take → **The Sparkline** (`references/the-sparkline.md`) - Absurd complexity → **Kafkaesque Labyrinth** (`references/kafkaesque-labyrinth.md`) **Category decision tree** (for the other 20%): - "I changed through this" → **Journey & Transformation** - "The structure IS the story" → **Structural Techniques** - "There's a surprise or tension" → **Tension & Contrast** - "Making a logical case" → **Analytical & Persuasive** - "Mood/feeling drives the piece" → **Atmospheric & Experimental** #### Journey & Transformation | Framework | Reference | One-liner | | --------------------- | ------------------------------------- | ------------------------------------------------------------ | | Story Circle | `references/story-circle.md` | 8-step hero's journey for personal transformation arcs | | Three-Act | `references/three-act.md` | Classic setup/confrontation/resolution narrative spine | | Freytag's Pyramid | `references/freytags-pyramid.md` | 5-phase dramatic arc with explicit climax mapping | | The Metamorphosis | `references/the-metamorphosis.md` | Identity-level change — the author becomes someone different | | Existential Awakening | `references/existential-awakening.md` | Profound realization that shifts relationship to work | #### Structural Techniques | Framework | Reference | One-liner | | ------------------ | ---------------------------------- | ------------------------------------------------------------ | | In Medias Res | `references/in-medias-res.md` | Start in the middle of the action, backfill context | | Reverse Chronology | `references/reverse-chronology.md` | Tell it backwards — outcome first, origin last | | Nested Loops | `references/nested-loops.md` | Layer stories inside each other like Russian dolls | | The Spiral | `references/the-spiral.md` | Revisit the same concept with deeper understanding each pass | | The Petal | `references/the-petal.md` | Multiple stories radiating from a central theme | #### Tension & Contrast | Framework | Reference | One-liner | | ---------------- | -------------------------------- | -------------------------------------------------------------- | | Kishōtenketsu | `references/kishotenketsu.md` | 4-act twist without conflict — recontextualize, don't confront | | The Sparkline | `references/the-sparkline.md` | Oscillate between "what is" and "what could be" | | The False Start | `references/the-false-start.md` | Begin with the wrong story, then restart with truth | | Converging Ideas | `references/converging-ideas.md` | Unrelated threads that connect to a single insight | | Catch-22 | `references/catch-22.md` | Paradox where the rules create an impossible situation | | The Rashomon | `references/the-rashomon.md` | Same event from multiple contradictory perspectives | #### Analytical & Persuasive | Framework | Reference | One-liner | | ---------------------- | ------------------------------------------ | ------------------------------------------------------------------ | | SCQA | `references/scqa.md` | Situation-Complication-Question-Answer for logical problem-solving | | Progressive Disclosure | `references/progressive-disclosure.md` | Simple-to-complex layering for teaching concepts | | Compare & Contrast | `references/compare-contrast.md` | Structured evaluation of trade-offs between options | | PAS | `references/problem-agitation-solution.md` | Punchy problem→pain→fix for short optimization stories | | Post-mortem | `references/post-mortem.md` | Incident retrospective with timeline and lessons | | Socratic Path | `references/socratic-path.md` | Chain of questions leading to self-discovered conclusions | #### Atmospheric & Experimental | Framework | Reference | One-liner | | -------------------- | ------------------------------------ | ----------------------------------------------------------------- | | Comedian's Set | `references/comedians-set.md` | Setup→punchline structure for myth-busting and reframes | | Kafkaesque Labyrinth | `references/kafkaesque-labyrinth.md` | Systemic absurdity where the villain is the system itself | | Sisyphean Arc | `references/sisyphean-arc.md` | Find meaning in repetitive work that never ends | | Stranger's Report | `references/strangers-report.md` | Fresh-eyes outsider perspective on normalized strangeness | | The Waiting | `references/the-waiting.md` | Something promised that never arrives — meaning from anticipation | Not every post maps cleanly to one framework. Hybrid approaches are fine — each framework's reference includes Combination Notes for pairing. Use a framework as a starting structure, not a straitjacket. `voice-tone.md` and `post-template.md` are always loaded. Load only one framework reference in addition — do not preload all twenty-seven. ### 4. Outline the Post Apply t
Related in Image & Video
watch
IncludedWatch a video (URL or local path). Downloads with yt-dlp, extracts auto-scaled frames with ffmpeg, pulls the transcript from captions (or Whisper API fallback), and hands the result to Claude so it can answer questions about what's in the video.
physical-ai-defect-image-generation
IncludedUse when the user wants to orchestrate defect image generation, run associated setup, or handle outputs on OSMO. The Day 0 path handles cold-start with USD-to-ROI, image-edit augmentation, and AnomalyGen to create initial PCBA datasets. The Day 1 path performs inference and labeling on real images. This skill helps with first-time asset setup, creation of finetuning checkpoints, and configuring deployment. Trigger keywords: defect image generation, dig workflow, dig pipeline, defect image detection workflow, aoi pipeline, aoi anomalygen, usd2roi anomalygen, day 0 pcba, day 1 pcba, day 1 real-photo alignment, day 1 manual roi, metal surface anomaly, glass defect, anomalygen finetune, setup_pcb, setup_metal, setup_glass, setup_pretrained, dig setup, dig datasets, dig pretrained checkpoint, dig image-edit endpoint.
accelint-react-best-practices
IncludedReact performance optimization and best practices. ALWAYS use this skill when working with any React code - writing components, hooks, JSX; refactoring; optimizing re-renders, memoization, state management; reviewing for performance; fixing hydration mismatches; debugging infinite re-renders, stale closures, input focus loss, animations restarting; preventing remounting; implementing transitions, lazy initialization, effect dependencies. Even simple React tasks benefit from these patterns. Covers React 19+ (useEffectEvent, Activity, ref props). Triggers - useEffect, useState, useMemo, useCallback, memo, inline components, nested components, components inside components, re-render, performance, hydration, SSR, Next.js, useDeferredValue, combined hooks.
elevenlabs-agents
IncludedBuild conversational AI voice agents with ElevenLabs Platform using React, JavaScript, React Native, or Swift SDKs. Configure agents, tools (client/server/MCP), RAG knowledge bases, multi-voice, and Scribe real-time STT. Use when: building voice chat interfaces, implementing AI phone agents with Twilio, configuring agent workflows or tools, adding RAG knowledge bases, testing with CLI "agents as code", or troubleshooting deprecated @11labs packages, Android audio cutoff, CSP violations, dynamic variables, or WebRTC config. Keywords: ElevenLabs Agents, ElevenLabs voice agents, AI voice agents, conversational AI, @elevenlabs/react, @elevenlabs/client, @elevenlabs/react-native, @elevenlabs/elevenlabs-js, @elevenlabs/agents-cli, elevenlabs SDK, voice AI, TTS, text-to-speech, ASR, speech recognition, turn-taking model, WebRTC voice, WebSocket voice, ElevenLabs conversation, agent system prompt, agent tools, agent knowledge base, RAG voice agents, multi-voice agents, pronunciation dictionary, voice speed control, elevenlabs scribe, @11labs deprecated, Android audio cutoff, CSP violation elevenlabs, dynamic variables elevenlabs, case-sensitive tool names, webhook authentication
humanizer
IncludedHumanize AI-generated text by detecting and removing patterns typical of LLM output. Rewrites text to sound natural, specific, and human. Uses 28 pattern detectors, 560+ AI vocabulary terms across 3 tiers, and statistical analysis (burstiness, type-token ratio, readability) for comprehensive detection. Use when asked to humanize text, de-AI writing, make content sound more natural/human, review writing for AI patterns, score text for AI detection, or improve AI-generated drafts. Covers content, language, style, communication, and filler categories.
generating-mermaid-diagrams
IncludedSalesforce architecture diagrams using Mermaid with ASCII fallback. Use this skill when generating text-based diagrams for Salesforce architecture, OAuth flows, ERDs, integration sequences, or Agentforce structure. TRIGGER when: user says "diagram", "visualize", "ERD", or asks for sequence diagrams, flowcharts, class diagrams, or architecture visualizations in Mermaid. DO NOT TRIGGER when: user wants PNG/SVG image output (use generating-visual-diagrams), or asks about non-Salesforce systems.