JSPM

  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 5
  • Score
    100M100P100Q68524F
  • License MIT

LLM-agnostic prompt templates and response parsers for AI-assisted SEO

Package Exports

  • @power-seo/ai

Readme

@power-seo/ai

ai banner

LLM-agnostic SEO prompt builders and structured response parsers — works with OpenAI, Anthropic Claude, Google Gemini, Mistral, and any other provider.

npm version npm downloads Socket License: MIT TypeScript tree-shakeable

@power-seo/ai bridges the gap between large language models and SEO workflows. Every major LLM provider has its own SDK, authentication pattern, and API shape — but the actual prompting logic for SEO tasks is the same regardless of which model you use. This package extracts that logic into reusable, testable, provider-agnostic building blocks.

Prompt builders return a plain { system, user, maxTokens } object that you pass directly to whatever LLM client you already have — OpenAI, Anthropic Claude, Google Gemini, Mistral, local Ollama models, or any other provider. Parsers accept the raw text string that comes back from the model and extract structured data: MetaDescriptionResult, TitleResult, ContentSuggestion[], or SerpFeaturePrediction. There is no LLM SDK bundled, no API keys managed, and no network calls made by this package.

The analyzeSerpEligibility function is the exception: it is a fully deterministic, rule-based analysis of SERP feature eligibility that requires no LLM at all. It inspects your page's schema markup and content structure to determine whether it qualifies for FAQ, HowTo, Product, and Article rich results.

Zero runtime dependencies — no LLM SDK bundled; bring your own provider client.


Why @power-seo/ai?

Without With
Meta descriptions ❌ Write manually ✅ LLM-generated, SEO-optimized candidates
Title optimization ❌ Guesswork ✅ Keyphrase-focused, branded title variants
Content gaps ❌ Manually identified ✅ Structured AI-powered improvement suggestions
SERP eligibility ❌ Unknown ✅ Rule-based + LLM prediction with confidence scores
Provider flexibility ❌ Vendor-locked ✅ Works with any LLM: OpenAI, Claude, Gemini...
Structured output ❌ Raw text parsing ✅ Typed results with char count + pixel width
CI integration ❌ Manual review ✅ Deterministic SERP eligibility in pipelines

LLM-Agnostic AI SEO


Features

  • LLM-agnostic design — no bundled SDK; prompt builders return { system, user, maxTokens }, parsers accept raw text strings
  • Works with any provider — OpenAI GPT-4o, Anthropic Claude, Google Gemini, Mistral, Cohere, local Ollama models, or any HTTP-based LLM
  • Meta description generationbuildMetaDescriptionPrompt produces prompts targeting 120–158 character descriptions that include the focus keyphrase and a compelling call-to-action; parseMetaDescriptionResponse extracts a single optimized candidate with validation status, character count and estimated pixel width
  • SEO title generationbuildTitlePrompt produces prompts for 5 optimized title tag variants; parseTitleResponse returns title candidates with character counts
  • Content improvement suggestionsbuildContentSuggestionsPrompt analyzes existing content for gaps; parseContentSuggestionsResponse returns typed suggestions for headings, paragraphs, keywords, and links with priority levels
  • SERP feature predictionbuildSerpPredictionPrompt and parseSerpPredictionResponse predict which SERP features (Featured Snippet, FAQ, HowTo, Product, Review, Video, etc.) a page is likely to appear in, with likelihood scores and requirements
  • Rule-based SERP eligibilityanalyzeSerpEligibility(input) is fully deterministic: no LLM required, no cost, instant execution; checks FAQ schema presence, HowTo step structure, Product schema completeness, and more
  • Structured output parsing — all parsers handle common LLM output variations (markdown code blocks, numbered lists, JSON) robustly
  • ContentSuggestionType union — type-safe suggestion categories: heading, paragraph, keyword, link
  • SerpFeature union — type-safe SERP feature identifiers: featured-snippet, faq-rich-result, how-to, product, review, video, image-pack, local-pack, sitelinks
  • Character and pixel width metadata — response objects include charCount and pixelWidth for each generated variant
  • Type-safe throughout — comprehensive TypeScript types for all inputs, outputs, and intermediate structures
  • Zero runtime dependencies — no external packages required

AI Content Suggestions UI


Comparison

Feature @power-seo/ai LangChain Vercel AI SDK Custom prompts
Provider-agnostic prompt builders Partial
SEO-specific prompt templates Manual
Structured response parsers Partial Partial Manual
Rule-based SERP eligibility
Char + pixel width metadata
Zero SDK dependencies
TypeScript-first Partial
Tree-shakeable Partial
CI / Node.js usage

AI Parsing Accuracy


Installation

npm install @power-seo/ai
yarn add @power-seo/ai
pnpm add @power-seo/ai

Quick Start

import { buildMetaDescriptionPrompt, parseMetaDescriptionResponse } from '@power-seo/ai';

// 1. Build the prompt
const prompt = buildMetaDescriptionPrompt({
  title: 'Best Coffee Shops in New York City',
  content: 'Explore the top 15 coffee shops in NYC, from specialty espresso bars in Brooklyn...',
  focusKeyphrase: 'coffee shops nyc',
});

// 2. Send to your LLM of choice (example uses OpenAI)
import OpenAI from 'openai';
const openai = new OpenAI({ apiKey: process.env.OPENAI_API_KEY });

const response = await openai.chat.completions.create({
  model: 'gpt-4o',
  messages: [
    { role: 'system', content: prompt.system },
    { role: 'user', content: prompt.user },
  ],
  max_tokens: prompt.maxTokens,
});

// 3. Parse the raw text response
const result = parseMetaDescriptionResponse(response.choices[0].message.content ?? '');
console.log(`"${result.description}" — ${result.charCount} chars, ~${result.pixelWidth}px`);
console.log(`Valid: ${result.isValid}`);

LLM-Agnostic Benefit


Usage

Meta Description Generation

import { buildMetaDescriptionPrompt, parseMetaDescriptionResponse } from '@power-seo/ai';
import type { MetaDescriptionInput, MetaDescriptionResult } from '@power-seo/ai';

const input: MetaDescriptionInput = {
  title: 'How to Optimize React Apps for SEO',
  content: 'Full article HTML or plain text about React SEO strategies...',
  focusKeyphrase: 'react seo optimization',
};

const prompt = buildMetaDescriptionPrompt(input);
// { system: 'You are an expert SEO copywriter...', user: 'Write 3 meta descriptions...', maxTokens: 300 }

const rawResponse = await yourLLM.complete(prompt.system, prompt.user, prompt.maxTokens);
const result: MetaDescriptionResult = parseMetaDescriptionResponse(rawResponse);

console.log(`"${result.description}"`);
console.log(`  ${result.charCount} characters, ~${result.pixelWidth}px`);
console.log(`  Valid: ${result.isValid}`);
if (result.validationMessage) console.log(`  Message: ${result.validationMessage}`);

SEO Title Generation

import { buildTitlePrompt, parseTitleResponse } from '@power-seo/ai';
import type { TitleInput, TitleResult } from '@power-seo/ai';

const input: TitleInput = {
  content: 'Article about the best tools for keyword research in 2026...',
  focusKeyphrase: 'keyword research tools',
  tone: 'informative',
};

const prompt = buildTitlePrompt(input);
const rawResponse = await yourLLM.complete(prompt.system, prompt.user, prompt.maxTokens);

const results: TitleResult[] = parseTitleResponse(rawResponse);
results.forEach(({ title, charCount, pixelWidth }, i) => {
  const status = charCount <= 60 ? 'OK' : 'TOO LONG';
  console.log(`${i + 1}. "${title}" — ${charCount} chars [${status}]`);
});

Content Improvement Suggestions

import { buildContentSuggestionsPrompt, parseContentSuggestionsResponse } from '@power-seo/ai';
import type { ContentSuggestionInput, ContentSuggestion } from '@power-seo/ai';

const input: ContentSuggestionInput = {
  title: 'React SEO Best Practices',
  content: '<h1>React SEO</h1><p>React is a JavaScript library...</p>',
  focusKeyphrase: 'react seo best practices',
  analysisResults: 'Current score: 58/100. Missing headings structure.',
};

const prompt = buildContentSuggestionsPrompt(input);
const rawResponse = await yourLLM.complete(prompt.system, prompt.user, prompt.maxTokens);

const suggestions: ContentSuggestion[] = parseContentSuggestionsResponse(rawResponse);
suggestions.forEach(({ type, suggestion, priority }) => {
  console.log(`[Priority ${priority}] ${type}: ${suggestion}`);
});

// Example output:
// [Priority 5] heading: Add h2 subheadings for "Server-Side Rendering" topic
// [Priority 4] paragraph: Expand "React Hooks" section with more examples
// [Priority 3] keyword: Increase usage of "react seo best practices" by 1-2 more mentions
// [Priority 2] link: Link to related article on Next.js SSR optimization

Suggestion types:

Type Description
heading Heading structure improvements and additions
paragraph Paragraph content improvements and rewrites
keyword Keyphrase density and placement optimization
link Internal linking opportunities and suggestions

SERP Feature Prediction

Use the LLM-powered prediction for nuanced, content-aware eligibility assessment.

import { buildSerpPredictionPrompt, parseSerpPredictionResponse } from '@power-seo/ai';
import type { SerpFeatureInput, SerpFeaturePrediction } from '@power-seo/ai';

const input: SerpFeatureInput = {
  title: 'How to Make Cold Brew Coffee at Home',
  content: '<h1>Cold Brew Coffee</h1><h2>Step 1: Grind the Coffee</h2><p>...</p>',
  schema: ['HowTo', 'Recipe'],
  contentType: 'guide',
};

const prompt = buildSerpPredictionPrompt(input);
const rawResponse = await yourLLM.complete(prompt.system, prompt.user, prompt.maxTokens);

const predictions: SerpFeaturePrediction[] = parseSerpPredictionResponse(rawResponse);
predictions.forEach(({ feature, likelihood, requirements, met }) => {
  console.log(`${feature}: ${(likelihood * 100).toFixed(0)}% likelihood`);
  console.log(`  Requirements: ${requirements.join(', ')}`);
  console.log(`  Met: ${met.join(', ')}`);
});

Rule-Based SERP Eligibility

analyzeSerpEligibility is entirely deterministic — no LLM, no API call, no cost.

import { analyzeSerpEligibility } from '@power-seo/ai';

// HowTo — detected by step-structured headings and HowTo schema
const result = analyzeSerpEligibility({
  title: 'How to Install Node.js on Ubuntu',
  content: '<h2>Step 1: Update apt</h2><p>...</p><h2>Step 2: Install nvm</h2><p>...</p>',
  schema: ['HowTo'],
});
// Returns array with SerpFeaturePrediction objects, including:
// { feature: 'how-to', likelihood: 0.8, requirements: [...], met: [...] }

// FAQ — detected by FAQPage schema
const faqResult = analyzeSerpEligibility({
  title: 'React SEO FAQ',
  content: '<h2>Does React hurt SEO?</h2><p>...</p><h2>How do I add meta tags?</h2><p>...</p>',
  schema: ['FAQPage'],
});
// Returns array including:
// { feature: 'faq-rich-result', likelihood: 0.9, requirements: [...], met: [...] }

Provider Integration Examples

// OpenAI
import OpenAI from 'openai';
import { buildMetaDescriptionPrompt, parseMetaDescriptionResponse } from '@power-seo/ai';

const openai = new OpenAI({ apiKey: process.env.OPENAI_API_KEY });
const prompt = buildMetaDescriptionPrompt({
  title: 'My Article',
  content: '...',
  focusKeyphrase: 'my topic',
});

const openaiResponse = await openai.chat.completions.create({
  model: 'gpt-4o',
  messages: [
    { role: 'system', content: prompt.system },
    { role: 'user', content: prompt.user },
  ],
  max_tokens: prompt.maxTokens,
});
const result = parseMetaDescriptionResponse(openaiResponse.choices[0].message.content ?? '');

// Anthropic Claude
import Anthropic from '@anthropic-ai/sdk';
const anthropic = new Anthropic({ apiKey: process.env.ANTHROPIC_API_KEY });

const claudeResponse = await anthropic.messages.create({
  model: 'claude-opus-4-6',
  system: prompt.system,
  messages: [{ role: 'user', content: prompt.user }],
  max_tokens: prompt.maxTokens,
});
const result2 = parseMetaDescriptionResponse(
  claudeResponse.content[0].type === 'text' ? claudeResponse.content[0].text : '',
);

// Google Gemini
import { GoogleGenerativeAI } from '@google/generative-ai';
const genai = new GoogleGenerativeAI(process.env.GEMINI_API_KEY!);
const model = genai.getGenerativeModel({ model: 'gemini-1.5-pro' });
const geminiResponse = await model.generateContent(`${prompt.system}\n\n${prompt.user}`);
const result3 = parseMetaDescriptionResponse(geminiResponse.response.text());

API Reference

buildMetaDescriptionPrompt(input) / parseMetaDescriptionResponse(text)

Parameter Type Default Description
input.title string required Page title for context
input.content string required Page content (HTML or plain text)
input.focusKeyphrase string Focus keyphrase to include in descriptions
input.maxLength number 158 Maximum character length
input.tone string Tone hint for the LLM

buildMetaDescriptionPrompt returns PromptTemplate: { system: string; user: string; maxTokens: number }.

parseMetaDescriptionResponse(text: string) returns MetaDescriptionResult: { description: string; charCount: number; pixelWidth: number; isValid: boolean; validationMessage?: string }.


buildTitlePrompt(input) / parseTitleResponse(text)

Parameter Type Default Description
input.content string required Page content for context
input.focusKeyphrase string Focus keyphrase for the title
input.tone string Tone hint for the LLM

buildTitlePrompt returns PromptTemplate.

parseTitleResponse(text: string) returns TitleResult[]: Array<{ title: string; charCount: number; pixelWidth: number }>.


buildContentSuggestionsPrompt(input) / parseContentSuggestionsResponse(text)

Parameter Type Default Description
input.title string required Page title
input.content string required Page HTML or plain text content
input.focusKeyphrase string Focus keyphrase
input.analysisResults string Current analysis results for context

buildContentSuggestionsPrompt returns PromptTemplate.

parseContentSuggestionsResponse(text: string) returns ContentSuggestion[]: Array<{ type: ContentSuggestionType; suggestion: string; priority: number }>.


buildSerpPredictionPrompt(input) / parseSerpPredictionResponse(text)

Parameter Type Default Description
input.title string required Page title
input.content string required Page content
input.schema string[] Schema types present on the page
input.contentType string Content type hint (guide, article, etc)

buildSerpPredictionPrompt returns PromptTemplate.

parseSerpPredictionResponse(text: string) returns SerpFeaturePrediction[]: Array<{ feature: SerpFeature; likelihood: number; requirements: string[]; met: string[] }>.


analyzeSerpEligibility(input)

Parameter Type Default Description
input.title string required Page title
input.content string required Page HTML content
input.schema string[] Schema types present
input.contentType string Content type hint

Returns SerpFeaturePrediction[]. Fully deterministic — no LLM required. Analyzes page structure, headings, and schema to predict eligible SERP features.


Types

import type {
  PromptTemplate, // { system: string; user: string; maxTokens?: number }
  MetaDescriptionInput, // { title, content, focusKeyphrase?, maxLength?, tone? }
  MetaDescriptionResult, // { description, charCount, pixelWidth, isValid, validationMessage? }
  ContentSuggestionInput, // { title, content, focusKeyphrase?, analysisResults? }
  ContentSuggestionType, // 'heading' | 'paragraph' | 'keyword' | 'link'
  ContentSuggestion, // { type: ContentSuggestionType; suggestion: string; priority: number }
  SerpFeature, // 'featured-snippet' | 'faq-rich-result' | 'how-to' | 'product' | 'review' | 'video' | 'image-pack' | 'local-pack' | 'sitelinks'
  SerpFeatureInput, // { title, content, schema?, contentType? }
  SerpFeaturePrediction, // { feature: SerpFeature; likelihood: number; requirements: string[]; met: string[] }
  TitleInput, // { content, focusKeyphrase?, tone? }
  TitleResult, // { title: string; charCount: number; pixelWidth: number }
} from '@power-seo/ai';

Use Cases

  • Headless CMS editors — generate meta description and title candidates at publish time; present LLM options to authors before going live
  • SaaS content pipelines — automate meta generation for thousands of programmatically generated pages without manual copywriting
  • Content quality dashboards — surface AI-powered improvement suggestions for low-scoring pages from @power-seo/content-analysis
  • SERP feature optimization — run analyzeSerpEligibility in CI to ensure schema markup remains eligible for rich results after every deploy
  • Multi-LLM A/B testing — compare output quality across OpenAI, Claude, and Gemini using identical prompt builders and measure SERP impact

Architecture Overview

  • Pure TypeScript — no compiled binary, no native modules
  • Provider-agnostic design — prompt builders return { system, user, maxTokens }; parsers accept raw strings
  • Zero runtime dependencies — no LLM SDK bundled; works with any LLM client you bring
  • Framework-agnostic — works in Next.js, Remix, Vite, Node.js, Edge, or any JS runtime
  • SSR compatible — no browser-specific APIs; safe for server-side use
  • Edge runtime safe — no Node.js-specific APIs; runs in Cloudflare Workers, Vercel Edge, Deno
  • Tree-shakeable"sideEffects": false with named exports per function
  • Dual ESM + CJS — ships both formats via tsup for any bundler or require() usage

Supply Chain Security

  • No install scripts (postinstall, preinstall)
  • No runtime network access
  • No eval or dynamic code execution
  • CI-signed builds — all releases published via verified github.com/CyberCraftBD/power-seo workflow
  • Safe for SSR, Edge, and server environments

The @power-seo Ecosystem

All 17 packages are independently installable — use only what you need.

Package Install Description
@power-seo/core npm i @power-seo/core Framework-agnostic utilities, types, validators, and constants
@power-seo/react npm i @power-seo/react React SEO components — meta, Open Graph, Twitter Card, breadcrumbs
@power-seo/meta npm i @power-seo/meta SSR meta helpers for Next.js App Router, Remix v2, and generic SSR
@power-seo/schema npm i @power-seo/schema Type-safe JSON-LD structured data — 23 builders + 22 React components
@power-seo/content-analysis npm i @power-seo/content-analysis Yoast-style SEO content scoring engine with React components
@power-seo/readability npm i @power-seo/readability Readability scoring — Flesch-Kincaid, Gunning Fog, Coleman-Liau, ARI
@power-seo/preview npm i @power-seo/preview SERP, Open Graph, and Twitter/X Card preview generators
@power-seo/sitemap npm i @power-seo/sitemap XML sitemap generation, streaming, index splitting, and validation
@power-seo/redirects npm i @power-seo/redirects Redirect engine with Next.js, Remix, and Express adapters
@power-seo/links npm i @power-seo/links Link graph analysis — orphan detection, suggestions, equity scoring
@power-seo/audit npm i @power-seo/audit Full SEO audit engine — meta, content, structure, performance rules
@power-seo/images npm i @power-seo/images Image SEO — alt text, lazy loading, format analysis, image sitemaps
@power-seo/ai npm i @power-seo/ai LLM-agnostic AI prompt templates and parsers for SEO tasks
@power-seo/analytics npm i @power-seo/analytics Merge GSC + audit data, trend analysis, ranking insights, dashboard
@power-seo/search-console npm i @power-seo/search-console Google Search Console API — OAuth2, service account, URL inspection
@power-seo/integrations npm i @power-seo/integrations Semrush and Ahrefs API clients with rate limiting and pagination
@power-seo/tracking npm i @power-seo/tracking GA4, Clarity, PostHog, Plausible, Fathom — scripts + consent management

About CyberCraft Bangladesh

CyberCraft Bangladesh is a Bangladesh-based enterprise-grade software development and Full Stack SEO service provider company specializing in ERP system development, AI-powered SaaS and business applications, full-stack SEO services, custom website development, and scalable eCommerce platforms. We design and develop intelligent, automation-driven SaaS and enterprise solutions that help startups, SMEs, NGOs, educational institutes, and large organizations streamline operations, enhance digital visibility, and accelerate growth through modern cloud-native technologies.

Website GitHub npm Email

© 2026 CyberCraft Bangladesh · Released under the MIT License