sanity-plugin-seofields 1.6.3 → 1.6.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/dist/{SeoPreview-XVAZYHCL.js → SeoPreview-KEGGQSPJ.js} +5 -4
  2. package/dist/{SeoPreview-PYYVZMY3.cjs.map → SeoPreview-KEGGQSPJ.js.map} +1 -1
  3. package/dist/{SeoPreview-PYYVZMY3.cjs → SeoPreview-WYH7NYNM.cjs} +6 -5
  4. package/dist/SeoPreview-WYH7NYNM.cjs.map +1 -0
  5. package/dist/{chunk-XXQURVNE.cjs → chunk-BCTPOWXA.cjs} +111 -111
  6. package/dist/{chunk-XXQURVNE.cjs.map → chunk-BCTPOWXA.cjs.map} +1 -1
  7. package/dist/{chunk-25JLWVEU.js → chunk-HDZZQCH7.js} +14 -8
  8. package/dist/chunk-HDZZQCH7.js.map +1 -0
  9. package/dist/{chunk-IQG5JWVT.js → chunk-KTL6NYNG.js} +4 -2
  10. package/dist/chunk-KTL6NYNG.js.map +1 -0
  11. package/dist/{chunk-ULFY5STC.js → chunk-XXA6WCWS.js} +3 -3
  12. package/dist/{chunk-ULFY5STC.js.map → chunk-XXA6WCWS.js.map} +1 -1
  13. package/dist/{chunk-YM3ZZ2HU.cjs → chunk-YHXUWGNA.cjs} +4 -2
  14. package/dist/chunk-YHXUWGNA.cjs.map +1 -0
  15. package/dist/{chunk-IFDLKZET.cjs → chunk-ZBHLMQTS.cjs} +14 -8
  16. package/dist/chunk-ZBHLMQTS.cjs.map +1 -0
  17. package/dist/cli.js +1 -1
  18. package/dist/{component-DS-Ve_nw.d.cts → component-CIE6Sy4F.d.cts} +1 -1
  19. package/dist/{component-CWZ0tlsq.d.ts → component-H52blyfc.d.ts} +1 -1
  20. package/dist/index.cjs +40 -15
  21. package/dist/index.cjs.map +1 -1
  22. package/dist/index.js +32 -7
  23. package/dist/index.js.map +1 -1
  24. package/dist/next.cjs +77 -77
  25. package/dist/next.d.cts +2 -2
  26. package/dist/next.d.ts +2 -2
  27. package/dist/next.js +2 -2
  28. package/dist/schema/next.cjs +80 -80
  29. package/dist/schema/next.d.cts +3 -3
  30. package/dist/schema/next.d.ts +3 -3
  31. package/dist/schema/next.js +3 -3
  32. package/dist/schema.cjs +153 -153
  33. package/dist/schema.d.cts +4 -4
  34. package/dist/schema.d.ts +4 -4
  35. package/dist/schema.js +2 -2
  36. package/dist/{types-BdaGoGQE.d.cts → types-BxcJinOf.d.cts} +8 -8
  37. package/dist/{types-Dy7r5det.d.ts → types-CbYb4MsN.d.ts} +1 -1
  38. package/dist/{types-BjVpmBAX.d.cts → types-CyRdIF-3.d.cts} +1 -1
  39. package/dist/{types-BwmZmt9I.d.ts → types-Dp9Pfnt9.d.ts} +8 -8
  40. package/package.json +1 -1
  41. package/dist/SeoPreview-XVAZYHCL.js.map +0 -1
  42. package/dist/chunk-25JLWVEU.js.map +0 -1
  43. package/dist/chunk-IFDLKZET.cjs.map +0 -1
  44. package/dist/chunk-IQG5JWVT.js.map +0 -1
  45. package/dist/chunk-YM3ZZ2HU.cjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/schema/utils.ts","../src/schema/SchemaOrgScript.tsx","../src/schema/organization/component.tsx","../src/schema/website/component.tsx","../src/schema/SchemaOrgScripts.tsx","../src/schema/aggregateRating/component.tsx","../src/schema/article/component.tsx","../src/schema/blogPosting/component.tsx","../src/schema/book/component.tsx","../src/schema/brand/component.tsx","../src/schema/breadcrumbList/component.tsx","../src/schema/contactPoint/component.tsx","../src/schema/country/component.tsx","../src/schema/course/component.tsx","../src/schema/event/component.tsx","../src/schema/faqPage/component.tsx","../src/schema/howTo/component.tsx","../src/schema/imageObject/component.tsx","../src/schema/itemList/component.tsx","../src/schema/jobPosting/component.tsx","../src/schema/legalService/component.tsx","../src/schema/localBusiness/component.tsx","../src/schema/movie/component.tsx","../src/schema/musicAlbum/component.tsx","../src/schema/musicRecording/component.tsx","../src/schema/newsArticle/component.tsx","../src/schema/offer/component.tsx","../src/schema/person/component.tsx","../src/schema/place/component.tsx","../src/schema/postalAddress/component.tsx","../src/schema/product/component.tsx","../src/schema/profilePage/component.tsx","../src/schema/recipe/component.tsx","../src/schema/restaurant/component.tsx","../src/schema/review/component.tsx","../src/schema/service/component.tsx","../src/schema/softwareApplication/component.tsx","../src/schema/videoObject/component.tsx","../src/schema/webApplication/component.tsx","../src/schema/webPage/component.tsx"],"names":["jsx","resolvePolymorphicPersonOrOrg","webPageFields","personFields","breadcrumbListFields","imageObjectFields","articleFields","blogPostingFields","faqPageFields","howToFields","productFields","offerFields","aggregateRatingFields","reviewFields","brandFields","localBusinessFields","postalAddressFields","contactPointFields","softwareApplicationFields","webApplicationFields","eventFields","placeFields","videoObjectFields","courseFields","legalServiceFields","countryFields","bookFields","itemListFields","jobPostingFields","movieFields","musicAlbumFields","musicRecordingFields","newsArticleFields","profilePageFields","recipeFields","restaurantFields","serviceFields","socialMediaPostingFields","buildGenericJsonLd","Fragment"],"mappings":"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","file":"chunk-XXQURVNE.cjs","sourcesContent":["/**\n * Escapes characters in a JSON string that could enable XSS when embedded\n * inside a `<script>` tag. Prevents `</script>` breakout, HTML comment\n * injection, and Unicode line terminators that can break JS parsing.\n */\nexport function escapeJsonForScript(json: string): string {\n return json\n .replace(/</g, '\\\\u003C')\n .replace(/>/g, '\\\\u003E')\n .replace(/&/g, '\\\\u0026')\n .replace(/\\u2028/g, '\\\\u2028')\n .replace(/\\u2029/g, '\\\\u2029')\n}\n","/**\n * Shared component that renders a `<script type=\"application/ld+json\">` tag.\n * Used by all Schema.org type components.\n */\nimport {JSX} from 'react'\n\nimport {escapeJsonForScript} from './utils'\n\nexport function SchemaOrgScript({\n jsonLd,\n}: {\n jsonLd: Record<string, unknown> | null\n}): JSX.Element | null {\n if (!jsonLd) return null\n\n return (\n <script\n type=\"application/ld+json\"\n // eslint-disable-next-line react/no-danger\n dangerouslySetInnerHTML={{__html: escapeJsonForScript(JSON.stringify(jsonLd))}}\n />\n )\n}\n","/**\n * <OrganizationSchema> — Renders Schema.org Organization JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { OrganizationSchema } from 'sanity-plugin-seofields/next/organization'\n *\n * const data = await sanityFetch({ query: `*[_type == \"settings\"][0]{ organization }` })\n *\n * <OrganizationSchema data={data.organization} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport type {SanityImage} from '../../types'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport type {SchemaOrgOrganizationData} from './types'\n\nexport interface OrganizationSchemaProps {\n /** The Schema.org Organization data from your Sanity GROQ query. */\n data?: SchemaOrgOrganizationData | null\n /**\n * Resolve a Sanity image asset to a URL string (for the logo field).\n * Only needed if you use the Sanity image upload field instead of logoUrl.\n *\n * @example\n * imageUrlResolver={(img) => urlFor(img).width(600).url()}\n */\n imageUrlResolver?: (image: SanityImage) => string | null | undefined\n}\n\n/**\n * Builds a Schema.org Organization JSON-LD object from Sanity data.\n * Returns `null` if required fields (name, url) are missing.\n */\nexport function buildOrganizationJsonLd(\n data?: SchemaOrgOrganizationData | null,\n imageUrlResolver?: (image: SanityImage) => string | null | undefined,\n): Record<string, unknown> | null {\n if (!data?.name || !data?.url) return null\n\n const jsonLd: Record<string, unknown> = {\n '@context': 'https://schema.org',\n '@type': 'Organization',\n name: data.name,\n url: data.url,\n }\n\n // Resolve logo — prefer explicit URL, fall back to Sanity image\n const logoUrl =\n data.logoUrl || (data.logo && imageUrlResolver ? imageUrlResolver(data.logo) : undefined)\n if (logoUrl) jsonLd.logo = logoUrl\n\n if (data.description) jsonLd.description = data.description\n\n if (data.sameAs) jsonLd.sameAs = data.sameAs\n\n if (data.contactPoint?.contactType) {\n const cp: Record<string, unknown> = {\n '@type': 'ContactPoint',\n contactType: data.contactPoint.contactType,\n }\n if (data.contactPoint.email) cp.email = data.contactPoint.email\n if (data.contactPoint.availableLanguage?.length) {\n cp.availableLanguage = data.contactPoint.availableLanguage\n }\n jsonLd.contactPoint = cp\n }\n\n return jsonLd\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Organization data.\n * Renders nothing if required fields are missing.\n */\nexport function OrganizationSchema({\n data,\n imageUrlResolver,\n}: OrganizationSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildOrganizationJsonLd(data, imageUrlResolver)} />\n}\n\nexport default OrganizationSchema\n","/**\n * <WebsiteSchema> — Renders Schema.org WebSite JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { WebsiteSchema } from 'sanity-plugin-seofields/next/website'\n *\n * const data = await sanityFetch({ query: `*[_type == \"settings\"][0]{ website }` })\n *\n * <WebsiteSchema data={data.website} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {resolvePolymorphicPersonOrOrg} from '../_shared'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport type {SchemaOrgWebsiteData} from './types'\n\nexport interface WebsiteSchemaProps {\n /** The Schema.org Website data from your Sanity GROQ query. */\n data?: SchemaOrgWebsiteData | null\n}\n\n/**\n * Builds a Schema.org WebSite JSON-LD object from Sanity data.\n * Returns `null` if required fields (name, url) are missing.\n */\nexport function buildWebsiteJsonLd(\n data?: SchemaOrgWebsiteData | null,\n): Record<string, unknown> | null {\n if (!data?.name || !data?.url) return null\n\n const jsonLd: Record<string, unknown> = {\n '@context': 'https://schema.org',\n '@type': 'WebSite',\n name: data.name,\n url: data.url,\n }\n\n if (data.description) jsonLd.description = data.description\n if (data.inLanguage) jsonLd.inLanguage = data.inLanguage\n\n const publisher = resolvePolymorphicPersonOrOrg(data.publisher)\n if (publisher) jsonLd.publisher = publisher\n\n return jsonLd\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org WebSite data.\n * Renders nothing if required fields are missing.\n */\nexport function WebsiteSchema({data}: WebsiteSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildWebsiteJsonLd(data)} />\n}\n\nexport default WebsiteSchema\n","/**\n * <SchemaOrgScripts> — Renders multiple Schema.org JSON-LD script tags\n * from a combined `schemaOrg` array field.\n *\n * @example\n * ```tsx\n * import { SchemaOrgScripts } from 'sanity-plugin-seofields/next'\n *\n * const data = await sanityFetch({ query: `*[_type == \"settings\"][0]{ structuredData }` })\n *\n * <SchemaOrgScripts data={data.structuredData} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {aggregateRatingFields} from './aggregateRating/schema'\nimport {articleFields} from './article/schema'\nimport {blogPostingFields} from './blogPosting/schema'\nimport {bookFields} from './book/schema'\nimport {brandFields} from './brand/schema'\nimport {breadcrumbListFields} from './breadcrumbList/schema'\nimport {contactPointFields} from './contactPoint/schema'\nimport {countryFields} from './country/schema'\nimport {courseFields} from './course/schema'\nimport {eventFields} from './event/schema'\nimport {faqPageFields} from './faqPage/schema'\nimport {buildGenericJsonLd, SchemaFieldDef} from './generator'\nimport {howToFields} from './howTo/schema'\nimport {imageObjectFields} from './imageObject/schema'\nimport {itemListFields} from './itemList/schema'\nimport {jobPostingFields} from './jobPosting/schema'\nimport {legalServiceFields} from './legalService/schema'\nimport {localBusinessFields} from './localBusiness/schema'\nimport {movieFields} from './movie/schema'\nimport {musicAlbumFields} from './musicAlbum/schema'\nimport {musicRecordingFields} from './musicRecording/schema'\nimport {newsArticleFields} from './newsArticle/schema'\nimport {offerFields} from './offer/schema'\nimport {buildOrganizationJsonLd} from './organization/component'\nimport {personFields} from './person/schema'\nimport {placeFields} from './place/schema'\nimport {postalAddressFields} from './postalAddress/schema'\nimport {productFields} from './product/schema'\nimport {profilePageFields} from './profilePage/schema'\nimport {recipeFields} from './recipe/schema'\nimport {restaurantFields} from './restaurant/schema'\nimport {reviewFields} from './review/schema'\nimport {SchemaOrgScript} from './SchemaOrgScript'\nimport {serviceFields} from './service/schema'\nimport {socialMediaPostingFields} from './socialMediaPosting/schema'\nimport {softwareApplicationFields} from './softwareApplication/schema'\nimport {videoObjectFields} from './videoObject/schema'\nimport {webApplicationFields} from './webApplication/schema'\nimport {webPageFields} from './webPage/schema'\nimport {buildWebsiteJsonLd} from './website/component'\n\n// ─── Type → Builder Registry ──────────────────────────────────────────────────\n\ninterface GenericEntry {\n schemaType: string\n fields: SchemaFieldDef[]\n requiredFields: string[]\n}\n\nconst GENERIC_TYPES: Record<string, GenericEntry> = {\n schemaOrgWebPage: {schemaType: 'WebPage', fields: webPageFields, requiredFields: ['name']},\n schemaOrgPerson: {schemaType: 'Person', fields: personFields, requiredFields: ['name']},\n schemaOrgBreadcrumbList: {\n schemaType: 'BreadcrumbList',\n fields: breadcrumbListFields,\n requiredFields: [],\n },\n schemaOrgImageObject: {\n schemaType: 'ImageObject',\n fields: imageObjectFields,\n requiredFields: ['url'],\n },\n schemaOrgArticle: {schemaType: 'Article', fields: articleFields, requiredFields: ['headline']},\n schemaOrgBlogPosting: {\n schemaType: 'BlogPosting',\n fields: blogPostingFields,\n requiredFields: ['headline'],\n },\n schemaOrgFAQPage: {schemaType: 'FAQPage', fields: faqPageFields, requiredFields: []},\n schemaOrgHowTo: {schemaType: 'HowTo', fields: howToFields, requiredFields: ['name']},\n schemaOrgProduct: {schemaType: 'Product', fields: productFields, requiredFields: ['name']},\n schemaOrgOffer: {schemaType: 'Offer', fields: offerFields, requiredFields: ['price']},\n schemaOrgAggregateRating: {\n schemaType: 'AggregateRating',\n fields: aggregateRatingFields,\n requiredFields: ['ratingValue'],\n },\n schemaOrgReview: {schemaType: 'Review', fields: reviewFields, requiredFields: []},\n schemaOrgBrand: {schemaType: 'Brand', fields: brandFields, requiredFields: ['name']},\n schemaOrgLocalBusiness: {\n schemaType: 'LocalBusiness',\n fields: localBusinessFields,\n requiredFields: ['name'],\n },\n schemaOrgPostalAddress: {\n schemaType: 'PostalAddress',\n fields: postalAddressFields,\n requiredFields: [],\n },\n schemaOrgContactPoint: {\n schemaType: 'ContactPoint',\n fields: contactPointFields,\n requiredFields: [],\n },\n schemaOrgSoftwareApplication: {\n schemaType: 'SoftwareApplication',\n fields: softwareApplicationFields,\n requiredFields: ['name'],\n },\n schemaOrgWebApplication: {\n schemaType: 'WebApplication',\n fields: webApplicationFields,\n requiredFields: ['name'],\n },\n schemaOrgEvent: {schemaType: 'Event', fields: eventFields, requiredFields: ['name']},\n schemaOrgPlace: {schemaType: 'Place', fields: placeFields, requiredFields: ['name']},\n schemaOrgVideoObject: {\n schemaType: 'VideoObject',\n fields: videoObjectFields,\n requiredFields: ['name'],\n },\n schemaOrgCourse: {schemaType: 'Course', fields: courseFields, requiredFields: ['name']},\n schemaOrgLegalService: {\n schemaType: 'LegalService',\n fields: legalServiceFields,\n requiredFields: ['name'],\n },\n schemaOrgCountry: {schemaType: 'Country', fields: countryFields, requiredFields: ['name']},\n schemaOrgBook: {schemaType: 'Book', fields: bookFields, requiredFields: ['name']},\n schemaOrgItemList: {\n schemaType: 'ItemList',\n fields: itemListFields,\n requiredFields: ['name'],\n },\n schemaOrgJobPosting: {\n schemaType: 'JobPosting',\n fields: jobPostingFields,\n requiredFields: ['title'],\n },\n schemaOrgMovie: {schemaType: 'Movie', fields: movieFields, requiredFields: ['name']},\n schemaOrgMusicAlbum: {\n schemaType: 'MusicAlbum',\n fields: musicAlbumFields,\n requiredFields: ['name'],\n },\n schemaOrgMusicRecording: {\n schemaType: 'MusicRecording',\n fields: musicRecordingFields,\n requiredFields: ['name'],\n },\n schemaOrgNewsArticle: {\n schemaType: 'NewsArticle',\n fields: newsArticleFields,\n requiredFields: ['headline'],\n },\n schemaOrgProfilePage: {\n schemaType: 'ProfilePage',\n fields: profilePageFields,\n requiredFields: ['name'],\n },\n schemaOrgRecipe: {schemaType: 'Recipe', fields: recipeFields, requiredFields: ['name']},\n schemaOrgRestaurant: {\n schemaType: 'Restaurant',\n fields: restaurantFields,\n requiredFields: ['name'],\n },\n schemaOrgService: {schemaType: 'Service', fields: serviceFields, requiredFields: ['name']},\n schemaOrgSocialMediaPosting: {\n schemaType: 'SocialMediaPosting',\n fields: socialMediaPostingFields,\n requiredFields: ['headline'],\n },\n}\n\nfunction buildJsonLdForItem(item: Record<string, unknown>): Record<string, unknown> | null {\n const type = item._type as string | undefined\n if (!type) return null\n\n // Website and Organization use custom builders\n if (type === 'schemaOrgWebsite') {\n return buildWebsiteJsonLd(item as Parameters<typeof buildWebsiteJsonLd>[0])\n }\n if (type === 'schemaOrgOrganization') {\n return buildOrganizationJsonLd(item as Parameters<typeof buildOrganizationJsonLd>[0])\n }\n\n // All other types use the generic builder\n const entry = GENERIC_TYPES[type]\n if (!entry) return null\n return buildGenericJsonLd(entry.schemaType, item, entry.fields, entry.requiredFields)\n}\n\n// ─── Component ────────────────────────────────────────────────────────────────\n\nexport interface SchemaOrgScriptsProps {\n /** Array of Schema.org items from the combined `schemaOrg` field. */\n data?: Array<Record<string, unknown>> | null\n}\n\n/**\n * Renders one `<script type=\"application/ld+json\">` tag per Schema.org item.\n * Skips items that fail validation (missing required fields).\n */\nexport function SchemaOrgScripts({data}: SchemaOrgScriptsProps): JSX.Element | null {\n if (!data?.length) return null\n\n const scripts = data\n .map((item) => buildJsonLdForItem(item))\n .filter((jsonLd): jsonLd is Record<string, unknown> => jsonLd !== null)\n\n if (!scripts.length) return null\n\n return (\n <>\n {scripts.map((jsonLd) => (\n <SchemaOrgScript key={JSON.stringify(jsonLd)} jsonLd={jsonLd} />\n ))}\n </>\n )\n}\n\nexport default SchemaOrgScripts\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {aggregateRatingFields} from './schema'\nimport type {SchemaOrgAggregateRatingData} from './types'\n\nexport interface AggregateRatingSchemaProps {\n data?: SchemaOrgAggregateRatingData | null\n}\n\nexport function buildAggregateRatingJsonLd(\n data?: SchemaOrgAggregateRatingData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'AggregateRating',\n data as Record<string, unknown> | null | undefined,\n aggregateRatingFields,\n ['ratingValue'],\n )\n}\n\nexport function AggregateRatingSchema({data}: AggregateRatingSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildAggregateRatingJsonLd(data)} />\n}\n\nexport default AggregateRatingSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {articleFields} from './schema'\nimport type {SchemaOrgArticleData} from './types'\n\nexport interface ArticleSchemaProps {\n /** The Schema.org Article data from your Sanity GROQ query. */\n data?: SchemaOrgArticleData | null\n}\n\n/**\n * Builds a Schema.org Article JSON-LD object from Sanity data.\n * Returns `null` if required fields (headline) are missing.\n */\nexport function buildArticleJsonLd(\n data?: SchemaOrgArticleData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Article',\n data as Record<string, unknown> | null | undefined,\n articleFields,\n ['headline'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Article data.\n * Renders nothing if required fields are missing.\n */\nexport function ArticleSchema({data}: ArticleSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildArticleJsonLd(data)} />\n}\n\nexport default ArticleSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {blogPostingFields} from './schema'\nimport type {SchemaOrgBlogPostingData} from './types'\n\nexport interface BlogPostingSchemaProps {\n /** The Schema.org BlogPosting data from your Sanity GROQ query. */\n data?: SchemaOrgBlogPostingData | null\n}\n\n/**\n * Builds a Schema.org BlogPosting JSON-LD object from Sanity data.\n * Returns `null` if required fields (headline) are missing.\n */\nexport function buildBlogPostingJsonLd(\n data?: SchemaOrgBlogPostingData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'BlogPosting',\n data as Record<string, unknown> | null | undefined,\n blogPostingFields,\n ['headline'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org BlogPosting data.\n * Renders nothing if required fields are missing.\n */\nexport function BlogPostingSchema({data}: BlogPostingSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildBlogPostingJsonLd(data)} />\n}\n\nexport default BlogPostingSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {bookFields} from './schema'\nimport type {SchemaOrgBookData} from './types'\n\nexport interface BookSchemaProps {\n data?: SchemaOrgBookData | null\n}\n\nexport function buildBookJsonLd(data?: SchemaOrgBookData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Book',\n data as Record<string, unknown> | null | undefined,\n bookFields,\n ['name'],\n )\n}\n\nexport function BookSchema({data}: BookSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildBookJsonLd(data)} />\n}\n\nexport default BookSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {brandFields} from './schema'\nimport type {SchemaOrgBrandData} from './types'\n\nexport interface BrandSchemaProps {\n data?: SchemaOrgBrandData | null\n}\n\nexport function buildBrandJsonLd(data?: SchemaOrgBrandData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Brand',\n data as Record<string, unknown> | null | undefined,\n brandFields,\n ['name'],\n )\n}\n\nexport function BrandSchema({data}: BrandSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildBrandJsonLd(data)} />\n}\n\nexport default BrandSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {breadcrumbListFields} from './schema'\nimport type {SchemaOrgBreadcrumbListData} from './types'\n\nexport interface BreadcrumbListSchemaProps {\n /** The Schema.org BreadcrumbList data from your Sanity GROQ query. */\n data?: SchemaOrgBreadcrumbListData | null\n}\n\n/**\n * Builds a Schema.org BreadcrumbList JSON-LD object from Sanity data.\n * Returns `null` if data is missing.\n */\nexport function buildBreadcrumbListJsonLd(\n data?: SchemaOrgBreadcrumbListData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'BreadcrumbList',\n data as Record<string, unknown> | null | undefined,\n breadcrumbListFields,\n [],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org BreadcrumbList data.\n * Renders nothing if data is missing.\n */\nexport function BreadcrumbListSchema({data}: BreadcrumbListSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildBreadcrumbListJsonLd(data)} />\n}\n\nexport default BreadcrumbListSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {contactPointFields} from './schema'\nimport type {SchemaOrgContactPointData} from './types'\n\nexport interface ContactPointSchemaProps {\n data?: SchemaOrgContactPointData | null\n}\n\nexport function buildContactPointJsonLd(\n data?: SchemaOrgContactPointData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'ContactPoint',\n data as Record<string, unknown> | null | undefined,\n contactPointFields,\n ['contactType'],\n )\n}\n\nexport function ContactPointSchema({data}: ContactPointSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildContactPointJsonLd(data)} />\n}\n\nexport default ContactPointSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {countryFields} from './schema'\nimport type {SchemaOrgCountryData} from './types'\n\nexport interface CountrySchemaProps {\n /** The Schema.org Country data from your Sanity GROQ query. */\n data?: SchemaOrgCountryData | null\n}\n\n/**\n * Builds a Schema.org Country JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildCountryJsonLd(\n data?: SchemaOrgCountryData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Country',\n data as Record<string, unknown> | null | undefined,\n countryFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Country data.\n * Renders nothing if required fields are missing.\n */\nexport function CountrySchema({data}: CountrySchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildCountryJsonLd(data)} />\n}\n\nexport default CountrySchema\n","/**\n * <CourseSchema> — Renders Schema.org Course JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { CourseSchema } from 'sanity-plugin-seofields/next/course'\n *\n * const data = await sanityFetch({ query: `*[_type == \"course\"][0]{ seo }` })\n *\n * <CourseSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {courseFields} from './schema'\nimport type {SchemaOrgCourseData} from './types'\n\nexport interface CourseSchemaProps {\n /** The Schema.org Course data from your Sanity GROQ query. */\n data?: SchemaOrgCourseData | null\n}\n\n/**\n * Builds a Schema.org Course JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildCourseJsonLd(\n data?: SchemaOrgCourseData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Course',\n data as Record<string, unknown> | null | undefined,\n courseFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Course data.\n * Renders nothing if required fields are missing.\n */\nexport function CourseSchema({data}: CourseSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildCourseJsonLd(data)} />\n}\n\nexport default CourseSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {eventFields} from './schema'\nimport type {SchemaOrgEventData} from './types'\n\nexport interface EventSchemaProps {\n /** The Schema.org Event data from your Sanity GROQ query. */\n data?: SchemaOrgEventData | null\n}\n\n/**\n * Builds a Schema.org Event JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildEventJsonLd(data?: SchemaOrgEventData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Event',\n data as Record<string, unknown> | null | undefined,\n eventFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Event data.\n * Renders nothing if required fields are missing.\n */\nexport function EventSchema({data}: EventSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildEventJsonLd(data)} />\n}\n\nexport default EventSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {faqPageFields} from './schema'\nimport type {SchemaOrgFAQPageData} from './types'\n\nexport interface FAQPageSchemaProps {\n /** The Schema.org FAQPage data from your Sanity GROQ query. */\n data?: SchemaOrgFAQPageData | null\n}\n\n/**\n * Builds a Schema.org FAQPage JSON-LD object from Sanity data.\n * Returns `null` if data is missing.\n */\nexport function buildFAQPageJsonLd(\n data?: SchemaOrgFAQPageData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'FAQPage',\n data as Record<string, unknown> | null | undefined,\n faqPageFields,\n [],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org FAQPage data.\n * Renders nothing if data is missing.\n */\nexport function FAQPageSchema({data}: FAQPageSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildFAQPageJsonLd(data)} />\n}\n\nexport default FAQPageSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {howToFields} from './schema'\nimport type {SchemaOrgHowToData} from './types'\n\nexport interface HowToSchemaProps {\n /** The Schema.org HowTo data from your Sanity GROQ query. */\n data?: SchemaOrgHowToData | null\n}\n\n/**\n * Builds a Schema.org HowTo JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildHowToJsonLd(data?: SchemaOrgHowToData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'HowTo',\n data as Record<string, unknown> | null | undefined,\n howToFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org HowTo data.\n * Renders nothing if required fields are missing.\n */\nexport function HowToSchema({data}: HowToSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildHowToJsonLd(data)} />\n}\n\nexport default HowToSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {imageObjectFields} from './schema'\nimport type {SchemaOrgImageObjectData} from './types'\n\nexport interface ImageObjectSchemaProps {\n data?: SchemaOrgImageObjectData | null\n}\n\nexport function buildImageObjectJsonLd(\n data?: SchemaOrgImageObjectData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'ImageObject',\n data as Record<string, unknown> | null | undefined,\n imageObjectFields,\n ['url'],\n )\n}\n\nexport function ImageObjectSchema({data}: ImageObjectSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildImageObjectJsonLd(data)} />\n}\n\nexport default ImageObjectSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {itemListFields} from './schema'\nimport type {SchemaOrgItemListData} from './types'\n\nexport interface ItemListSchemaProps {\n data?: SchemaOrgItemListData | null\n}\n\nexport function buildItemListJsonLd(\n data?: SchemaOrgItemListData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'ItemList',\n data as Record<string, unknown> | null | undefined,\n itemListFields,\n [],\n )\n}\n\nexport function ItemListSchema({data}: ItemListSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildItemListJsonLd(data)} />\n}\n\nexport default ItemListSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {jobPostingFields} from './schema'\nimport type {SchemaOrgJobPostingData} from './types'\n\nexport interface JobPostingSchemaProps {\n data?: SchemaOrgJobPostingData | null\n}\n\nexport function buildJobPostingJsonLd(\n data?: SchemaOrgJobPostingData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'JobPosting',\n data as Record<string, unknown> | null | undefined,\n jobPostingFields,\n ['title', 'description', 'datePosted'],\n )\n}\n\nexport function JobPostingSchema({data}: JobPostingSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildJobPostingJsonLd(data)} />\n}\n\nexport default JobPostingSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {legalServiceFields} from './schema'\nimport type {SchemaOrgLegalServiceData} from './types'\n\nexport interface LegalServiceSchemaProps {\n /** The Schema.org LegalService data from your Sanity GROQ query. */\n data?: SchemaOrgLegalServiceData | null\n}\n\n/**\n * Builds a Schema.org LegalService JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildLegalServiceJsonLd(\n data?: SchemaOrgLegalServiceData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'LegalService',\n data as Record<string, unknown> | null | undefined,\n legalServiceFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org LegalService data.\n * Renders nothing if required fields are missing.\n */\nexport function LegalServiceSchema({data}: LegalServiceSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildLegalServiceJsonLd(data)} />\n}\n\nexport default LegalServiceSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {localBusinessFields} from './schema'\nimport type {SchemaOrgLocalBusinessData} from './types'\n\nexport interface LocalBusinessSchemaProps {\n /** The Schema.org LocalBusiness data from your Sanity GROQ query. */\n data?: SchemaOrgLocalBusinessData | null\n}\n\n/**\n * Builds a Schema.org LocalBusiness JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildLocalBusinessJsonLd(\n data?: SchemaOrgLocalBusinessData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'LocalBusiness',\n data as Record<string, unknown> | null | undefined,\n localBusinessFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org LocalBusiness data.\n * Renders nothing if required fields are missing.\n */\nexport function LocalBusinessSchema({data}: LocalBusinessSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildLocalBusinessJsonLd(data)} />\n}\n\nexport default LocalBusinessSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {movieFields} from './schema'\nimport type {SchemaOrgMovieData} from './types'\n\nexport interface MovieSchemaProps {\n data?: SchemaOrgMovieData | null\n}\n\nexport function buildMovieJsonLd(data?: SchemaOrgMovieData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Movie',\n data as Record<string, unknown> | null | undefined,\n movieFields,\n ['name'],\n )\n}\n\nexport function MovieSchema({data}: MovieSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildMovieJsonLd(data)} />\n}\n\nexport default MovieSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {musicAlbumFields} from './schema'\nimport type {SchemaOrgMusicAlbumData} from './types'\n\nexport interface MusicAlbumSchemaProps {\n data?: SchemaOrgMusicAlbumData | null\n}\n\nexport function buildMusicAlbumJsonLd(\n data?: SchemaOrgMusicAlbumData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'MusicAlbum',\n data as Record<string, unknown> | null | undefined,\n musicAlbumFields,\n ['name'],\n )\n}\n\nexport function MusicAlbumSchema({data}: MusicAlbumSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildMusicAlbumJsonLd(data)} />\n}\n\nexport default MusicAlbumSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {musicRecordingFields} from './schema'\nimport type {SchemaOrgMusicRecordingData} from './types'\n\nexport interface MusicRecordingSchemaProps {\n data?: SchemaOrgMusicRecordingData | null\n}\n\nexport function buildMusicRecordingJsonLd(\n data?: SchemaOrgMusicRecordingData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'MusicRecording',\n data as Record<string, unknown> | null | undefined,\n musicRecordingFields,\n ['name'],\n )\n}\n\nexport function MusicRecordingSchema({data}: MusicRecordingSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildMusicRecordingJsonLd(data)} />\n}\n\nexport default MusicRecordingSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {newsArticleFields} from './schema'\nimport type {SchemaOrgNewsArticleData} from './types'\n\nexport interface NewsArticleSchemaProps {\n data?: SchemaOrgNewsArticleData | null\n}\n\nexport function buildNewsArticleJsonLd(\n data?: SchemaOrgNewsArticleData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'NewsArticle',\n data as Record<string, unknown> | null | undefined,\n newsArticleFields,\n ['headline', 'datePublished'],\n )\n}\n\nexport function NewsArticleSchema({data}: NewsArticleSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildNewsArticleJsonLd(data)} />\n}\n\nexport default NewsArticleSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {offerFields} from './schema'\nimport type {SchemaOrgOfferData} from './types'\n\nexport interface OfferSchemaProps {\n data?: SchemaOrgOfferData | null\n}\n\nexport function buildOfferJsonLd(data?: SchemaOrgOfferData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Offer',\n data as Record<string, unknown> | null | undefined,\n offerFields,\n ['price'],\n )\n}\n\nexport function OfferSchema({data}: OfferSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildOfferJsonLd(data)} />\n}\n\nexport default OfferSchema\n","/**\n * <PersonSchema> — Renders Schema.org Person JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { PersonSchema } from 'sanity-plugin-seofields/next/person'\n *\n * const data = await sanityFetch({ query: `*[_type == \"teamMember\"][0]{ person }` })\n *\n * <PersonSchema data={data.person} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {personFields} from './schema'\nimport type {SchemaOrgPersonData} from './types'\n\nexport interface PersonSchemaProps {\n /** The Schema.org Person data from your Sanity GROQ query. */\n data?: SchemaOrgPersonData | null\n}\n\n/**\n * Builds a Schema.org Person JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildPersonJsonLd(\n data?: SchemaOrgPersonData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Person',\n data as Record<string, unknown> | null | undefined,\n personFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Person data.\n * Renders nothing if required fields are missing.\n */\nexport function PersonSchema({data}: PersonSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildPersonJsonLd(data)} />\n}\n\nexport default PersonSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {placeFields} from './schema'\nimport type {SchemaOrgPlaceData} from './types'\n\nexport interface PlaceSchemaProps {\n /** The Schema.org Place data from your Sanity GROQ query. */\n data?: SchemaOrgPlaceData | null\n}\n\n/**\n * Builds a Schema.org Place JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildPlaceJsonLd(data?: SchemaOrgPlaceData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Place',\n data as Record<string, unknown> | null | undefined,\n placeFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Place data.\n * Renders nothing if required fields are missing.\n */\nexport function PlaceSchema({data}: PlaceSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildPlaceJsonLd(data)} />\n}\n\nexport default PlaceSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {postalAddressFields} from './schema'\nimport type {SchemaOrgPostalAddressData} from './types'\n\nexport interface PostalAddressSchemaProps {\n data?: SchemaOrgPostalAddressData | null\n}\n\nexport function buildPostalAddressJsonLd(\n data?: SchemaOrgPostalAddressData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'PostalAddress',\n data as Record<string, unknown> | null | undefined,\n postalAddressFields,\n [],\n )\n}\n\nexport function PostalAddressSchema({data}: PostalAddressSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildPostalAddressJsonLd(data)} />\n}\n\nexport default PostalAddressSchema\n","/**\n * <ProductSchema> — Renders Schema.org Product JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { ProductSchema } from 'sanity-plugin-seofields/next/product'\n *\n * const data = await sanityFetch({ query: `*[_type == \"product\"][0]{ seo }` })\n *\n * <ProductSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {productFields} from './schema'\nimport type {SchemaOrgProductData} from './types'\n\nexport interface ProductSchemaProps {\n /** The Schema.org Product data from your Sanity GROQ query. */\n data?: SchemaOrgProductData | null\n}\n\n/**\n * Builds a Schema.org Product JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildProductJsonLd(\n data?: SchemaOrgProductData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Product',\n data as Record<string, unknown> | null | undefined,\n productFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Product data.\n * Renders nothing if required fields are missing.\n */\nexport function ProductSchema({data}: ProductSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildProductJsonLd(data)} />\n}\n\nexport default ProductSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {profilePageFields} from './schema'\nimport type {SchemaOrgProfilePageData} from './types'\n\nexport interface ProfilePageSchemaProps {\n data?: SchemaOrgProfilePageData | null\n}\n\nexport function buildProfilePageJsonLd(\n data?: SchemaOrgProfilePageData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'ProfilePage',\n data as Record<string, unknown> | null | undefined,\n profilePageFields,\n [],\n )\n}\n\nexport function ProfilePageSchema({data}: ProfilePageSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildProfilePageJsonLd(data)} />\n}\n\nexport default ProfilePageSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {recipeFields} from './schema'\nimport type {SchemaOrgRecipeData} from './types'\n\nexport interface RecipeSchemaProps {\n data?: SchemaOrgRecipeData | null\n}\n\nexport function buildRecipeJsonLd(\n data?: SchemaOrgRecipeData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Recipe',\n data as Record<string, unknown> | null | undefined,\n recipeFields,\n ['name'],\n )\n}\n\nexport function RecipeSchema({data}: RecipeSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildRecipeJsonLd(data)} />\n}\n\nexport default RecipeSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {restaurantFields} from './schema'\nimport type {SchemaOrgRestaurantData} from './types'\n\nexport interface RestaurantSchemaProps {\n data?: SchemaOrgRestaurantData | null\n}\n\nexport function buildRestaurantJsonLd(\n data?: SchemaOrgRestaurantData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Restaurant',\n data as Record<string, unknown> | null | undefined,\n restaurantFields,\n ['name'],\n )\n}\n\nexport function RestaurantSchema({data}: RestaurantSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildRestaurantJsonLd(data)} />\n}\n\nexport default RestaurantSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {reviewFields} from './schema'\nimport type {SchemaOrgReviewData} from './types'\n\nexport interface ReviewSchemaProps {\n /** The Schema.org Review data from your Sanity GROQ query. */\n data?: SchemaOrgReviewData | null\n}\n\n/**\n * Builds a Schema.org Review JSON-LD object from Sanity data.\n * Returns `null` if data is missing.\n */\nexport function buildReviewJsonLd(\n data?: SchemaOrgReviewData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Review',\n data as Record<string, unknown> | null | undefined,\n reviewFields,\n [],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Review data.\n * Renders nothing if data is missing.\n */\nexport function ReviewSchema({data}: ReviewSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildReviewJsonLd(data)} />\n}\n\nexport default ReviewSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {serviceFields} from './schema'\nimport type {SchemaOrgServiceData} from './types'\n\nexport interface ServiceSchemaProps {\n data?: SchemaOrgServiceData | null\n}\n\nexport function buildServiceJsonLd(\n data?: SchemaOrgServiceData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Service',\n data as Record<string, unknown> | null | undefined,\n serviceFields,\n ['name'],\n )\n}\n\nexport function ServiceSchema({data}: ServiceSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildServiceJsonLd(data)} />\n}\n\nexport default ServiceSchema\n","/**\n * <SoftwareApplicationSchema> — Renders Schema.org SoftwareApplication JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { SoftwareApplicationSchema } from 'sanity-plugin-seofields/next/softwareApplication'\n *\n * const data = await sanityFetch({ query: `*[_type == \"app\"][0]{ seo }` })\n *\n * <SoftwareApplicationSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {softwareApplicationFields} from './schema'\nimport type {SchemaOrgSoftwareApplicationData} from './types'\n\nexport interface SoftwareApplicationSchemaProps {\n /** The Schema.org SoftwareApplication data from your Sanity GROQ query. */\n data?: SchemaOrgSoftwareApplicationData | null\n}\n\n/**\n * Builds a Schema.org SoftwareApplication JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildSoftwareApplicationJsonLd(\n data?: SchemaOrgSoftwareApplicationData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'SoftwareApplication',\n data as Record<string, unknown> | null | undefined,\n softwareApplicationFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org SoftwareApplication data.\n * Renders nothing if required fields are missing.\n */\nexport function SoftwareApplicationSchema({\n data,\n}: SoftwareApplicationSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildSoftwareApplicationJsonLd(data)} />\n}\n\nexport default SoftwareApplicationSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {videoObjectFields} from './schema'\nimport type {SchemaOrgVideoObjectData} from './types'\n\nexport interface VideoObjectSchemaProps {\n data?: SchemaOrgVideoObjectData | null\n}\n\nexport function buildVideoObjectJsonLd(\n data?: SchemaOrgVideoObjectData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'VideoObject',\n data as Record<string, unknown> | null | undefined,\n videoObjectFields,\n ['name'],\n )\n}\n\nexport function VideoObjectSchema({data}: VideoObjectSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildVideoObjectJsonLd(data)} />\n}\n\nexport default VideoObjectSchema\n","/**\n * <WebApplicationSchema> — Renders Schema.org WebApplication JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { WebApplicationSchema } from 'sanity-plugin-seofields/next/webApplication'\n *\n * const data = await sanityFetch({ query: `*[_type == \"app\"][0]{ seo }` })\n *\n * <WebApplicationSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {webApplicationFields} from './schema'\nimport type {SchemaOrgWebApplicationData} from './types'\n\nexport interface WebApplicationSchemaProps {\n /** The Schema.org WebApplication data from your Sanity GROQ query. */\n data?: SchemaOrgWebApplicationData | null\n}\n\n/**\n * Builds a Schema.org WebApplication JSON-LD object from Sanity data.\n * Returns `null` if required fields (name, url) are missing.\n */\nexport function buildWebApplicationJsonLd(\n data?: SchemaOrgWebApplicationData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'WebApplication',\n data as Record<string, unknown> | null | undefined,\n webApplicationFields,\n ['name', 'url'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org WebApplication data.\n * Renders nothing if required fields are missing.\n */\nexport function WebApplicationSchema({data}: WebApplicationSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildWebApplicationJsonLd(data)} />\n}\n\nexport default WebApplicationSchema\n","/**\n * <WebPageSchema> — Renders Schema.org WebPage JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { WebPageSchema } from 'sanity-plugin-seofields/next/webPage'\n *\n * const data = await sanityFetch({ query: `*[_type == \"page\"][0]{ seo }` })\n *\n * <WebPageSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {webPageFields} from './schema'\nimport type {SchemaOrgWebPageData} from './types'\n\nexport interface WebPageSchemaProps {\n /** The Schema.org WebPage data from your Sanity GROQ query. */\n data?: SchemaOrgWebPageData | null\n}\n\n/**\n * Builds a Schema.org WebPage JSON-LD object from Sanity data.\n * Returns `null` if required fields (name, url) are missing.\n */\nexport function buildWebPageJsonLd(\n data?: SchemaOrgWebPageData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'WebPage',\n data as Record<string, unknown> | null | undefined,\n webPageFields,\n ['name', 'url'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org WebPage data.\n * Renders nothing if required fields are missing.\n */\nexport function WebPageSchema({data}: WebPageSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildWebPageJsonLd(data)} />\n}\n\nexport default WebPageSchema\n"]}
1
+ {"version":3,"sources":["../src/schema/utils.ts","../src/schema/SchemaOrgScript.tsx","../src/schema/organization/component.tsx","../src/schema/website/component.tsx","../src/schema/SchemaOrgScripts.tsx","../src/schema/aggregateRating/component.tsx","../src/schema/article/component.tsx","../src/schema/blogPosting/component.tsx","../src/schema/book/component.tsx","../src/schema/brand/component.tsx","../src/schema/breadcrumbList/component.tsx","../src/schema/contactPoint/component.tsx","../src/schema/country/component.tsx","../src/schema/course/component.tsx","../src/schema/event/component.tsx","../src/schema/faqPage/component.tsx","../src/schema/howTo/component.tsx","../src/schema/imageObject/component.tsx","../src/schema/itemList/component.tsx","../src/schema/jobPosting/component.tsx","../src/schema/legalService/component.tsx","../src/schema/localBusiness/component.tsx","../src/schema/movie/component.tsx","../src/schema/musicAlbum/component.tsx","../src/schema/musicRecording/component.tsx","../src/schema/newsArticle/component.tsx","../src/schema/offer/component.tsx","../src/schema/person/component.tsx","../src/schema/place/component.tsx","../src/schema/postalAddress/component.tsx","../src/schema/product/component.tsx","../src/schema/profilePage/component.tsx","../src/schema/recipe/component.tsx","../src/schema/restaurant/component.tsx","../src/schema/review/component.tsx","../src/schema/service/component.tsx","../src/schema/softwareApplication/component.tsx","../src/schema/videoObject/component.tsx","../src/schema/webApplication/component.tsx","../src/schema/webPage/component.tsx"],"names":["jsx","resolvePolymorphicPersonOrOrg","webPageFields","personFields","breadcrumbListFields","imageObjectFields","articleFields","blogPostingFields","faqPageFields","howToFields","productFields","offerFields","aggregateRatingFields","reviewFields","brandFields","localBusinessFields","postalAddressFields","contactPointFields","softwareApplicationFields","webApplicationFields","eventFields","placeFields","videoObjectFields","courseFields","legalServiceFields","countryFields","bookFields","itemListFields","jobPostingFields","movieFields","musicAlbumFields","musicRecordingFields","newsArticleFields","profilePageFields","recipeFields","restaurantFields","serviceFields","socialMediaPostingFields","buildGenericJsonLd","Fragment"],"mappings":"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","file":"chunk-BCTPOWXA.cjs","sourcesContent":["/**\n * Escapes characters in a JSON string that could enable XSS when embedded\n * inside a `<script>` tag. Prevents `</script>` breakout, HTML comment\n * injection, and Unicode line terminators that can break JS parsing.\n */\nexport function escapeJsonForScript(json: string): string {\n return json\n .replace(/</g, '\\\\u003C')\n .replace(/>/g, '\\\\u003E')\n .replace(/&/g, '\\\\u0026')\n .replace(/\\u2028/g, '\\\\u2028')\n .replace(/\\u2029/g, '\\\\u2029')\n}\n","/**\n * Shared component that renders a `<script type=\"application/ld+json\">` tag.\n * Used by all Schema.org type components.\n */\nimport {JSX} from 'react'\n\nimport {escapeJsonForScript} from './utils'\n\nexport function SchemaOrgScript({\n jsonLd,\n}: {\n jsonLd: Record<string, unknown> | null\n}): JSX.Element | null {\n if (!jsonLd) return null\n\n return (\n <script\n type=\"application/ld+json\"\n // eslint-disable-next-line react/no-danger\n dangerouslySetInnerHTML={{__html: escapeJsonForScript(JSON.stringify(jsonLd))}}\n />\n )\n}\n","/**\n * <OrganizationSchema> — Renders Schema.org Organization JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { OrganizationSchema } from 'sanity-plugin-seofields/next/organization'\n *\n * const data = await sanityFetch({ query: `*[_type == \"settings\"][0]{ organization }` })\n *\n * <OrganizationSchema data={data.organization} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport type {SanityImage} from '../../types'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport type {SchemaOrgOrganizationData} from './types'\n\nexport interface OrganizationSchemaProps {\n /** The Schema.org Organization data from your Sanity GROQ query. */\n data?: SchemaOrgOrganizationData | null\n /**\n * Resolve a Sanity image asset to a URL string (for the logo field).\n * Only needed if you use the Sanity image upload field instead of logoUrl.\n *\n * @example\n * imageUrlResolver={(img) => urlFor(img).width(600).url()}\n */\n imageUrlResolver?: (image: SanityImage) => string | null | undefined\n}\n\n/**\n * Builds a Schema.org Organization JSON-LD object from Sanity data.\n * Returns `null` if required fields (name, url) are missing.\n */\nexport function buildOrganizationJsonLd(\n data?: SchemaOrgOrganizationData | null,\n imageUrlResolver?: (image: SanityImage) => string | null | undefined,\n): Record<string, unknown> | null {\n if (!data?.name || !data?.url) return null\n\n const jsonLd: Record<string, unknown> = {\n '@context': 'https://schema.org',\n '@type': 'Organization',\n name: data.name,\n url: data.url,\n }\n\n // Resolve logo — prefer explicit URL, fall back to Sanity image\n const logoUrl =\n data.logoUrl || (data.logo && imageUrlResolver ? imageUrlResolver(data.logo) : undefined)\n if (logoUrl) jsonLd.logo = logoUrl\n\n if (data.description) jsonLd.description = data.description\n\n if (data.sameAs) jsonLd.sameAs = data.sameAs\n\n if (data.contactPoint?.contactType) {\n const cp: Record<string, unknown> = {\n '@type': 'ContactPoint',\n contactType: data.contactPoint.contactType,\n }\n if (data.contactPoint.email) cp.email = data.contactPoint.email\n if (data.contactPoint.availableLanguage?.length) {\n cp.availableLanguage = data.contactPoint.availableLanguage\n }\n jsonLd.contactPoint = cp\n }\n\n return jsonLd\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Organization data.\n * Renders nothing if required fields are missing.\n */\nexport function OrganizationSchema({\n data,\n imageUrlResolver,\n}: OrganizationSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildOrganizationJsonLd(data, imageUrlResolver)} />\n}\n\nexport default OrganizationSchema\n","/**\n * <WebsiteSchema> — Renders Schema.org WebSite JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { WebsiteSchema } from 'sanity-plugin-seofields/next/website'\n *\n * const data = await sanityFetch({ query: `*[_type == \"settings\"][0]{ website }` })\n *\n * <WebsiteSchema data={data.website} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {resolvePolymorphicPersonOrOrg} from '../_shared'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport type {SchemaOrgWebsiteData} from './types'\n\nexport interface WebsiteSchemaProps {\n /** The Schema.org Website data from your Sanity GROQ query. */\n data?: SchemaOrgWebsiteData | null\n}\n\n/**\n * Builds a Schema.org WebSite JSON-LD object from Sanity data.\n * Returns `null` if required fields (name, url) are missing.\n */\nexport function buildWebsiteJsonLd(\n data?: SchemaOrgWebsiteData | null,\n): Record<string, unknown> | null {\n if (!data?.name || !data?.url) return null\n\n const jsonLd: Record<string, unknown> = {\n '@context': 'https://schema.org',\n '@type': 'WebSite',\n name: data.name,\n url: data.url,\n }\n\n if (data.description) jsonLd.description = data.description\n if (data.inLanguage) jsonLd.inLanguage = data.inLanguage\n\n const publisher = resolvePolymorphicPersonOrOrg(data.publisher)\n if (publisher) jsonLd.publisher = publisher\n\n return jsonLd\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org WebSite data.\n * Renders nothing if required fields are missing.\n */\nexport function WebsiteSchema({data}: WebsiteSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildWebsiteJsonLd(data)} />\n}\n\nexport default WebsiteSchema\n","/**\n * <SchemaOrgScripts> — Renders multiple Schema.org JSON-LD script tags\n * from a combined `schemaOrg` array field.\n *\n * @example\n * ```tsx\n * import { SchemaOrgScripts } from 'sanity-plugin-seofields/next'\n *\n * const data = await sanityFetch({ query: `*[_type == \"settings\"][0]{ structuredData }` })\n *\n * <SchemaOrgScripts data={data.structuredData} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {aggregateRatingFields} from './aggregateRating/schema'\nimport {articleFields} from './article/schema'\nimport {blogPostingFields} from './blogPosting/schema'\nimport {bookFields} from './book/schema'\nimport {brandFields} from './brand/schema'\nimport {breadcrumbListFields} from './breadcrumbList/schema'\nimport {contactPointFields} from './contactPoint/schema'\nimport {countryFields} from './country/schema'\nimport {courseFields} from './course/schema'\nimport {eventFields} from './event/schema'\nimport {faqPageFields} from './faqPage/schema'\nimport {buildGenericJsonLd, SchemaFieldDef} from './generator'\nimport {howToFields} from './howTo/schema'\nimport {imageObjectFields} from './imageObject/schema'\nimport {itemListFields} from './itemList/schema'\nimport {jobPostingFields} from './jobPosting/schema'\nimport {legalServiceFields} from './legalService/schema'\nimport {localBusinessFields} from './localBusiness/schema'\nimport {movieFields} from './movie/schema'\nimport {musicAlbumFields} from './musicAlbum/schema'\nimport {musicRecordingFields} from './musicRecording/schema'\nimport {newsArticleFields} from './newsArticle/schema'\nimport {offerFields} from './offer/schema'\nimport {buildOrganizationJsonLd} from './organization/component'\nimport {personFields} from './person/schema'\nimport {placeFields} from './place/schema'\nimport {postalAddressFields} from './postalAddress/schema'\nimport {productFields} from './product/schema'\nimport {profilePageFields} from './profilePage/schema'\nimport {recipeFields} from './recipe/schema'\nimport {restaurantFields} from './restaurant/schema'\nimport {reviewFields} from './review/schema'\nimport {SchemaOrgScript} from './SchemaOrgScript'\nimport {serviceFields} from './service/schema'\nimport {socialMediaPostingFields} from './socialMediaPosting/schema'\nimport {softwareApplicationFields} from './softwareApplication/schema'\nimport {videoObjectFields} from './videoObject/schema'\nimport {webApplicationFields} from './webApplication/schema'\nimport {webPageFields} from './webPage/schema'\nimport {buildWebsiteJsonLd} from './website/component'\n\n// ─── Type → Builder Registry ──────────────────────────────────────────────────\n\ninterface GenericEntry {\n schemaType: string\n fields: SchemaFieldDef[]\n requiredFields: string[]\n}\n\nconst GENERIC_TYPES: Record<string, GenericEntry> = {\n schemaOrgWebPage: {schemaType: 'WebPage', fields: webPageFields, requiredFields: ['name']},\n schemaOrgPerson: {schemaType: 'Person', fields: personFields, requiredFields: ['name']},\n schemaOrgBreadcrumbList: {\n schemaType: 'BreadcrumbList',\n fields: breadcrumbListFields,\n requiredFields: [],\n },\n schemaOrgImageObject: {\n schemaType: 'ImageObject',\n fields: imageObjectFields,\n requiredFields: ['url'],\n },\n schemaOrgArticle: {schemaType: 'Article', fields: articleFields, requiredFields: ['headline']},\n schemaOrgBlogPosting: {\n schemaType: 'BlogPosting',\n fields: blogPostingFields,\n requiredFields: ['headline'],\n },\n schemaOrgFAQPage: {schemaType: 'FAQPage', fields: faqPageFields, requiredFields: []},\n schemaOrgHowTo: {schemaType: 'HowTo', fields: howToFields, requiredFields: ['name']},\n schemaOrgProduct: {schemaType: 'Product', fields: productFields, requiredFields: ['name']},\n schemaOrgOffer: {schemaType: 'Offer', fields: offerFields, requiredFields: ['price']},\n schemaOrgAggregateRating: {\n schemaType: 'AggregateRating',\n fields: aggregateRatingFields,\n requiredFields: ['ratingValue'],\n },\n schemaOrgReview: {schemaType: 'Review', fields: reviewFields, requiredFields: []},\n schemaOrgBrand: {schemaType: 'Brand', fields: brandFields, requiredFields: ['name']},\n schemaOrgLocalBusiness: {\n schemaType: 'LocalBusiness',\n fields: localBusinessFields,\n requiredFields: ['name'],\n },\n schemaOrgPostalAddress: {\n schemaType: 'PostalAddress',\n fields: postalAddressFields,\n requiredFields: [],\n },\n schemaOrgContactPoint: {\n schemaType: 'ContactPoint',\n fields: contactPointFields,\n requiredFields: [],\n },\n schemaOrgSoftwareApplication: {\n schemaType: 'SoftwareApplication',\n fields: softwareApplicationFields,\n requiredFields: ['name'],\n },\n schemaOrgWebApplication: {\n schemaType: 'WebApplication',\n fields: webApplicationFields,\n requiredFields: ['name'],\n },\n schemaOrgEvent: {schemaType: 'Event', fields: eventFields, requiredFields: ['name']},\n schemaOrgPlace: {schemaType: 'Place', fields: placeFields, requiredFields: ['name']},\n schemaOrgVideoObject: {\n schemaType: 'VideoObject',\n fields: videoObjectFields,\n requiredFields: ['name'],\n },\n schemaOrgCourse: {schemaType: 'Course', fields: courseFields, requiredFields: ['name']},\n schemaOrgLegalService: {\n schemaType: 'LegalService',\n fields: legalServiceFields,\n requiredFields: ['name'],\n },\n schemaOrgCountry: {schemaType: 'Country', fields: countryFields, requiredFields: ['name']},\n schemaOrgBook: {schemaType: 'Book', fields: bookFields, requiredFields: ['name']},\n schemaOrgItemList: {\n schemaType: 'ItemList',\n fields: itemListFields,\n requiredFields: ['name'],\n },\n schemaOrgJobPosting: {\n schemaType: 'JobPosting',\n fields: jobPostingFields,\n requiredFields: ['title'],\n },\n schemaOrgMovie: {schemaType: 'Movie', fields: movieFields, requiredFields: ['name']},\n schemaOrgMusicAlbum: {\n schemaType: 'MusicAlbum',\n fields: musicAlbumFields,\n requiredFields: ['name'],\n },\n schemaOrgMusicRecording: {\n schemaType: 'MusicRecording',\n fields: musicRecordingFields,\n requiredFields: ['name'],\n },\n schemaOrgNewsArticle: {\n schemaType: 'NewsArticle',\n fields: newsArticleFields,\n requiredFields: ['headline'],\n },\n schemaOrgProfilePage: {\n schemaType: 'ProfilePage',\n fields: profilePageFields,\n requiredFields: ['name'],\n },\n schemaOrgRecipe: {schemaType: 'Recipe', fields: recipeFields, requiredFields: ['name']},\n schemaOrgRestaurant: {\n schemaType: 'Restaurant',\n fields: restaurantFields,\n requiredFields: ['name'],\n },\n schemaOrgService: {schemaType: 'Service', fields: serviceFields, requiredFields: ['name']},\n schemaOrgSocialMediaPosting: {\n schemaType: 'SocialMediaPosting',\n fields: socialMediaPostingFields,\n requiredFields: ['headline'],\n },\n}\n\nfunction buildJsonLdForItem(item: Record<string, unknown>): Record<string, unknown> | null {\n const type = item._type as string | undefined\n if (!type) return null\n\n // Website and Organization use custom builders\n if (type === 'schemaOrgWebsite') {\n return buildWebsiteJsonLd(item as Parameters<typeof buildWebsiteJsonLd>[0])\n }\n if (type === 'schemaOrgOrganization') {\n return buildOrganizationJsonLd(item as Parameters<typeof buildOrganizationJsonLd>[0])\n }\n\n // All other types use the generic builder\n const entry = GENERIC_TYPES[type]\n if (!entry) return null\n return buildGenericJsonLd(entry.schemaType, item, entry.fields, entry.requiredFields)\n}\n\n// ─── Component ────────────────────────────────────────────────────────────────\n\nexport interface SchemaOrgScriptsProps {\n /** Array of Schema.org items from the combined `schemaOrg` field. */\n data?: Array<Record<string, unknown>> | null\n}\n\n/**\n * Renders one `<script type=\"application/ld+json\">` tag per Schema.org item.\n * Skips items that fail validation (missing required fields).\n */\nexport function SchemaOrgScripts({data}: SchemaOrgScriptsProps): JSX.Element | null {\n if (!data?.length) return null\n\n const scripts = data\n .map((item) => buildJsonLdForItem(item))\n .filter((jsonLd): jsonLd is Record<string, unknown> => jsonLd !== null)\n\n if (!scripts.length) return null\n\n return (\n <>\n {scripts.map((jsonLd) => (\n <SchemaOrgScript key={JSON.stringify(jsonLd)} jsonLd={jsonLd} />\n ))}\n </>\n )\n}\n\nexport default SchemaOrgScripts\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {aggregateRatingFields} from './schema'\nimport type {SchemaOrgAggregateRatingData} from './types'\n\nexport interface AggregateRatingSchemaProps {\n data?: SchemaOrgAggregateRatingData | null\n}\n\nexport function buildAggregateRatingJsonLd(\n data?: SchemaOrgAggregateRatingData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'AggregateRating',\n data as Record<string, unknown> | null | undefined,\n aggregateRatingFields,\n ['ratingValue'],\n )\n}\n\nexport function AggregateRatingSchema({data}: AggregateRatingSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildAggregateRatingJsonLd(data)} />\n}\n\nexport default AggregateRatingSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {articleFields} from './schema'\nimport type {SchemaOrgArticleData} from './types'\n\nexport interface ArticleSchemaProps {\n /** The Schema.org Article data from your Sanity GROQ query. */\n data?: SchemaOrgArticleData | null\n}\n\n/**\n * Builds a Schema.org Article JSON-LD object from Sanity data.\n * Returns `null` if required fields (headline) are missing.\n */\nexport function buildArticleJsonLd(\n data?: SchemaOrgArticleData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Article',\n data as Record<string, unknown> | null | undefined,\n articleFields,\n ['headline'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Article data.\n * Renders nothing if required fields are missing.\n */\nexport function ArticleSchema({data}: ArticleSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildArticleJsonLd(data)} />\n}\n\nexport default ArticleSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {blogPostingFields} from './schema'\nimport type {SchemaOrgBlogPostingData} from './types'\n\nexport interface BlogPostingSchemaProps {\n /** The Schema.org BlogPosting data from your Sanity GROQ query. */\n data?: SchemaOrgBlogPostingData | null\n}\n\n/**\n * Builds a Schema.org BlogPosting JSON-LD object from Sanity data.\n * Returns `null` if required fields (headline) are missing.\n */\nexport function buildBlogPostingJsonLd(\n data?: SchemaOrgBlogPostingData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'BlogPosting',\n data as Record<string, unknown> | null | undefined,\n blogPostingFields,\n ['headline'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org BlogPosting data.\n * Renders nothing if required fields are missing.\n */\nexport function BlogPostingSchema({data}: BlogPostingSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildBlogPostingJsonLd(data)} />\n}\n\nexport default BlogPostingSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {bookFields} from './schema'\nimport type {SchemaOrgBookData} from './types'\n\nexport interface BookSchemaProps {\n data?: SchemaOrgBookData | null\n}\n\nexport function buildBookJsonLd(data?: SchemaOrgBookData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Book',\n data as Record<string, unknown> | null | undefined,\n bookFields,\n ['name'],\n )\n}\n\nexport function BookSchema({data}: BookSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildBookJsonLd(data)} />\n}\n\nexport default BookSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {brandFields} from './schema'\nimport type {SchemaOrgBrandData} from './types'\n\nexport interface BrandSchemaProps {\n data?: SchemaOrgBrandData | null\n}\n\nexport function buildBrandJsonLd(data?: SchemaOrgBrandData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Brand',\n data as Record<string, unknown> | null | undefined,\n brandFields,\n ['name'],\n )\n}\n\nexport function BrandSchema({data}: BrandSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildBrandJsonLd(data)} />\n}\n\nexport default BrandSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {breadcrumbListFields} from './schema'\nimport type {SchemaOrgBreadcrumbListData} from './types'\n\nexport interface BreadcrumbListSchemaProps {\n /** The Schema.org BreadcrumbList data from your Sanity GROQ query. */\n data?: SchemaOrgBreadcrumbListData | null\n}\n\n/**\n * Builds a Schema.org BreadcrumbList JSON-LD object from Sanity data.\n * Returns `null` if data is missing.\n */\nexport function buildBreadcrumbListJsonLd(\n data?: SchemaOrgBreadcrumbListData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'BreadcrumbList',\n data as Record<string, unknown> | null | undefined,\n breadcrumbListFields,\n [],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org BreadcrumbList data.\n * Renders nothing if data is missing.\n */\nexport function BreadcrumbListSchema({data}: BreadcrumbListSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildBreadcrumbListJsonLd(data)} />\n}\n\nexport default BreadcrumbListSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {contactPointFields} from './schema'\nimport type {SchemaOrgContactPointData} from './types'\n\nexport interface ContactPointSchemaProps {\n data?: SchemaOrgContactPointData | null\n}\n\nexport function buildContactPointJsonLd(\n data?: SchemaOrgContactPointData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'ContactPoint',\n data as Record<string, unknown> | null | undefined,\n contactPointFields,\n ['contactType'],\n )\n}\n\nexport function ContactPointSchema({data}: ContactPointSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildContactPointJsonLd(data)} />\n}\n\nexport default ContactPointSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {countryFields} from './schema'\nimport type {SchemaOrgCountryData} from './types'\n\nexport interface CountrySchemaProps {\n /** The Schema.org Country data from your Sanity GROQ query. */\n data?: SchemaOrgCountryData | null\n}\n\n/**\n * Builds a Schema.org Country JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildCountryJsonLd(\n data?: SchemaOrgCountryData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Country',\n data as Record<string, unknown> | null | undefined,\n countryFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Country data.\n * Renders nothing if required fields are missing.\n */\nexport function CountrySchema({data}: CountrySchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildCountryJsonLd(data)} />\n}\n\nexport default CountrySchema\n","/**\n * <CourseSchema> — Renders Schema.org Course JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { CourseSchema } from 'sanity-plugin-seofields/next/course'\n *\n * const data = await sanityFetch({ query: `*[_type == \"course\"][0]{ seo }` })\n *\n * <CourseSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {courseFields} from './schema'\nimport type {SchemaOrgCourseData} from './types'\n\nexport interface CourseSchemaProps {\n /** The Schema.org Course data from your Sanity GROQ query. */\n data?: SchemaOrgCourseData | null\n}\n\n/**\n * Builds a Schema.org Course JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildCourseJsonLd(\n data?: SchemaOrgCourseData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Course',\n data as Record<string, unknown> | null | undefined,\n courseFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Course data.\n * Renders nothing if required fields are missing.\n */\nexport function CourseSchema({data}: CourseSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildCourseJsonLd(data)} />\n}\n\nexport default CourseSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {eventFields} from './schema'\nimport type {SchemaOrgEventData} from './types'\n\nexport interface EventSchemaProps {\n /** The Schema.org Event data from your Sanity GROQ query. */\n data?: SchemaOrgEventData | null\n}\n\n/**\n * Builds a Schema.org Event JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildEventJsonLd(data?: SchemaOrgEventData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Event',\n data as Record<string, unknown> | null | undefined,\n eventFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Event data.\n * Renders nothing if required fields are missing.\n */\nexport function EventSchema({data}: EventSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildEventJsonLd(data)} />\n}\n\nexport default EventSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {faqPageFields} from './schema'\nimport type {SchemaOrgFAQPageData} from './types'\n\nexport interface FAQPageSchemaProps {\n /** The Schema.org FAQPage data from your Sanity GROQ query. */\n data?: SchemaOrgFAQPageData | null\n}\n\n/**\n * Builds a Schema.org FAQPage JSON-LD object from Sanity data.\n * Returns `null` if data is missing.\n */\nexport function buildFAQPageJsonLd(\n data?: SchemaOrgFAQPageData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'FAQPage',\n data as Record<string, unknown> | null | undefined,\n faqPageFields,\n [],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org FAQPage data.\n * Renders nothing if data is missing.\n */\nexport function FAQPageSchema({data}: FAQPageSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildFAQPageJsonLd(data)} />\n}\n\nexport default FAQPageSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {howToFields} from './schema'\nimport type {SchemaOrgHowToData} from './types'\n\nexport interface HowToSchemaProps {\n /** The Schema.org HowTo data from your Sanity GROQ query. */\n data?: SchemaOrgHowToData | null\n}\n\n/**\n * Builds a Schema.org HowTo JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildHowToJsonLd(data?: SchemaOrgHowToData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'HowTo',\n data as Record<string, unknown> | null | undefined,\n howToFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org HowTo data.\n * Renders nothing if required fields are missing.\n */\nexport function HowToSchema({data}: HowToSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildHowToJsonLd(data)} />\n}\n\nexport default HowToSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {imageObjectFields} from './schema'\nimport type {SchemaOrgImageObjectData} from './types'\n\nexport interface ImageObjectSchemaProps {\n data?: SchemaOrgImageObjectData | null\n}\n\nexport function buildImageObjectJsonLd(\n data?: SchemaOrgImageObjectData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'ImageObject',\n data as Record<string, unknown> | null | undefined,\n imageObjectFields,\n ['url'],\n )\n}\n\nexport function ImageObjectSchema({data}: ImageObjectSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildImageObjectJsonLd(data)} />\n}\n\nexport default ImageObjectSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {itemListFields} from './schema'\nimport type {SchemaOrgItemListData} from './types'\n\nexport interface ItemListSchemaProps {\n data?: SchemaOrgItemListData | null\n}\n\nexport function buildItemListJsonLd(\n data?: SchemaOrgItemListData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'ItemList',\n data as Record<string, unknown> | null | undefined,\n itemListFields,\n [],\n )\n}\n\nexport function ItemListSchema({data}: ItemListSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildItemListJsonLd(data)} />\n}\n\nexport default ItemListSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {jobPostingFields} from './schema'\nimport type {SchemaOrgJobPostingData} from './types'\n\nexport interface JobPostingSchemaProps {\n data?: SchemaOrgJobPostingData | null\n}\n\nexport function buildJobPostingJsonLd(\n data?: SchemaOrgJobPostingData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'JobPosting',\n data as Record<string, unknown> | null | undefined,\n jobPostingFields,\n ['title', 'description', 'datePosted'],\n )\n}\n\nexport function JobPostingSchema({data}: JobPostingSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildJobPostingJsonLd(data)} />\n}\n\nexport default JobPostingSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {legalServiceFields} from './schema'\nimport type {SchemaOrgLegalServiceData} from './types'\n\nexport interface LegalServiceSchemaProps {\n /** The Schema.org LegalService data from your Sanity GROQ query. */\n data?: SchemaOrgLegalServiceData | null\n}\n\n/**\n * Builds a Schema.org LegalService JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildLegalServiceJsonLd(\n data?: SchemaOrgLegalServiceData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'LegalService',\n data as Record<string, unknown> | null | undefined,\n legalServiceFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org LegalService data.\n * Renders nothing if required fields are missing.\n */\nexport function LegalServiceSchema({data}: LegalServiceSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildLegalServiceJsonLd(data)} />\n}\n\nexport default LegalServiceSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {localBusinessFields} from './schema'\nimport type {SchemaOrgLocalBusinessData} from './types'\n\nexport interface LocalBusinessSchemaProps {\n /** The Schema.org LocalBusiness data from your Sanity GROQ query. */\n data?: SchemaOrgLocalBusinessData | null\n}\n\n/**\n * Builds a Schema.org LocalBusiness JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildLocalBusinessJsonLd(\n data?: SchemaOrgLocalBusinessData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'LocalBusiness',\n data as Record<string, unknown> | null | undefined,\n localBusinessFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org LocalBusiness data.\n * Renders nothing if required fields are missing.\n */\nexport function LocalBusinessSchema({data}: LocalBusinessSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildLocalBusinessJsonLd(data)} />\n}\n\nexport default LocalBusinessSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {movieFields} from './schema'\nimport type {SchemaOrgMovieData} from './types'\n\nexport interface MovieSchemaProps {\n data?: SchemaOrgMovieData | null\n}\n\nexport function buildMovieJsonLd(data?: SchemaOrgMovieData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Movie',\n data as Record<string, unknown> | null | undefined,\n movieFields,\n ['name'],\n )\n}\n\nexport function MovieSchema({data}: MovieSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildMovieJsonLd(data)} />\n}\n\nexport default MovieSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {musicAlbumFields} from './schema'\nimport type {SchemaOrgMusicAlbumData} from './types'\n\nexport interface MusicAlbumSchemaProps {\n data?: SchemaOrgMusicAlbumData | null\n}\n\nexport function buildMusicAlbumJsonLd(\n data?: SchemaOrgMusicAlbumData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'MusicAlbum',\n data as Record<string, unknown> | null | undefined,\n musicAlbumFields,\n ['name'],\n )\n}\n\nexport function MusicAlbumSchema({data}: MusicAlbumSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildMusicAlbumJsonLd(data)} />\n}\n\nexport default MusicAlbumSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {musicRecordingFields} from './schema'\nimport type {SchemaOrgMusicRecordingData} from './types'\n\nexport interface MusicRecordingSchemaProps {\n data?: SchemaOrgMusicRecordingData | null\n}\n\nexport function buildMusicRecordingJsonLd(\n data?: SchemaOrgMusicRecordingData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'MusicRecording',\n data as Record<string, unknown> | null | undefined,\n musicRecordingFields,\n ['name'],\n )\n}\n\nexport function MusicRecordingSchema({data}: MusicRecordingSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildMusicRecordingJsonLd(data)} />\n}\n\nexport default MusicRecordingSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {newsArticleFields} from './schema'\nimport type {SchemaOrgNewsArticleData} from './types'\n\nexport interface NewsArticleSchemaProps {\n data?: SchemaOrgNewsArticleData | null\n}\n\nexport function buildNewsArticleJsonLd(\n data?: SchemaOrgNewsArticleData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'NewsArticle',\n data as Record<string, unknown> | null | undefined,\n newsArticleFields,\n ['headline', 'datePublished'],\n )\n}\n\nexport function NewsArticleSchema({data}: NewsArticleSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildNewsArticleJsonLd(data)} />\n}\n\nexport default NewsArticleSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {offerFields} from './schema'\nimport type {SchemaOrgOfferData} from './types'\n\nexport interface OfferSchemaProps {\n data?: SchemaOrgOfferData | null\n}\n\nexport function buildOfferJsonLd(data?: SchemaOrgOfferData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Offer',\n data as Record<string, unknown> | null | undefined,\n offerFields,\n ['price'],\n )\n}\n\nexport function OfferSchema({data}: OfferSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildOfferJsonLd(data)} />\n}\n\nexport default OfferSchema\n","/**\n * <PersonSchema> — Renders Schema.org Person JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { PersonSchema } from 'sanity-plugin-seofields/next/person'\n *\n * const data = await sanityFetch({ query: `*[_type == \"teamMember\"][0]{ person }` })\n *\n * <PersonSchema data={data.person} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {personFields} from './schema'\nimport type {SchemaOrgPersonData} from './types'\n\nexport interface PersonSchemaProps {\n /** The Schema.org Person data from your Sanity GROQ query. */\n data?: SchemaOrgPersonData | null\n}\n\n/**\n * Builds a Schema.org Person JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildPersonJsonLd(\n data?: SchemaOrgPersonData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Person',\n data as Record<string, unknown> | null | undefined,\n personFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Person data.\n * Renders nothing if required fields are missing.\n */\nexport function PersonSchema({data}: PersonSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildPersonJsonLd(data)} />\n}\n\nexport default PersonSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {placeFields} from './schema'\nimport type {SchemaOrgPlaceData} from './types'\n\nexport interface PlaceSchemaProps {\n /** The Schema.org Place data from your Sanity GROQ query. */\n data?: SchemaOrgPlaceData | null\n}\n\n/**\n * Builds a Schema.org Place JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildPlaceJsonLd(data?: SchemaOrgPlaceData | null): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Place',\n data as Record<string, unknown> | null | undefined,\n placeFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Place data.\n * Renders nothing if required fields are missing.\n */\nexport function PlaceSchema({data}: PlaceSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildPlaceJsonLd(data)} />\n}\n\nexport default PlaceSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {postalAddressFields} from './schema'\nimport type {SchemaOrgPostalAddressData} from './types'\n\nexport interface PostalAddressSchemaProps {\n data?: SchemaOrgPostalAddressData | null\n}\n\nexport function buildPostalAddressJsonLd(\n data?: SchemaOrgPostalAddressData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'PostalAddress',\n data as Record<string, unknown> | null | undefined,\n postalAddressFields,\n [],\n )\n}\n\nexport function PostalAddressSchema({data}: PostalAddressSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildPostalAddressJsonLd(data)} />\n}\n\nexport default PostalAddressSchema\n","/**\n * <ProductSchema> — Renders Schema.org Product JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { ProductSchema } from 'sanity-plugin-seofields/next/product'\n *\n * const data = await sanityFetch({ query: `*[_type == \"product\"][0]{ seo }` })\n *\n * <ProductSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {productFields} from './schema'\nimport type {SchemaOrgProductData} from './types'\n\nexport interface ProductSchemaProps {\n /** The Schema.org Product data from your Sanity GROQ query. */\n data?: SchemaOrgProductData | null\n}\n\n/**\n * Builds a Schema.org Product JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildProductJsonLd(\n data?: SchemaOrgProductData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Product',\n data as Record<string, unknown> | null | undefined,\n productFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Product data.\n * Renders nothing if required fields are missing.\n */\nexport function ProductSchema({data}: ProductSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildProductJsonLd(data)} />\n}\n\nexport default ProductSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {profilePageFields} from './schema'\nimport type {SchemaOrgProfilePageData} from './types'\n\nexport interface ProfilePageSchemaProps {\n data?: SchemaOrgProfilePageData | null\n}\n\nexport function buildProfilePageJsonLd(\n data?: SchemaOrgProfilePageData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'ProfilePage',\n data as Record<string, unknown> | null | undefined,\n profilePageFields,\n [],\n )\n}\n\nexport function ProfilePageSchema({data}: ProfilePageSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildProfilePageJsonLd(data)} />\n}\n\nexport default ProfilePageSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {recipeFields} from './schema'\nimport type {SchemaOrgRecipeData} from './types'\n\nexport interface RecipeSchemaProps {\n data?: SchemaOrgRecipeData | null\n}\n\nexport function buildRecipeJsonLd(\n data?: SchemaOrgRecipeData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Recipe',\n data as Record<string, unknown> | null | undefined,\n recipeFields,\n ['name'],\n )\n}\n\nexport function RecipeSchema({data}: RecipeSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildRecipeJsonLd(data)} />\n}\n\nexport default RecipeSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {restaurantFields} from './schema'\nimport type {SchemaOrgRestaurantData} from './types'\n\nexport interface RestaurantSchemaProps {\n data?: SchemaOrgRestaurantData | null\n}\n\nexport function buildRestaurantJsonLd(\n data?: SchemaOrgRestaurantData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Restaurant',\n data as Record<string, unknown> | null | undefined,\n restaurantFields,\n ['name'],\n )\n}\n\nexport function RestaurantSchema({data}: RestaurantSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildRestaurantJsonLd(data)} />\n}\n\nexport default RestaurantSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {reviewFields} from './schema'\nimport type {SchemaOrgReviewData} from './types'\n\nexport interface ReviewSchemaProps {\n /** The Schema.org Review data from your Sanity GROQ query. */\n data?: SchemaOrgReviewData | null\n}\n\n/**\n * Builds a Schema.org Review JSON-LD object from Sanity data.\n * Returns `null` if data is missing.\n */\nexport function buildReviewJsonLd(\n data?: SchemaOrgReviewData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Review',\n data as Record<string, unknown> | null | undefined,\n reviewFields,\n [],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org Review data.\n * Renders nothing if data is missing.\n */\nexport function ReviewSchema({data}: ReviewSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildReviewJsonLd(data)} />\n}\n\nexport default ReviewSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {serviceFields} from './schema'\nimport type {SchemaOrgServiceData} from './types'\n\nexport interface ServiceSchemaProps {\n data?: SchemaOrgServiceData | null\n}\n\nexport function buildServiceJsonLd(\n data?: SchemaOrgServiceData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'Service',\n data as Record<string, unknown> | null | undefined,\n serviceFields,\n ['name'],\n )\n}\n\nexport function ServiceSchema({data}: ServiceSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildServiceJsonLd(data)} />\n}\n\nexport default ServiceSchema\n","/**\n * <SoftwareApplicationSchema> — Renders Schema.org SoftwareApplication JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { SoftwareApplicationSchema } from 'sanity-plugin-seofields/next/softwareApplication'\n *\n * const data = await sanityFetch({ query: `*[_type == \"app\"][0]{ seo }` })\n *\n * <SoftwareApplicationSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {softwareApplicationFields} from './schema'\nimport type {SchemaOrgSoftwareApplicationData} from './types'\n\nexport interface SoftwareApplicationSchemaProps {\n /** The Schema.org SoftwareApplication data from your Sanity GROQ query. */\n data?: SchemaOrgSoftwareApplicationData | null\n}\n\n/**\n * Builds a Schema.org SoftwareApplication JSON-LD object from Sanity data.\n * Returns `null` if required fields (name) are missing.\n */\nexport function buildSoftwareApplicationJsonLd(\n data?: SchemaOrgSoftwareApplicationData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'SoftwareApplication',\n data as Record<string, unknown> | null | undefined,\n softwareApplicationFields,\n ['name'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org SoftwareApplication data.\n * Renders nothing if required fields are missing.\n */\nexport function SoftwareApplicationSchema({\n data,\n}: SoftwareApplicationSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildSoftwareApplicationJsonLd(data)} />\n}\n\nexport default SoftwareApplicationSchema\n","import {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {videoObjectFields} from './schema'\nimport type {SchemaOrgVideoObjectData} from './types'\n\nexport interface VideoObjectSchemaProps {\n data?: SchemaOrgVideoObjectData | null\n}\n\nexport function buildVideoObjectJsonLd(\n data?: SchemaOrgVideoObjectData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'VideoObject',\n data as Record<string, unknown> | null | undefined,\n videoObjectFields,\n ['name'],\n )\n}\n\nexport function VideoObjectSchema({data}: VideoObjectSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildVideoObjectJsonLd(data)} />\n}\n\nexport default VideoObjectSchema\n","/**\n * <WebApplicationSchema> — Renders Schema.org WebApplication JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { WebApplicationSchema } from 'sanity-plugin-seofields/next/webApplication'\n *\n * const data = await sanityFetch({ query: `*[_type == \"app\"][0]{ seo }` })\n *\n * <WebApplicationSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {webApplicationFields} from './schema'\nimport type {SchemaOrgWebApplicationData} from './types'\n\nexport interface WebApplicationSchemaProps {\n /** The Schema.org WebApplication data from your Sanity GROQ query. */\n data?: SchemaOrgWebApplicationData | null\n}\n\n/**\n * Builds a Schema.org WebApplication JSON-LD object from Sanity data.\n * Returns `null` if required fields (name, url) are missing.\n */\nexport function buildWebApplicationJsonLd(\n data?: SchemaOrgWebApplicationData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'WebApplication',\n data as Record<string, unknown> | null | undefined,\n webApplicationFields,\n ['name', 'url'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org WebApplication data.\n * Renders nothing if required fields are missing.\n */\nexport function WebApplicationSchema({data}: WebApplicationSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildWebApplicationJsonLd(data)} />\n}\n\nexport default WebApplicationSchema\n","/**\n * <WebPageSchema> — Renders Schema.org WebPage JSON-LD structured data.\n *\n * @example\n * ```tsx\n * import { WebPageSchema } from 'sanity-plugin-seofields/next/webPage'\n *\n * const data = await sanityFetch({ query: `*[_type == \"page\"][0]{ seo }` })\n *\n * <WebPageSchema data={data.seo} />\n * ```\n */\nimport {JSX} from 'react'\n\nimport {buildGenericJsonLd} from '../generator'\nimport {SchemaOrgScript} from '../SchemaOrgScript'\nimport {webPageFields} from './schema'\nimport type {SchemaOrgWebPageData} from './types'\n\nexport interface WebPageSchemaProps {\n /** The Schema.org WebPage data from your Sanity GROQ query. */\n data?: SchemaOrgWebPageData | null\n}\n\n/**\n * Builds a Schema.org WebPage JSON-LD object from Sanity data.\n * Returns `null` if required fields (name, url) are missing.\n */\nexport function buildWebPageJsonLd(\n data?: SchemaOrgWebPageData | null,\n): Record<string, unknown> | null {\n return buildGenericJsonLd(\n 'WebPage',\n data as Record<string, unknown> | null | undefined,\n webPageFields,\n ['name', 'url'],\n )\n}\n\n/**\n * Renders a `<script type=\"application/ld+json\">` tag with Schema.org WebPage data.\n * Renders nothing if required fields are missing.\n */\nexport function WebPageSchema({data}: WebPageSchemaProps): JSX.Element | null {\n return <SchemaOrgScript jsonLd={buildWebPageJsonLd(data)} />\n}\n\nexport default WebPageSchema\n"]}
@@ -21,26 +21,32 @@ var startsWithStopWord = (title) => {
21
21
  };
22
22
  var truncate = (text, maxLength) => text.length > maxLength ? `${text.slice(0, maxLength)}\u2026` : text;
23
23
  var hasExcessivePunctuation = (title) => /[!@#$%^&*]{2,}/.test(title);
24
- var getMetaTitleValidationMessages = (title, keywords, isParentseoField) => {
24
+ var getMetaTitleValidationMessages = (title, keywords, isParentseoField, suffixLength = 0) => {
25
25
  const feedback = [];
26
26
  const minChar = 50;
27
27
  const maxChar = 60;
28
28
  const charCount = (title == null ? void 0 : title.length) || 0;
29
+ const combinedLength = charCount + suffixLength;
30
+ const suffixMessage = suffixLength > 0 ? ` Suffix value is included (${suffixLength} chars).` : "";
29
31
  if (!(title == null ? void 0 : title.trim())) {
30
32
  feedback.push({ text: "Meta Title is empty. Add content to improve SEO.", color: "red" });
31
33
  return feedback;
32
34
  }
33
- if (charCount < minChar)
35
+ if (combinedLength < minChar)
34
36
  feedback.push({
35
- text: `Title is ${charCount} characters \u2014 below recommended ${minChar}.`,
37
+ text: `Title is ${combinedLength} characters \u2014 below recommended ${minChar}.${suffixMessage}`,
36
38
  color: "orange"
37
39
  });
38
- else if (charCount > maxChar)
40
+ else if (combinedLength > maxChar)
39
41
  feedback.push({
40
- text: `Title is ${charCount} characters \u2014 exceeds recommended ${maxChar}.`,
42
+ text: `Title is ${combinedLength} characters \u2014 exceeds recommended ${maxChar}.${suffixMessage}`,
41
43
  color: "red"
42
44
  });
43
- else feedback.push({ text: `Title length (${charCount}) looks good for SEO.`, color: "green" });
45
+ else
46
+ feedback.push({
47
+ text: `Title length (${combinedLength}) looks good for SEO.${suffixMessage}`,
48
+ color: "green"
49
+ });
44
50
  if (isParentseoField) {
45
51
  if (keywords.length > 0) {
46
52
  const hasKeyword = hasMatchingKeyword(title, keywords);
@@ -468,5 +474,5 @@ var getTwitterImageUrlValidation = (imageUrl, seoParent) => {
468
474
  };
469
475
 
470
476
  export { getMetaDescriptionValidationMessages, getMetaImageValidation, getMetaTitleValidationMessages, getOgDescriptionValidation, getOgImageUrlValidation, getOgImageValidation, getOgTitleValidation, getTwitterDescriptionValidation, getTwitterImageUrlValidation, getTwitterImageValidation, getTwitterTitleValidation, truncate };
471
- //# sourceMappingURL=chunk-25JLWVEU.js.map
472
- //# sourceMappingURL=chunk-25JLWVEU.js.map
477
+ //# sourceMappingURL=chunk-HDZZQCH7.js.map
478
+ //# sourceMappingURL=chunk-HDZZQCH7.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/seoUtils.ts"],"names":[],"mappings":"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","file":"chunk-HDZZQCH7.js","sourcesContent":["import {FeedbackType} from '../types'\n\nexport const stopWords = ['the', 'a', 'an', 'and', 'or', 'but']\n\nexport const hasMatchingKeyword = (title: string, keywordList: string[]): boolean => {\n if (!title || keywordList.length === 0) return false\n const lowerTitle = title.toLowerCase()\n return keywordList.some((keyword) => keyword && lowerTitle.includes(keyword.toLowerCase()))\n}\n\nexport const hasKeywordOveruse = (\n title: string,\n keywordList: string[],\n maxOccurrences = 3,\n): boolean => {\n if (!title || keywordList.length === 0) return false\n const lowerTitle = title.toLowerCase()\n return keywordList.some((keyword) => {\n if (!keyword) return false\n const matches = lowerTitle.match(new RegExp(keyword.toLowerCase(), 'g'))\n return matches ? matches.length > maxOccurrences : false\n })\n}\n\nexport const startsWithStopWord = (title: string): boolean => {\n if (!title) return false\n const firstWord = title.trim().split(' ')[0].toLowerCase()\n return stopWords.includes(firstWord)\n}\n\nexport const primaryKeywordAtStart = (title: string, keywords: string[]): boolean => {\n if (!title || keywords.length === 0) return true\n return title.toLowerCase().startsWith(keywords[0].toLowerCase())\n}\n\nexport const truncate = (text: string, maxLength: number): string =>\n text.length > maxLength ? `${text.slice(0, maxLength)}…` : text\n\nexport const hasExcessivePunctuation = (title: string): boolean => /[!@#$%^&*]{2,}/.test(title)\n\nexport const getMetaTitleValidationMessages = (\n title: string,\n keywords: string[],\n isParentseoField: boolean,\n suffixLength = 0,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n\n const minChar = 50\n const maxChar = 60\n const charCount = title?.length || 0\n const combinedLength = charCount + suffixLength\n const suffixMessage = suffixLength > 0 ? ` Suffix value is included (${suffixLength} chars).` : ''\n\n // Empty check\n if (!title?.trim()) {\n feedback.push({text: 'Meta Title is empty. Add content to improve SEO.', color: 'red'})\n return feedback\n }\n\n // Length check (evaluated against combined title + suffix length)\n if (combinedLength < minChar)\n feedback.push({\n text: `Title is ${combinedLength} characters — below recommended ${minChar}.${suffixMessage}`,\n color: 'orange',\n })\n else if (combinedLength > maxChar)\n feedback.push({\n text: `Title is ${combinedLength} characters — exceeds recommended ${maxChar}.${suffixMessage}`,\n color: 'red',\n })\n else\n feedback.push({\n text: `Title length (${combinedLength}) looks good for SEO.${suffixMessage}`,\n color: 'green',\n })\n\n // Keyword checks\n if (isParentseoField) {\n if (keywords.length > 0) {\n const hasKeyword = hasMatchingKeyword(title, keywords)\n feedback.push({\n text: hasKeyword\n ? 'Keyword found in title — good job!'\n : 'Keywords defined but missing in title.',\n color: hasKeyword ? 'green' : 'red',\n })\n\n if (hasKeywordOveruse(title, keywords)) {\n feedback.push({\n text: 'Keyword appears too many times — avoid keyword stuffing.',\n color: 'orange',\n })\n }\n } else {\n feedback.push({\n text: 'No keywords defined. Consider adding relevant keywords.',\n color: 'orange',\n })\n }\n }\n\n // Stop word check\n if (startsWithStopWord(title))\n feedback.push({text: 'Title starts with a stop word — consider rephrasing.', color: 'orange'})\n\n // Punctuation check\n if (hasExcessivePunctuation(title))\n feedback.push({text: 'Title contains excessive punctuation — simplify it.', color: 'orange'})\n\n return feedback\n}\n\nexport const getMetaDescriptionValidationMessages = (\n description: string,\n keywords: string[],\n isParentseoField: boolean,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n\n const minChar = 120\n const maxChar = 160\n const charCount = description?.length || 0\n\n if (!description?.trim()) {\n feedback.push({text: 'Meta description is empty. Add content to improve SEO.', color: 'red'})\n return feedback\n }\n\n // Length check\n if (charCount < minChar)\n feedback.push({\n text: `Description is ${charCount} chars — below recommended ${minChar}.`,\n color: 'orange',\n })\n else if (charCount > maxChar)\n feedback.push({\n text: `Description is ${charCount} chars — exceeds recommended ${maxChar}.`,\n color: 'red',\n })\n else\n feedback.push({text: `Description length (${charCount}) looks good for SEO.`, color: 'green'})\n\n // Keyword checks\n if (isParentseoField) {\n if (keywords.length > 0) {\n const hasKeyword = hasMatchingKeyword(description, keywords)\n feedback.push({\n text: hasKeyword\n ? 'Keyword found in description — good job!'\n : 'Keywords defined but missing in description.',\n color: hasKeyword ? 'green' : 'red',\n })\n\n if (hasKeywordOveruse(description, keywords)) {\n feedback.push({\n text: 'Keyword appears too many times — avoid keyword stuffing.',\n color: 'orange',\n })\n }\n } else {\n feedback.push({\n text: 'No keywords defined. Consider adding relevant keywords.',\n color: 'orange',\n })\n }\n }\n\n // Stop word / filler check\n if (startsWithStopWord(description))\n feedback.push({\n text: 'Description starts with a stop word — consider rephrasing.',\n color: 'orange',\n })\n\n // Punctuation / special characters\n if (hasExcessivePunctuation(description))\n feedback.push({\n text: 'Description contains excessive punctuation — simplify it.',\n color: 'orange',\n })\n\n return feedback\n}\n\nexport const getOgTitleValidation = (\n title: string,\n keywords: string[] = [],\n isParentseoField: boolean,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n const min = 40\n const max = 60\n const count = title?.length || 0\n\n // Empty check\n if (!title?.trim()) {\n feedback.push({text: 'OG Title is empty. Add content for better social preview.', color: 'red'})\n return feedback\n }\n\n // Length check\n if (count < min)\n feedback.push({\n text: `OG Title is ${count} chars — shorter than recommended ${min}.`,\n color: 'orange',\n })\n else if (count > max)\n feedback.push({text: `OG Title is ${count} chars — exceeds recommended ${max}.`, color: 'red'})\n else feedback.push({text: `OG Title length (${count}) looks good.`, color: 'green'})\n\n if (isParentseoField) {\n // Keyword checks\n if (keywords.length > 0) {\n const hasKeyword = hasMatchingKeyword(title, keywords)\n feedback.push({\n text: hasKeyword\n ? 'Keyword found in OG title — good job!'\n : 'Keywords defined but missing in OG title.',\n color: hasKeyword ? 'green' : 'red',\n })\n\n if (hasKeywordOveruse(title, keywords)) {\n feedback.push({\n text: 'Keyword appears too many times in OG title — avoid keyword stuffing.',\n color: 'orange',\n })\n }\n } else {\n feedback.push({\n text: 'No keywords defined. Consider adding relevant keywords.',\n color: 'orange',\n })\n }\n }\n\n // Additional OG-specific checks\n if (startsWithStopWord(title))\n feedback.push({\n text: 'OG Title starts with a stop word — consider rephrasing.',\n color: 'orange',\n })\n\n if (hasExcessivePunctuation(title))\n feedback.push({text: 'OG Title contains excessive punctuation — simplify it.', color: 'orange'})\n\n return feedback\n}\n\nexport const getOgDescriptionValidation = (\n desc: string,\n keywords: string[] = [],\n isParentseoField: boolean,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n const min = 90\n const max = 120\n const count = desc?.length || 0\n\n // Empty check\n if (!desc?.trim()) {\n feedback.push({\n text: 'OG Description is empty. Add content for better social preview.',\n color: 'red',\n })\n return feedback\n }\n\n // Length check\n if (count < min)\n feedback.push({\n text: `OG Description is ${count} chars — shorter than recommended ${min}.`,\n color: 'orange',\n })\n else if (count > max)\n feedback.push({\n text: `OG Description is ${count} chars — exceeds recommended ${max}.`,\n color: 'red',\n })\n else feedback.push({text: `OG Description length (${count}) looks good.`, color: 'green'})\n\n // Keyword checks\n if (isParentseoField) {\n if (keywords.length > 0) {\n const hasKeyword = hasMatchingKeyword(desc, keywords)\n feedback.push({\n text: hasKeyword\n ? 'Keyword found in OG description — good job!'\n : 'Keywords defined but missing in OG description.',\n color: hasKeyword ? 'green' : 'red',\n })\n\n if (hasKeywordOveruse(desc, keywords)) {\n feedback.push({\n text: 'Keyword appears too many times in OG description — avoid keyword stuffing.',\n color: 'orange',\n })\n }\n } else {\n feedback.push({\n text: 'No keywords defined. Consider adding relevant keywords.',\n color: 'orange',\n })\n }\n }\n\n // Additional OG-specific checks\n if (startsWithStopWord(desc))\n feedback.push({\n text: 'OG Description starts with a stop word — consider rephrasing.',\n color: 'orange',\n })\n\n if (hasExcessivePunctuation(desc))\n feedback.push({\n text: 'OG Description contains excessive punctuation — simplify it.',\n color: 'orange',\n })\n\n return feedback\n}\n\nexport const getTwitterTitleValidation = (\n title: string,\n keywords: string[] = [],\n isParentseoField: boolean,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n const min = 30\n const max = 70\n const count = title?.length || 0\n\n if (!title?.trim()) {\n feedback.push({text: 'X Title is empty. Add content for better SEO.', color: 'red'})\n return feedback\n }\n\n // Length check\n if (count < min)\n feedback.push({\n text: `X Title is ${count} chars — shorter than recommended ${min}.`,\n color: 'orange',\n })\n else if (count > max)\n feedback.push({\n text: `X Title is ${count} chars — exceeds recommended ${max}.`,\n color: 'red',\n })\n else feedback.push({text: `X Title length (${count}) looks good.`, color: 'green'})\n\n if (isParentseoField) {\n // Keyword checks\n if (keywords.length > 0) {\n const hasKeyword = hasMatchingKeyword(title, keywords)\n feedback.push({\n text: hasKeyword\n ? 'Keyword found in X title — good job!'\n : 'Keywords defined but missing in X title.',\n color: hasKeyword ? 'green' : 'red',\n })\n } else {\n feedback.push({\n text: 'No keywords defined. Consider adding relevant keywords.',\n color: 'orange',\n })\n }\n }\n\n // Punctuation check\n if (/[!@#$%^&*]{2,}/.test(title))\n feedback.push({text: 'X Title has excessive punctuation — simplify it.', color: 'orange'})\n\n return feedback\n}\n\nexport const getTwitterDescriptionValidation = (\n desc: string,\n keywords: string[] = [],\n isParentseoField: boolean,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n const min = 50\n const max = 200\n const count = desc?.length || 0\n\n if (!desc?.trim()) {\n feedback.push({text: 'X Description is empty. Add content for better SEO.', color: 'red'})\n return feedback\n }\n\n // Length check\n if (count < min)\n feedback.push({\n text: `X Description is ${count} chars — shorter than recommended ${min}.`,\n color: 'orange',\n })\n else if (count > max)\n feedback.push({\n text: `X Description is ${count} chars — exceeds recommended ${max}.`,\n color: 'red',\n })\n else feedback.push({text: `X Description length (${count}) looks good.`, color: 'green'})\n\n if (isParentseoField) {\n // Keyword checks\n if (keywords.length > 0) {\n const hasKeyword = hasMatchingKeyword(desc, keywords)\n feedback.push({\n text: hasKeyword\n ? 'Keyword found in X description — good job!'\n : 'Keywords defined but missing in X description.',\n color: hasKeyword ? 'green' : 'red',\n })\n } else {\n feedback.push({\n text: 'No keywords defined. Consider adding relevant keywords.',\n color: 'orange',\n })\n }\n }\n\n // Punctuation check\n if (/[!@#$%^&*]{2,}/.test(desc))\n feedback.push({\n text: 'X Description has excessive punctuation — simplify it.',\n color: 'orange',\n })\n\n return feedback\n}\n\n// ── Image Validation Helpers ──\n\n/** Check if an image is set in an OG/Twitter sub-object (handles upload vs URL) */\nexport const isSubImageSet = (subObj: Record<string, unknown> | null | undefined): boolean => {\n if (!subObj) return false\n if (subObj.imageType === 'url') return !!(subObj.imageUrl as string)?.trim()\n const img = subObj.image as Record<string, unknown> | undefined\n return !!img?.asset\n}\n\n/** Check if metaImage asset is set */\nconst isMetaImageSet = (seoParent: Record<string, unknown> | null | undefined): boolean => {\n if (!seoParent) return false\n const metaImage = seoParent.metaImage as Record<string, unknown> | undefined\n return !!metaImage?.asset\n}\n\nexport const getMetaImageValidation = (\n hasImage: boolean,\n seoParent: Record<string, unknown> | null | undefined,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n\n if (!hasImage) {\n feedback.push({\n text: 'No meta image provided. Adding an image improves click-through rates.',\n color: 'red',\n })\n return feedback\n }\n\n feedback.push({text: 'Meta image is set — great for SEO and social sharing.', color: 'green'})\n\n const ogSet = isSubImageSet(seoParent?.openGraph as Record<string, unknown> | undefined)\n const twSet = isSubImageSet(seoParent?.twitter as Record<string, unknown> | undefined)\n\n if (!ogSet && !twSet) {\n feedback.push({\n text: 'OG and Twitter images are missing — add them for full social coverage.',\n color: 'orange',\n })\n } else if (!ogSet) {\n feedback.push({\n text: 'OG image is missing — add it for better Facebook/LinkedIn previews.',\n color: 'orange',\n })\n } else if (twSet) {\n feedback.push({text: 'All images set (Meta, OG, Twitter) — full coverage!', color: 'green'})\n } else {\n feedback.push({\n text: 'Twitter image is missing — add it for better X (Twitter) cards.',\n color: 'orange',\n })\n }\n\n return feedback\n}\n\nexport const getOgImageValidation = (\n hasImage: boolean,\n altText: string | undefined,\n seoParent: Record<string, unknown> | null | undefined,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n\n if (!hasImage) {\n feedback.push({\n text: 'No OG image provided. Social shares will lack a visual preview.',\n color: 'red',\n })\n return feedback\n }\n\n feedback.push({text: 'OG image is set — good for social sharing.', color: 'green'})\n\n if (altText?.trim()) {\n feedback.push({text: 'Alt text is set — good for accessibility.', color: 'green'})\n } else {\n feedback.push({text: 'Consider adding alt text for better accessibility.', color: 'orange'})\n }\n\n const metaSet = isMetaImageSet(seoParent)\n const twSet = isSubImageSet(seoParent?.twitter as Record<string, unknown> | undefined)\n\n if (metaSet && twSet) {\n feedback.push({text: 'All images set (Meta, OG, Twitter) — full coverage!', color: 'green'})\n } else {\n if (!metaSet)\n feedback.push({\n text: 'Meta image is missing — add it for search engine results.',\n color: 'orange',\n })\n if (!twSet)\n feedback.push({\n text: 'Twitter image is missing — add it for X (Twitter) cards.',\n color: 'orange',\n })\n }\n\n return feedback\n}\n\nexport const getOgImageUrlValidation = (\n imageUrl: string | undefined,\n seoParent: Record<string, unknown> | null | undefined,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n\n if (!imageUrl?.trim()) {\n feedback.push({\n text: 'No OG image URL provided. Social shares will lack a visual preview.',\n color: 'red',\n })\n return feedback\n }\n\n feedback.push({text: 'OG image URL is set — good for social sharing.', color: 'green'})\n\n const metaSet = isMetaImageSet(seoParent)\n const twSet = isSubImageSet(seoParent?.twitter as Record<string, unknown> | undefined)\n\n if (metaSet && twSet) {\n feedback.push({text: 'All images set (Meta, OG, Twitter) — full coverage!', color: 'green'})\n } else {\n if (!metaSet)\n feedback.push({\n text: 'Meta image is missing — add it for search engine results.',\n color: 'orange',\n })\n if (!twSet)\n feedback.push({\n text: 'Twitter image is missing — add it for X (Twitter) cards.',\n color: 'orange',\n })\n }\n\n return feedback\n}\n\nexport const getTwitterImageValidation = (\n hasImage: boolean,\n altText: string | undefined,\n seoParent: Record<string, unknown> | null | undefined,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n\n if (!hasImage) {\n feedback.push({\n text: 'No Twitter image provided. Posts on X will lack a visual.',\n color: 'red',\n })\n return feedback\n }\n\n feedback.push({text: 'Twitter image is set — good for X sharing.', color: 'green'})\n\n if (altText?.trim()) {\n feedback.push({text: 'Alt text is set — good for accessibility.', color: 'green'})\n } else {\n feedback.push({text: 'Consider adding alt text for better accessibility.', color: 'orange'})\n }\n\n const metaSet = isMetaImageSet(seoParent)\n const ogSet = isSubImageSet(seoParent?.openGraph as Record<string, unknown> | undefined)\n\n if (metaSet && ogSet) {\n feedback.push({text: 'All images set (Meta, OG, Twitter) — full coverage!', color: 'green'})\n } else {\n if (!metaSet)\n feedback.push({\n text: 'Meta image is missing — add it for search engine results.',\n color: 'orange',\n })\n if (!ogSet)\n feedback.push({\n text: 'OG image is missing — add it for Facebook/LinkedIn sharing.',\n color: 'orange',\n })\n }\n\n return feedback\n}\n\nexport const getTwitterImageUrlValidation = (\n imageUrl: string | undefined,\n seoParent: Record<string, unknown> | null | undefined,\n): FeedbackType[] => {\n const feedback: FeedbackType[] = []\n\n if (!imageUrl?.trim()) {\n feedback.push({\n text: 'No Twitter image URL provided. Posts on X will lack a visual.',\n color: 'red',\n })\n return feedback\n }\n\n feedback.push({text: 'Twitter image URL is set — good for X sharing.', color: 'green'})\n\n const metaSet = isMetaImageSet(seoParent)\n const ogSet = isSubImageSet(seoParent?.openGraph as Record<string, unknown> | undefined)\n\n if (metaSet && ogSet) {\n feedback.push({text: 'All images set (Meta, OG, Twitter) — full coverage!', color: 'green'})\n } else {\n if (!metaSet)\n feedback.push({\n text: 'Meta image is missing — add it for search engine results.',\n color: 'orange',\n })\n if (!ogSet)\n feedback.push({\n text: 'OG image is missing — add it for Facebook/LinkedIn sharing.',\n color: 'orange',\n })\n }\n\n return feedback\n}\n"]}
@@ -2351,6 +2351,7 @@ var legalServiceFields = [
2351
2351
  description: "The firm website URL."
2352
2352
  },
2353
2353
  polymorphicImage({
2354
+ name: "logo",
2354
2355
  title: "Logo",
2355
2356
  description: "An image that represents the firm, such as a logo."
2356
2357
  }),
@@ -2518,6 +2519,7 @@ var localBusinessFields = [
2518
2519
  description: "The website URL of the business."
2519
2520
  },
2520
2521
  polymorphicImage({
2522
+ name: "logo",
2521
2523
  title: "Logo",
2522
2524
  description: "An image that represents the business, such as a logo."
2523
2525
  }),
@@ -3914,5 +3916,5 @@ function schemaOrgWebPage(config = {}) {
3914
3916
  }
3915
3917
 
3916
3918
  export { IETF_LANGUAGE_OPTIONS, SchemaOrgIcons, aggregateRatingFields, articleFields, blogPostingFields, bookFields, brandFields, breadcrumbListFields, buildGenericJsonLd, contactPointFields, countryFields, courseFields, datePublishedField, descriptionField, eventFields, faqPageFields, generateSchemaType, headlineField, howToFields, imageObjectFields, inLanguageField, issnField, itemListFields, jobPostingFields, legalServiceFields, localBusinessFields, movieFields, musicAlbumFields, musicRecordingFields, nameField, newsArticleFields, offerFields, personFields, placeFields, polymorphicAdditionalType, polymorphicArchivedAt, polymorphicAuthor, polymorphicCitation, polymorphicContentRating, polymorphicContributor, polymorphicCopyrightHolder, polymorphicCreator, polymorphicFunder, polymorphicGenre, polymorphicIdentifier, polymorphicImage, polymorphicIsBasedOn, polymorphicIsPartOf, polymorphicKeywords, polymorphicLicense, polymorphicLocationCreated, polymorphicMaintainer, polymorphicMaterial, polymorphicOwner, polymorphicPublisher, postalAddressFields, potentialActionSearch, productFields, profilePageFields, recipeFields, resolvePolymorphicPersonOrOrg, restaurantFields, reviewFields, schemaOrgAggregateRating, schemaOrgArticle, schemaOrgBlogPosting, schemaOrgBook, schemaOrgBrand, schemaOrgBreadcrumbList, schemaOrgContactPoint, schemaOrgCountry, schemaOrgCourse, schemaOrgEvent, schemaOrgFAQPage, schemaOrgHowTo, schemaOrgImageObject, schemaOrgItemList, schemaOrgJobPosting, schemaOrgLegalService, schemaOrgLocalBusiness, schemaOrgMovie, schemaOrgMusicAlbum, schemaOrgMusicRecording, schemaOrgNewsArticle, schemaOrgOffer, schemaOrgPerson, schemaOrgPlace, schemaOrgPostalAddress, schemaOrgProduct, schemaOrgProfilePage, schemaOrgRecipe, schemaOrgRestaurant, schemaOrgReview, schemaOrgService, schemaOrgSocialMediaPosting, schemaOrgSoftwareApplication, schemaOrgVideoObject, schemaOrgWebApplication, schemaOrgWebPage, serviceFields, socialMediaPostingFields, softwareApplicationFields, urlField, videoObjectFields, webApplicationFields, webPageFields, withCreativeWorkCommons, withThingCommons };
3917
- //# sourceMappingURL=chunk-IQG5JWVT.js.map
3918
- //# sourceMappingURL=chunk-IQG5JWVT.js.map
3919
+ //# sourceMappingURL=chunk-KTL6NYNG.js.map
3920
+ //# sourceMappingURL=chunk-KTL6NYNG.js.map