skills/capabilities/create-x-content/SKILL.md
Draft voice-tuned X (Twitter) post variants from a free-form brief. Reads a personal voice guide (generated via generate-voice-guide), produces 2–5 variants with distinct framings (simple-howto, problem-first, hype, mechanism-breakdown, etc.), and self-checks against the voice guide's banned phrases before returning.
npx skillsauth add gooseworks-ai/goose-skills create-x-contentInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Draft X/Twitter post variants that sound like you, not like an AI. Reads a voice guide the user has already generated (or prompts to create one), produces multiple framings of the same idea, and saves each variant as its own markdown file with frontmatter.
This is an agent-executed skill — the agent does the drafting and self-check inline. No Python script.
/create-x-content --brief "New open-source CLI that turns Figma files into React components. Called figma2react. Free, MIT licensed."
Or interactively:
/create-x-content
| Flag | Required | Default |
|------|----------|---------|
| --brief | Yes (asked interactively if missing) | — |
| --variants | No | Skill decides based on brief richness (2–5) |
| --voice-guide | No | Resolved via chain below |
| --output | No | ./content/YYYY-MM-DD-<topic-slug>/ |
| --topic | No | Derived from brief |
Resolve in this order, stop at first hit:
--voice-guide <path> flag~/.goose-skills/config.json → voice_guides.x~/.goose-skills/voice-guides/voice-x.md (default path)/generate-voice-guide --platforms x now to create one (recommended)Never silently skip the voice guide. Generic posts are the failure mode to avoid.
Read the resolved voice guide into context. Extract, for use throughout drafting:
Decide variant count by richness:
If --variants is explicitly set, respect it. Otherwise pick the smallest count where each variant genuinely adds a different angle. Quality > quantity. 2 strong variants beat 5 watered-down ones.
Each variant gets a distinct framing label that determines its structure and hook:
| Framing | Structure | When to use |
|---------|-----------|-------------|
| simple-howto | Bare steps, no mechanism | Tool install + usage, 2–3 line how-to |
| howto-plus-mechanism | How-to + "here's how it works" breakdown | Tools where the mechanism is interesting |
| problem-first | Open with the pain, then solution | When the problem is visceral/relatable |
| hype | Punchy "someone just dropped X" energy | Launches, new OSS releases, cool builds |
| mechanism-breakdown | Focus on the how | Technical builds, systems, architectures |
| ecosystem-map | Curated list of N related tools/companies | Landscape posts |
| contrarian | "Most people do X wrong" opener | Opinion pieces with a clear counter-take |
| personal-experience | "We've been doing X. Here's what I learned" | Field notes, lessons learned |
Use framings the voice guide's hook patterns actually support. Don't force framings the user never employs.
Before saving, run each variant through these checks:
If a variant fails any check and two rewrite attempts don't fix it, drop the variant rather than ship something weak.
Write each variant as its own .md file. File naming:
variant-<letter>-<framing-slug>.md
Examples: variant-a-simple-howto.md, variant-b-problem-first.md.
Frontmatter schema:
---
id: <topic-slug>-<letter>
platform: x
format: short | long
topic: <slug>
framing: <framing-slug>
status: draft
---
Body: just the post text. No commentary, no surrounding markdown.
Print to the user:
/social-kit for a matching graphic)<output>/variant-<letter>-<framing>.md per variantSimple brief:
/create-x-content --brief "npx goose-skills install claude-code-hooks — a new skill that adds pre-commit, pre-tool-use, and post-response hooks to Claude Code so you can enforce coding standards automatically."
→ 3 variants (howto, hype, mechanism)
Rich brief:
/create-x-content --brief "Built a Claude-driven lead gen system. Scrapes Reddit for people asking about email deliverability, finds their domains, verifies their business email via Hunter, drafts a personalized DM. 47 leads in 6 hours at $0.03/lead."
→ 5 variants (personal-experience, mechanism-breakdown, hype, problem-first, simple-howto)
generate-voice-guide skill (for creating one when missing)development
End-to-end skill that turns a single reference image into a fully-installed, example-rendered style preset for the goose-graphics composite. Analyzes the image, writes the slim style spec, registers it in styles/index.json, generates all 7 format examples using the standard brief, renders PNGs via Playwright, and updates examples/manifest.json. Invoke with /goose-graphics-create-style.
development
Evaluate YC batch companies for investment — scrapes the YC directory, researches each company and its founders (work history, LinkedIn, website), assesses founder-company fit, and exports to Google Sheets with priority rankings. Use when asked to evaluate YC companies, research a YC batch, screen startups, or do due diligence on YC companies.
tools
Take screenshots of any website using Notte browser automation. Use when asked to screenshot, capture, or snap a webpage.
development
Search the web, platforms, and datasets. Use when asked to search, find, look up, research, or discover information from the web, YouTube, Amazon, eBay, news, academic sources, or any online platform.