From social-media-skills
Scores LinkedIn post drafts against user's historical performance data via Apify scraping or cached benchmarks. Activates on 'score my post', 'review my post', or similar.
npx claudepluginhub charlie947/social-media-skills --plugin social-media-skillsThis skill uses the workspace's default tool permissions.
When this skill triggers, go straight to Step 1. Do not summarise. Do not explain the scoring method. Start immediately.
Audits and optimizes LinkedIn profiles via browser snapshots, scores sections like visuals/headline/experience/SSI, creates high-engagement posts and personal branding content.
Audits LinkedIn post drafts against 2026 algorithm heuristics and voice rules, catching AI tells, penalties, and structural issues. Returns pass/fail report with fixes, rewrites, and timing advice before publishing.
Generates two viral LinkedIn posts in proven formats with voice matching from templates. Use for creating engaging, high-performing LinkedIn content.
Share bugs, ideas, or general feedback.
When this skill triggers, go straight to Step 1. Do not summarise. Do not explain the scoring method. Start immediately.
If the user already pasted a post in the same message, use it. Otherwise say:
Paste the LinkedIn post you want scored.
Wait for the post.
The scorer needs two things: the user's voice system and real performance data.
Read about-me.md and voice.md from the project if they exist. If missing, note it and score without voice matching.
Check for cached LinkedIn data in the project or outputs folder. Look for files matching *-all-posts.json or *-posts.txt.
If cached data exists, use it. If not, ask the user:
[
{
"question": "To score your post against real data, I need your LinkedIn history. How should I get it?",
"header": "Data source",
"multiSelect": false,
"options": [
{"label": "Scrape my posts", "description": "Pull my last 100 posts from LinkedIn via Apify. Takes 1 to 2 minutes, costs about $0.50."},
{"label": "Use Charlie Hills data", "description": "Score against Charlie Hills benchmarks (1,872 avg engagement, 500 posts analysed). Good fallback."},
{"label": "Skip data scoring", "description": "Score against generic best practices only. Less accurate but instant."}
]
}
]
If "Scrape my posts":
If "Use Charlie Hills data": Look for cached Charlie data at **/linkedin-data/charlie-all-posts.json. If found, use it. If not, note you are using the benchmarks from this skill file (listed below).
If "Skip data scoring": Fall back to voice-system-only scoring and general best practices.
When performance data is available, run this analysis before scoring:
Save these patterns as a "scoring profile" you reference for each criterion.
Score across 5 criteria. Each scored 1 to 10.
Compare the draft's opening line to the hook types in the top 10%.
If voice.md exists:
Compare to the user's top-performing posts:
Based on their data:
Output in a code block:
LINKEDIN POST SCORE
Data source: [their posts / Charlie Hills benchmarks / generic]
Posts analysed: [number]
Top 10% avg engagement: [number]
Hook strength: [X] / 10 [hook type detected]
Voice match: [X] / 10
Value density: [X] / 10
Structure and format: [X] / 10 [format: text/image/carousel]
Publish readiness: [X] / 10
----------------------------------------
TOTAL: [XX] / 50
VERDICT: [One sentence referencing specific data]
TOP PERFORMER COMPARISON:
Your top posts average [X] words, use [hook type] hooks,
and include [CTA pattern]. This draft [matches/differs] because [specific reason].
FIXES:
1. [Specific fix backed by data, e.g. "Your top 10% posts open with numbers. This opens with a question. Switch to a stat."]
2. [Second fix backed by data]
3. [Third fix if needed]
Every fix must reference the user's actual data. Not "improve the hook" but "your top 10% posts use number-led hooks (42% of hits). This draft uses a question hook (12% of hits). Lead with the stat instead."
After the scorecard:
Want me to rewrite the weakest section using patterns from your top posts, or ship it?
If rewrite requested, apply the fixes and output the revised post in a code block.
Use these Charlie Hills benchmarks as the scoring baseline when the user picks "Use Charlie Hills data" and no cached file is found:
Average engagement: 1,872 (reactions + comments x 3) Average reactions: 808 Average comments: 355 Average reposts: 61 Comment-to-reaction ratio: 44%
Top hook types: number-led (31%), bold claim (27%), contrarian (18%) Top formats: carousel (33%), image (29%), text only (22%) Average post length top 10%: 180 to 250 words CTA rate: 45% mention newsletter Comment gate rate: 5%