From e9c78fde3dab744afdffdc1f8c62481b7b1bff57 Mon Sep 17 00:00:00 2001 From: Mathias Oterhals Myklebust Date: Thu, 24 Oct 2024 12:11:26 +0200 Subject: [PATCH] feat(pageBuilder): translated slug field for dynamic pages --- src/utils/pageData.ts | 10 +++++++++- studio/lib/queries/pages.ts | 11 ++--------- studio/schemas/documents/pageBuilder.ts | 16 +++++++++++----- 3 files changed, 22 insertions(+), 15 deletions(-) diff --git a/src/utils/pageData.ts b/src/utils/pageData.ts index 66894ba53..9cfd39760 100644 --- a/src/utils/pageData.ts +++ b/src/utils/pageData.ts @@ -63,10 +63,18 @@ async function fetchDynamicPage({ if (!isNonNullQueryResponse(queryResponse)) { return null; } + const pathTranslations = + await loadStudioQuery( + SLUG_FIELD_TRANSLATIONS_FROM_LANGUAGE_QUERY, + { + slug: path[0], + language, + }, + ); return { queryResponse, docType: pageBuilderID, - pathTranslations: [], + pathTranslations: pathTranslations.data ?? [], }; } diff --git a/studio/lib/queries/pages.ts b/studio/lib/queries/pages.ts index d5bde970b..f1c37f6ef 100644 --- a/studio/lib/queries/pages.ts +++ b/studio/lib/queries/pages.ts @@ -48,6 +48,7 @@ export const SEO_FRAGMENT = groq` export const PAGE_FRAGMENT = groq` ..., + "slug": ${translatedFieldFragment("slug")}, ${LANGUAGE_FIELD_FRAGMENT}, ${SECTIONS_FRAGMENT}, ${SEO_FRAGMENT} @@ -66,16 +67,8 @@ export const PAGES_SITEMAP_QUERY = groq` } `; -export const PAGE_SEO_QUERY = groq` - *[_type == "pageBuilder" && _id == $id][0]{ - "title": seo.seoTitle, - "description": seo.seoDescription, - "imageUrl": seo.seoImage.asset->url - } -`; - export const PAGE_BY_SLUG_QUERY = groq` - *[_type == "pageBuilder" && slug.current == $slug][0]{ + *[_type == "pageBuilder" && ${translatedFieldFragment("slug")} == $slug][0]{ ${PAGE_FRAGMENT} } `; diff --git a/studio/schemas/documents/pageBuilder.ts b/studio/schemas/documents/pageBuilder.ts index dab7df0c3..ef0024e4a 100644 --- a/studio/schemas/documents/pageBuilder.ts +++ b/studio/schemas/documents/pageBuilder.ts @@ -1,6 +1,7 @@ import { defineField, defineType } from "sanity"; import { StringInputWithCharacterCount } from "studio/components/stringInputWithCharacterCount/StringInputWithCharacterCount"; +import { isInternationalizedString } from "studio/lib/interfaces/global"; import article from "studio/schemas/objects/sections/article"; import callout from "studio/schemas/objects/sections/callout"; import callToAction from "studio/schemas/objects/sections/callToAction"; @@ -11,6 +12,7 @@ import logoSalad from "studio/schemas/objects/sections/logoSalad"; import testimonals from "studio/schemas/objects/sections/testimonials"; import seo from "studio/schemas/objects/seo"; import { pageSlug } from "studio/schemas/schemaTypes/slug"; +import { firstTranslation } from "studio/utils/i18n"; export const pageBuilderID = "pageBuilder"; @@ -53,13 +55,17 @@ const pageBuilder = defineType({ preview: { select: { title: "page", - urlSlug: "slug.current", + slug: pageSlug.name, }, - prepare(selection) { - const { title, urlSlug } = selection; + prepare({ title, slug }) { + if (!isInternationalizedString(slug)) { + throw new TypeError( + `Expected 'slug' to be InternationalizedString, was ${typeof slug}`, + ); + } return { - title: title, - subtitle: urlSlug, + title: title ?? undefined, + subtitle: firstTranslation(slug) ?? undefined, }; }, },