blog-draft

2
0
Source

Draft a blog post from ideas and resources. Use when users want to write a blog post, create content from research, or draft articles. Guides through research, brainstorming, outlining, and iterative drafting with version control.

Install

mkdir -p .claude/skills/blog-draft && curl -L -o skill.zip "https://mcp.directory/api/skills/download/3853" && unzip -o skill.zip -d .claude/skills/blog-draft && rm skill.zip

Installs to .claude/skills/blog-draft

About this skill

User Input

$ARGUMENTS

You MUST consider the user input before proceeding. User should provide:

  • Idea/Topic: The main concept or theme for the blog post
  • Resources: URLs, files, or references to research (optional but recommended)
  • Target audience: Who the blog post is for (optional)
  • Tone/Style: Formal, casual, technical, etc. (optional)

IMPORTANT: If the user is requesting updates to an existing blog post, skip steps 0-8 and start directly at Step 9. Read the existing draft file(s) first, then proceed with the iteration process.

Execution Flow

Follow these steps sequentially. Do not skip steps or proceed without user approval where indicated.

Step 0: Create Project Folder

  1. Generate a folder name using format: YYYY-MM-DD-short-topic-name

    • Use today's date
    • Create a short, URL-friendly slug from the topic (lowercase, hyphens, max 5 words)
  2. Create the folder structure:

    blog-posts/
    └── YYYY-MM-DD-short-topic-name/
        └── resources/
    
  3. Confirm folder creation with user before proceeding.

Step 1: Research & Resource Collection

  1. Create resources/ subfolder in the blog post directory

  2. For each provided resource:

    • URLs: Fetch and save key information to resources/ as markdown files
    • Files: Read and summarize in resources/
    • Topics: Use web search to gather up-to-date information
  3. For each resource, create a summary file in resources/:

    • resources/source-1-[short-name].md
    • resources/source-2-[short-name].md
    • etc.
  4. Each summary should include:

    # Source: [Title/URL]
    
    ## Key Points
    - Point 1
    - Point 2
    
    ## Relevant Quotes/Data
    - Quote or statistic 1
    - Quote or statistic 2
    
    ## How This Relates to Topic
    Brief explanation of relevance
    
  5. Present research summary to user.

Step 2: Brainstorm & Clarify

  1. Based on the idea and researched resources, present:

    • Main themes identified from research
    • Potential angles for the blog post
    • Key points that should be covered
    • Gaps in information that need clarification
  2. Ask clarifying questions:

    • What is the main takeaway you want readers to have?
    • Are there specific points from the research you want to emphasize?
    • What's the target length? (short: 500-800 words, medium: 1000-1500, long: 2000+)
    • Any points you want to exclude?
  3. Wait for user responses before proceeding.

Step 3: Propose Outline

  1. Create a structured outline including:

    # Blog Post Outline: [Title]
    
    ## Meta Information
    - **Target Audience**: [who]
    - **Tone**: [style]
    - **Target Length**: [word count]
    - **Main Takeaway**: [key message]
    
    ## Proposed Structure
    
    ### Hook/Introduction
    - Opening hook idea
    - Context setting
    - Thesis statement
    
    ### Section 1: [Title]
    - Key point A
    - Key point B
    - Supporting evidence from [source]
    
    ### Section 2: [Title]
    - Key point A
    - Key point B
    
    [Continue for all sections...]
    
    ### Conclusion
    - Summary of key points
    - Call to action or final thought
    
    ## Sources to Cite
    - Source 1
    - Source 2
    
  2. Present outline to user and ask for approval or modifications.

Step 4: Save Approved Outline

  1. Once user approves the outline, save it to OUTLINE.md in the blog post folder.

  2. Confirm the outline has been saved.

Step 5: Commit Outline (if in git repo)

  1. Check if current directory is a git repository.

  2. If yes:

    • Stage the new files: blog post folder, resources, and OUTLINE.md
    • Create commit with message: docs: Add outline for blog post - [topic-name]
    • Push to remote
  3. If not a git repo, skip this step and inform user.

Step 6: Write Draft

  1. Based on the approved outline, write the full blog post draft.

  2. Follow the structure from OUTLINE.md exactly.

  3. Include:

    • Engaging introduction with hook
    • Clear section headers
    • Supporting evidence and examples from research
    • Smooth transitions between sections
    • Strong conclusion with takeaway
    • Citations: All comparisons, statistics, data points, and factual claims MUST cite the original source
  4. Save the draft as draft-v0.1.md in the blog post folder.

  5. Format:

    # [Blog Post Title]
    
    *[Optional: subtitle or tagline]*
    
    [Full content with inline citations...]
    
    ---
    
    ## References
    - [1] Source 1 Title - URL or Citation
    - [2] Source 2 Title - URL or Citation
    - [3] Source 3 Title - URL or Citation
    
  6. Citation Requirements:

    • Every data point, statistic, or comparison MUST have an inline citation
    • Use numbered references [1], [2], etc., or named citations [Source Name]
    • Link citations to the References section at the end
    • Example: "Studies show that 65% of developers prefer TypeScript [1]"
    • Example: "React outperforms Vue in rendering speed by 20% [React Benchmarks 2024]"

Step 7: Commit Draft (if in git repo)

  1. Check if in git repository.

  2. If yes:

    • Stage the draft file
    • Create commit with message: docs: Add draft v0.1 for blog post - [topic-name]
    • Push to remote
  3. If not a git repo, skip and inform user.

Step 8: Present Draft for Review

  1. Present the draft content to user.

  2. Ask for feedback:

    • Overall impression?
    • Sections that need expansion or reduction?
    • Tone adjustments needed?
    • Missing information?
    • Specific edits or rewrites?
  3. Wait for user response.

Step 9: Iterate or Finalize

If user requests changes:

  1. Note all requested modifications
  2. Return to Step 6 with the following adjustments:
    • Increment version number (v0.2, v0.3, etc.)
    • Incorporate all feedback
    • Save as draft-v[X.Y].md
    • Repeat Steps 7-8

If user approves:

  1. Confirm the final draft version
  2. Optionally rename to final.md if user requests
  3. Summarize the blog post creation process:
    • Total versions created
    • Key changes between versions
    • Final word count
    • Files created

Version Tracking

All drafts are preserved with incremental versioning:

  • draft-v0.1.md - Initial draft
  • draft-v0.2.md - After first round of feedback
  • draft-v0.3.md - After second round of feedback
  • etc.

This allows tracking the evolution of the blog post and reverting if needed.

Output Files Structure

blog-posts/
└── YYYY-MM-DD-topic-name/
    ├── resources/
    │   ├── source-1-name.md
    │   ├── source-2-name.md
    │   └── ...
    ├── OUTLINE.md
    ├── draft-v0.1.md
    ├── draft-v0.2.md (if iterations)
    └── draft-v0.3.md (if more iterations)

Tips for Quality

  • Hook: Start with a question, surprising fact, or relatable scenario
  • Flow: Each paragraph should connect to the next
  • Evidence: Support claims with data from research
  • Citations: ALWAYS cite sources for:
    • All statistics and data points (e.g., "According to [Source], 75% of...")
    • Comparisons between products, services, or approaches (e.g., "X performs 2x faster than Y [Source]")
    • Factual claims about market trends, research findings, or benchmarks
    • Use inline citations with format: [Source Name] or [Author, Year]
  • Voice: Maintain consistent tone throughout
  • Length: Respect the target word count
  • Readability: Use short paragraphs, bullet points where appropriate
  • CTA: End with a clear call-to-action or thought-provoking question

Notes

  • Always wait for user approval at outlined checkpoints
  • Preserve all draft versions for history
  • Use web search for up-to-date information when URLs are provided
  • If resources are insufficient, ask user for more or suggest additional research
  • Adapt tone based on target audience (technical, general, business, etc.)

You might also like

flutter-development

aj-geddes

Build beautiful cross-platform mobile apps with Flutter and Dart. Covers widgets, state management with Provider/BLoC, navigation, API integration, and material design.

643969

drawio-diagrams-enhanced

jgtolentino

Create professional draw.io (diagrams.net) diagrams in XML format (.drawio files) with integrated PMP/PMBOK methodologies, extensive visual asset libraries, and industry-standard professional templates. Use this skill when users ask to create flowcharts, swimlane diagrams, cross-functional flowcharts, org charts, network diagrams, UML diagrams, BPMN, project management diagrams (WBS, Gantt, PERT, RACI), risk matrices, stakeholder maps, or any other visual diagram in draw.io format. This skill includes access to custom shape libraries for icons, clipart, and professional symbols.

591705

ui-ux-pro-max

nextlevelbuilder

"UI/UX design intelligence. 50 styles, 21 palettes, 50 font pairings, 20 charts, 8 stacks (React, Next.js, Vue, Svelte, SwiftUI, React Native, Flutter, Tailwind). Actions: plan, build, create, design, implement, review, fix, improve, optimize, enhance, refactor, check UI/UX code. Projects: website, landing page, dashboard, admin panel, e-commerce, SaaS, portfolio, blog, mobile app, .html, .tsx, .vue, .svelte. Elements: button, modal, navbar, sidebar, card, table, form, chart. Styles: glassmorphism, claymorphism, minimalism, brutalism, neumorphism, bento grid, dark mode, responsive, skeuomorphism, flat design. Topics: color palette, accessibility, animation, layout, typography, font pairing, spacing, hover, shadow, gradient."

318398

godot

bfollington

This skill should be used when working on Godot Engine projects. It provides specialized knowledge of Godot's file formats (.gd, .tscn, .tres), architecture patterns (component-based, signal-driven, resource-based), common pitfalls, validation tools, code templates, and CLI workflows. The `godot` command is available for running the game, validating scripts, importing resources, and exporting builds. Use this skill for tasks involving Godot game development, debugging scene/resource files, implementing game systems, or creating new Godot components.

340397

nano-banana-pro

garg-aayush

Generate and edit images using Google's Nano Banana Pro (Gemini 3 Pro Image) API. Use when the user asks to generate, create, edit, modify, change, alter, or update images. Also use when user references an existing image file and asks to modify it in any way (e.g., "modify this image", "change the background", "replace X with Y"). Supports both text-to-image generation and image-to-image editing with configurable resolution (1K default, 2K, or 4K for high resolution). DO NOT read the image file first - use this skill directly with the --input-image parameter.

451339

fastapi-templates

wshobson

Create production-ready FastAPI projects with async patterns, dependency injection, and comprehensive error handling. Use when building new FastAPI applications or setting up backend API projects.

304231

Stay ahead of the MCP ecosystem

Get weekly updates on new skills and servers.