blog-write
npx skills add https://github.com/megastep/codex-skills --skill blog-write
Agent 安装分布
Skill 文档
Blog Writer — New Article Generation
Writes complete blog articles from a topic, brief, or outline. Every article follows the 6 pillars of dual optimization (Google rankings + AI citations).
Key references:
../blog/references/content-templates.mdâ Template selection guide and usage../blog/references/quality-scoring.mdâ 5-category scoring (Content 30, SEO 25, E-E-A-T 15, Technical 15, AI Citation 15)../blog/references/eeat-signals.mdâ Experience, expertise, authority, trust markers../blog/references/internal-linking.mdâ Linking strategy and anchor text rules../blog/references/visual-media.mdâ Image sourcing and chart styling
Workflow
Phase 1: Topic Understanding
- Clarify the topic â If the user provides just a topic, ask:
- Target audience (who is this for?)
- Primary keyword / search intent
- Desired word count (default: 2,000-2,500 words)
- Platform/format (MDX, markdown, HTML â auto-detect if in a project)
- If a brief exists â Load it and skip to Phase 1.5
Phase 1.5: Template Selection
Select the appropriate content template from the 12 templates in ../blog/templates/.
-
Auto-detect content type from the topic and search intent:
Signal Template “How to…”, process, steps how-to-guide“Best X”, “Top N”, list format listicleClient result, before/after, metrics case-study“X vs Y”, comparison, alternatives comparisonBroad topic, comprehensive guide pillar-page“Is X worth it”, product evaluation product-reviewOpinion, prediction, industry take thought-leadershipExpert quotes, multi-source collection roundupCode walkthrough, tool demo, technical tutorialBreaking news, algorithm update, event news-analysisSurvey results, experiment, original data data-researchQ&A, knowledge base, “What is X” faq-knowledge -
Load the matching template â Read from
../blog/templates/<type>.md -
Adapt the outline â Use the template’s section structure, heading patterns, and word count guidance to shape Phase 3’s outline
-
Fallback â If no template clearly fits, use the generic outline structure in Phase 3 below. Inform the user which template was selected (or that none matched).
See ../blog/references/content-templates.md for detailed selection criteria and intent mapping.
Phase 2: Research
Spawn a blog-researcher agent (or do inline research with WebSearch):
- Find 8-12 current statistics (2025-2026 data preferred)
- Search:
[topic] study 2025 2026 data statistics - Prioritize tier 1-3 sources (see
../blog/references/quality-scoring.md) - Record: statistic, source name, URL, date, methodology
- Search:
- Find a cover image (wide, high-quality, topic-relevant):
- Search:
site:pixabay.com [topic] wide banner(preferred) - Alternative:
site:unsplash.com [topic] wide - Fallback:
site:pexels.com [topic] wide banner - Target dimensions: 1200×630 (OG-compatible) or 1920×1080
- Or generate a custom SVG cover via
blog-chart(text-on-gradient with key stat) - See
../blog/references/visual-media.mdfor cover image sizing details
- Search:
- Find 3-5 inline images from open-source platforms:
- Pixabay (preferred): Search
site:pixabay.com [topic keywords]- Extract image URL from page
- Direct URLs:
https://cdn.pixabay.com/photo/YYYY/MM/DD/HH/MM/filename.jpg - Verify with
curl -sI "<url>" | head -1returns HTTP 200
- Unsplash (alternative): Search
site:unsplash.com [topic keywords]- Build URL:
https://images.unsplash.com/photo-<id>?w=1200&h=630&fit=crop&q=80
- Build URL:
- Pexels (fallback): Search
site:pexels.com [topic keywords]
- Pixabay (preferred): Search
- Plan 2-4 data visualizations from researched statistics
- Select diverse chart types (see
../blog/references/visual-media.md) - Map data points to chart formats
- Select diverse chart types (see
Phase 3: Outline Generation
Create a structured outline before writing. If a template was loaded in Phase 1.5, adapt this skeleton to match the template’s section structure:
# [Title as Question â Include Primary Keyword]
## Introduction (100-150 words)
- Hook with surprising statistic
- Problem/opportunity statement
- What the reader will learn
> **TL;DR:** [40-60 word standalone summary â placeholder]
## H2: [Question Format] (300-400 words)
- Answer-first paragraph (40-60 words with stat + source)
- Supporting evidence
- [Image placement]
- Practical advice
- [CITATION CAPSULE placeholder]
- [INTERNAL-LINK: anchor text â target description]
## H2: [Question Format] (300-400 words)
- Answer-first paragraph
- [Chart: type + data description]
- Analysis and implications
- [CITATION CAPSULE placeholder]
- [INTERNAL-LINK: anchor text â target description]
## H2: [Statement for Variety] (300-400 words)
- Answer-first paragraph
- Real-world example or case study
- [Image placement]
- [CITATION CAPSULE placeholder]
## H2: [Question Format] (300-400 words)
- Answer-first paragraph
- [Chart: type + data description]
- Step-by-step guidance
- [CITATION CAPSULE placeholder]
- [INTERNAL-LINK: anchor text â target description]
## H2: [Question Format] (200-300 words)
- Answer-first paragraph
- Forward-looking analysis
## FAQ Section (3-5 questions, 40-60 words each answer)
- [INTERNAL-LINK: anchor text â detailed content]
## Conclusion (100-150 words)
- Key takeaways (bulleted)
- Call to action
- [INTERNAL-LINK: anchor text â next logical content]
Present the outline to the user for approval before writing.
Phase 4: Chart Generation (Built-In)
When the researcher identifies chart-worthy data (3+ comparable metrics, trend data, before/after comparisons):
- Select chart type using the diversity rule (no repeated types per post)
- Invoke
blog-chartsub-skill with: chart type, title, data values, source, platform format - Embed the returned SVG directly in the post within a
<figure>wrapper - Target 2-4 charts per 2,000-word post
- Distribute charts evenly â never cluster them
See ../blog/references/visual-media.md for chart type selection and styling rules.
Phase 5: Content Writing
Write the full article following these rules:
5a. Frontmatter
---
title: "[Question-format title with primary keyword]"
description: "[Fact-dense, 150-160 chars, includes 1 statistic]"
coverImage: "[URL from Pixabay/Unsplash/Pexels or generated SVG path]"
coverImageAlt: "[Descriptive sentence about the cover image]"
ogImage: "[Same as coverImage, or custom OG image URL]"
date: "YYYY-MM-DD"
lastUpdated: "YYYY-MM-DD"
author: "[Author name]"
tags: ["keyword1", "keyword2", "keyword3"]
---
If the platform uses a different field name (e.g., image, hero, thumbnail),
adapt to match the project’s existing frontmatter convention.
5b. TL;DR Box
Immediately after the introduction (before the first H2 body section), add a TL;DR box:
> **TL;DR:** [40-60 word standalone summary that makes sense without reading the
> full article. Contains the key finding or recommendation plus 1 statistic with
> source attribution. Reader should get the core value from this alone.]
Requirements:
- 40-60 words, no more
- Must be self-contained â understandable without reading the article
- Include 1 specific statistic with source name
- State the key finding, recommendation, or answer
- Place as a blockquote directly after the introduction paragraph
5c. Answer-First Formatting (Critical)
Every H2 section MUST open with a 40-60 word paragraph containing:
- At least one specific statistic with source attribution
- A direct answer to the heading’s implicit question
Pattern:
## How Does X Impact Y in 2026?
[Stat from source] ([Source Name](url), year). [Direct answer to the heading
question in 1-2 more sentences, explaining the implication and what this means
for the reader.]
5d. Information Gain Markers
Distribute at least 2-3 information gain markers throughout the article. These signal to search engines and AI systems that the content contains original value not available elsewhere.
Tag each with a comment or visible marker:
[ORIGINAL DATA]â Proprietary surveys, experiments, A/B test results, case study metrics the author collected first-hand[PERSONAL EXPERIENCE]â First-hand observations, lessons learned from direct involvement, “when we tried X, Y happened” narratives[UNIQUE INSIGHT]â Analysis others haven’t made, contrarian perspectives backed by data, novel connections between existing research
Placement:
- Weave into the body text naturally
- Use as inline comments:
<!-- [ORIGINAL DATA] -->before the relevant paragraph - Or as visible callouts if the format supports it:
> **Our finding:** [original observation backed by specific data] - Minimum 2 per post, target 3 for comprehensive articles
These markers map directly to the “Originality/unique value markers” criterion
in the Content Quality scoring category (see ../blog/references/quality-scoring.md).
5e. Citation Capsules
For each major H2 section, generate a citation capsule â a 40-60 word self-contained passage designed so AI systems can extract and quote it directly.
Requirements per capsule:
- 40-60 words, self-contained (makes sense in isolation)
- Contains: one specific claim + one data point + source attribution
- Written in a declarative, quotable style
- Placed within the H2 section body (not as a separate block)
Example:
According to a 2026 Gartner study, 58% of enterprise buyers now consult AI
assistants before contacting a vendor ([Gartner](https://www.gartner.com), 2026).
This shift means B2B content must answer specific questions concisely enough
for AI systems to extract and cite in their responses.
Capsules map to the “AI Citation Readiness” scoring category (15 points) in
../blog/references/quality-scoring.md.
5f. Internal Linking Zones
Mark internal linking opportunities throughout the article using placeholder notation. The user (or a follow-up pass) will resolve these to actual URLs.
Zone placement:
- Introduction â Link to related pillar content or topic hub
- Each H2 section â Link to supporting articles, deeper dives, related tools
- FAQ section â Link answers to detailed content that expands on the answer
- Conclusion â Link to the next logical piece of content the reader should consume
Format:
[INTERNAL-LINK: anchor text â target description]
Example:
For a deeper dive into keyword clustering, see our
[INTERNAL-LINK: complete guide to keyword clustering â pillar page on keyword research methodology].
Target 5-10 internal link zones per 2,000-word post. Use descriptive anchor text
(never “click here” or “read more”). See ../blog/references/internal-linking.md for
anchor text rules and linking strategy.
5g. Paragraph Rules
- Every paragraph: 40-80 words (never exceed 150)
- Every sentence: max 15-20 words
- Start each paragraph with the most important information
- Target Flesch Reading Ease: 60-70
5h. Heading Rules
- One H1 (title only)
- H2s for main sections (60-70% as questions)
- H3s for subsections only â never skip levels
- Include primary keyword naturally in 2-3 headings
5i. Image Embedding
Standard markdown:

MDX with Next.js Image (if detected):

- Place images after H2 headings, before body text
- Space evenly throughout the post (not clustered)
- Alt text should be a full descriptive sentence
5j. Chart Embedding
Standard markdown/HTML:
<figure>
<svg viewBox="0 0 560 380" ...>...</svg>
<figcaption>Source: [Source Name], [Year]</figcaption>
</figure>
MDX format:
<figure className="chart-container" style={{margin: '2.5rem 0', textAlign: 'center', padding: '1.5rem', borderRadius: '12px'}}>
<svg viewBox="0 0 560 380" ...>...</svg>
</figure>
5k. Citation Format
Inline attribution (always):
Organic CTR declined 61% with AI Overviews ([Seer Interactive](https://www.seerinteractive.com/), 2025).
5l. FAQ Section
Add 3-5 FAQ items with 40-60 word answers. Each answer must contain a statistic.
For MDX with FAQSchema component:
<FAQSchema faqs={[
{ question: "Question?", answer: "40-60 word answer with statistic and source." },
]} />
For standard markdown:
## Frequently Asked Questions
### Question text here?
Answer with statistic and source attribution (40-60 words).
5m. Internal Linking
- 5-10 internal links per 2,000-word post
- Link to relevant existing content naturally
- Use descriptive anchor text (not “click here”)
Phase 6: Quality Check
Before delivering, verify:
Structure and Content
- Every H2 opens with a statistic + source
- No paragraph exceeds 150 words
- All statistics have named tier 1-3 sources
- 2-4 charts with type diversity
- 3-5 inline images with descriptive alt text
- Cover image present in frontmatter (coverImage + ogImage)
- FAQ section present with 3-5 items
- Heading hierarchy is clean (H1 -> H2 -> H3)
- Meta description is 150-160 chars with a stat
New Element Verification
- TL;DR box present after introduction (40-60 words, contains statistic + source)
- At least 2-3 information gain markers (
[ORIGINAL DATA],[PERSONAL EXPERIENCE], or[UNIQUE INSIGHT]) - Citation capsules present in major H2 sections (40-60 words, self-contained, quotable)
- Internal linking zones marked in introduction, H2 sections, FAQ, and conclusion
- No AI-detectable phrases from banned list (see
agents/blog-writer.md)
Burstiness and Naturalness Check
- Sentence length variance â Verify a mix of short (8-word) and long (25-word) sentences. Uniform sentence length signals AI authorship.
- Banned AI phrase scan â Check for and remove:
- “in today’s digital landscape”, “it’s important to note”, “dive into”
- “game-changer”, “navigate the landscape”, “revolutionize”, “seamlessly”
- “cutting-edge”, “harness the power of”, “leverage” (as verb)
- “delve”, “crucial”, “elevate”, “foster”, “landscape” (overused)
- “multifaceted”, “robust”, “tapestry”, “embark”
- Full list in
agents/blog-writer.md
- Contractions â Verify natural use of contractions (“it’s”, “we’ve”, “don’t”, “isn’t”). Formal AI prose avoids contractions; natural writing uses them.
- Rhetorical questions â Verify at least one rhetorical question every 200-300 words to break up declarative patterns.
Phase 7: Delivery
Present the completed article with a summary:
## Blog Post Complete: [Title]
### Template Used
- [Template name] (or "generic outline â no template matched")
### Statistics
- [N] sourced statistics from tier 1-3 sources
- [N] unique sources cited
### Visual Elements
- Cover image: [source â Pixabay/Unsplash/Pexels or generated SVG]
- [N] inline images (Pixabay/Unsplash/Pexels)
- [N] SVG charts (types: bar, lollipop, donut, line)
### Dual-Optimization Elements
- TL;DR box: present (N words)
- Information gain markers: [N] ([types used])
- Citation capsules: [N] across H2 sections
- Internal linking zones: [N] marked
### Structure
- [N] H2 sections with answer-first formatting
- [N] FAQ items with schema
- Word count: ~[N] words
- Estimated reading time: [N] min
### Naturalness
- Sentence length variance: [pass/fail]
- AI phrase scan: [pass/fail]
- Contractions used: [yes/no]
- Rhetorical questions: [N] (target: 1 per 200-300 words)
### Next Steps
- Review and customize for your brand voice
- Resolve [INTERNAL-LINK] placeholders with actual URLs
- Add internal links to your existing content
- Run `$blog analyze <file>` to verify quality score