AEO and GEO

Storefront Next ships built-in support for Answer Engine Optimization (AEO) and Generative Engine Optimization (GEO) on the Product Detail Page (PDP) and Product Listing Page (PLP). AEO makes product and category data machine-readable so search engines, voice assistants, and AI-powered answer surfaces can accurately surface facts—name, price, availability, brand—without guessing from unstructured HTML. GEO supplies clear entity structure and aligned metadata so generative and retrieval-augmented AI systems can ground their responses in your storefront’s authoritative data. When a user asks an AI assistant about a product or category you sell, GEO increases the likelihood that the AI cites your storefront as the source.

AEO and GEO have these benefits:

  • Rich results in search engines: Structured Product data enables Google rich snippets: price, availability, and review stars inline in search results.
  • AI citation and grounding: Clear entity graphs (products, offers, breadcrumbs) give Large Language Models (LLMs) and Retrieval-Augmented Generation (RAG) systems verifiable facts to cite rather than fabricated summaries.
  • Voice and assistant surfaces: Answer engines can resolve who, what, how much, and in-stock queries directly from your structured data.
  • Multisite consistency: URL helpers respect site/locale path prefixes and proxy headers, so structured data links are correct across all your storefronts without manual configuration.
  • Zero page-breakage risk: Schema generation runs in a deferred Promise. If it fails, the page renders normally with no script tag or broken pages.

Two technical mechanisms work together: JSON-LD and SeoMeta.

MechanismPurposeWhere
JSON-LD (<script type="application/ld+json">)Structured entity data for crawlers and AI systemsPDP and PLP route loaders → JsonLd component
SeoMetaClassic <title>, <meta name="description">, Open Graph tagsProductContent (PDP) and category route (PLP)

JSON-LD is the primary AEO and GEO signal. SeoMeta complements it—crawlers and social previews still read <head> tags even when structured data is present.

The PDP emits a schema.org/Product graph with these fields populated from B2C Commerce API (SCAPI) data when available.

FieldSource
nameproduct.name
descriptionlongDescription, falling back to shortDescription, then pageDescription if earlier fields are empty
imageUp to 5 large or medium images (thumbnails excluded)
sku, productIDproduct.id
urlPublic storefront origin + current path
brandproduct.brand
mpnproduct.manufacturerSKU
gtinproduct.ean
categoryproduct.primaryCategoryId
colorFirst color variation attribute value
additionalPropertyAll variation attributes + custom attributes as PropertyValue
offers.priceEffective price (base or promo)
offers.priceCurrencyproduct.currency
offers.availabilityDerived from inventory (InStock, OutOfStock, BackOrder, and PreOrder)
offers.priceValidUntilOne year from generation date (default horizon)
offers.lowPrice and highPricePopulated for master products with a price range across variants

SeoMeta sets <title> to the product name, meta description to pageDescription or shortDescription, and Open Graph og:type to product with the page URL and primary image.

File:

The PLP emits a schema.org/CollectionPage with a mainEntity of type ItemList.

CollectionPage

  • name: Category name
  • description: category.pageDescription, when present
  • url: Canonical category URL

ItemList (inside mainEntity)

  • numberOfItems: Total from search result
  • itemListElement: Up to 24 products, each as a ListItem wrapping a lightweight Product (name, url, image, offers)

Each list item uses the lowest promotional price when promotions exist. Otherwise, it uses the base price. For master products, the schema considers variant-level prices.

The orderable field on the search hit drives availability. If the hit doesn’t expose orderability but config.search.products.refine.orderableOnly is true, then the storefront infers InStock availability for all listed hits.

Built from parentCategoryTree when present, plus the current category. All category URLs use buildCategorySchemaUrl to preserve site/locale prefixes.

The loader merges critical and non-critical search hits before schema generation, so the ItemList reflects the full first page of results, not just the above-the-fold slice.

Sets <title> to the category name, meta description to pageDescription or the general description, and og:type to website with the canonical page URL.

File:

Storefront Next builds all JSON-LD URLs from the public storefront origin, not from product.slugUrl or internal API URLs. This approach is critical in serverless or proxied environments, such as Managed Runtime and content delivery networks (CDNs), where request.url can contain internal routing addresses.

File:

Key functions:

Storefront Next extracts the site/locale prefix (for example, /global/en-GB) from the current page URL and prepends it to every linked URL inside the schema.

Both PDP and PLP inject JSON-LD via the JsonLd component, which renders a <script type="application/ld+json"> tag. The loader defers schema generation and returns an unresolved Promise. JsonLd is wrapped in <Suspense> using React’s use() so that it streams with Server-Side Rendering (SSR) after product data is ready.

If generateProductSchema or generateCategorySchema throws, the error is logged in development and no script tag is rendered. The page continues to load normally.

Script IDs:

  • PDP: id="product-schema"
  • PLP: id="category-schema"

The ProductSchema type already includes an aggregateRating field. Wire it in product-schema.ts after fetching rating data from your review provider:

If your PDP or editorial pages include FAQ content, add a FAQPage schema alongside the product schema:

The quality of AEO/GEO signals depends directly on the data in your B2C Commerce catalog. Make sure that these Business Manager fields are populated for every product and category.

  • pageDescription: Used as the meta description and JSON-LD description
  • longDescription or shortDescription: Fallbacks for JSON-LD description
  • brand: Populates schema:brand
  • ean: Populates schema:gtin
  • manufacturerSKU: Populates schema:mpn

Google’s Rich Results Test flags structured data that contradicts visible on-page content as a quality issue. Keep catalog fields in sync with what shoppers see.

After making changes, validate with:

In development, JsonLd logs errors to the console when invalid data is passed. These errors are suppressed in production.

  • SEO and Metadata: Canonical URLs, hreflang, full SeoMeta prop reference, query-parameter allowlists