From 19ecb7cbac4bd2c940a7d5b3dff8d66f71ab9163 Mon Sep 17 00:00:00 2001 From: Ane Date: Wed, 16 Oct 2024 07:32:30 +0200 Subject: [PATCH] feat(customerCase): fields for top section in customer cases Co-authored-by: Mathias Oterhals Myklebust --- studioShared/lib/queries/customerCases.ts | 18 +++++++- .../schemas/documents/customerCase.ts | 24 +++++++--- .../schemas/fields/customerCaseProjectInfo.ts | 44 +++++++++++++++++++ studioShared/studioConfig.tsx | 2 +- 4 files changed, 79 insertions(+), 9 deletions(-) create mode 100644 studioShared/schemas/fields/customerCaseProjectInfo.ts diff --git a/studioShared/lib/queries/customerCases.ts b/studioShared/lib/queries/customerCases.ts index dbb29462a..c1373c03f 100644 --- a/studioShared/lib/queries/customerCases.ts +++ b/studioShared/lib/queries/customerCases.ts @@ -11,7 +11,23 @@ export const CUSTOMER_CASES_QUERY = groq` } `; -export const CUSTOMER_CASE_QUERY = groq`*[_type == "customerCase" && slug.current == $slug && language == $language][0]`; +export const CUSTOMER_CASE_QUERY = groq` + *[_type == "customerCase" && ${translatedFieldFragment("slug")} == $slug][0] { + ${LANGUAGE_FIELD_FRAGMENT}, + "slug": ${translatedFieldFragment("slug")}, + "basicTitle": ${translatedFieldFragment("basicTitle")}, + "description": ${translatedFieldFragment("description")}, + "richText": ${translatedFieldFragment("richText")}, + "projectInfo": projectInfo { + customer, + "name": ${translatedFieldFragment("name")}, + "duration": ${translatedFieldFragment("duration")}, + "sector": ${translatedFieldFragment("sector")}, + "delivery": ${translatedFieldFragment("delivery")}, + consultants + } + } +`; export const CUSTOMER_CASES_SITEMAP_QUERY = groq` *[_type == "customerCase"] { diff --git a/studioShared/schemas/documents/customerCase.ts b/studioShared/schemas/documents/customerCase.ts index 71f28b979..3f4e8df7e 100644 --- a/studioShared/schemas/documents/customerCase.ts +++ b/studioShared/schemas/documents/customerCase.ts @@ -4,6 +4,7 @@ import { isInternationalizedString } from "studio/lib/interfaces/global"; import { richTextID, titleID } from "studio/schemas/fields/text"; import { titleSlug } from "studio/schemas/schemaTypes/slug"; import { firstTranslation } from "studio/utils/i18n"; +import { customerCaseProjectInfo } from "studioShared/schemas/fields/customerCaseProjectInfo"; export const customerCaseID = "customerCase"; @@ -12,15 +13,24 @@ const customerCase = defineType({ type: "document", title: "Customer Case", fields: [ - { - name: titleID.basic, - type: "internationalizedArrayString", - title: "Customer Case Title", - }, - { + defineField({ ...titleSlug, type: "internationalizedArrayString", - }, + }), + defineField({ + name: titleID.basic, + type: "internationalizedArrayString", + title: "Title", + }), + defineField({ + name: "description", + type: "internationalizedArrayText", + title: "Description", + description: + "Short paragraph displayed at the top of the customer case page", + }), + customerCaseProjectInfo, + //TODO: Block section defineField({ name: richTextID, title: "Body", diff --git a/studioShared/schemas/fields/customerCaseProjectInfo.ts b/studioShared/schemas/fields/customerCaseProjectInfo.ts new file mode 100644 index 000000000..358fb5e42 --- /dev/null +++ b/studioShared/schemas/fields/customerCaseProjectInfo.ts @@ -0,0 +1,44 @@ +import { defineField } from "sanity"; + +export const customerCaseProjectInfo = defineField({ + name: "projectInfo", + title: "Project Info", + description: "General information about the project", + type: "object", + fields: [ + defineField({ + name: "customer", + description: "The customer for the project", + type: "string", + }), + defineField({ + name: "name", + description: "The name of the project", + type: "internationalizedArrayString", + }), + defineField({ + name: "duration", + description: "The duration of the project (e.g. 'Q2 2023 – Q1 2024')", + type: "internationalizedArrayString", + }), + defineField({ + // TODO: pick from global sector tags + name: "sector", + description: "The sector of the project", + type: "internationalizedArrayString", + }), + defineField({ + // TODO: pick from global delivery tags + name: "delivery", + description: "The delivery of the project", + type: "internationalizedArrayString", + }), + defineField({ + // TODO: We should be able to select the consultants from a list + name: "consultants", + description: "The consultants for the project", + type: "array", + of: [{ type: "string" }], + }), + ], +}); diff --git a/studioShared/studioConfig.tsx b/studioShared/studioConfig.tsx index 6c904e63b..23ced8911 100644 --- a/studioShared/studioConfig.tsx +++ b/studioShared/studioConfig.tsx @@ -30,7 +30,7 @@ const config: WorkspaceOptions = { media(), internationalizedArray({ languages: supportedLanguages, - fieldTypes: ["string", "richText"], + fieldTypes: ["string", "richText", "text"], }), ], };