Skip to content

Commit

Permalink
Add title to customer case entry block
Browse files Browse the repository at this point in the history
  • Loading branch information
idamand committed Dec 12, 2024
1 parent 5eb0cd6 commit 466cea1
Show file tree
Hide file tree
Showing 4 changed files with 36 additions and 4 deletions.
Original file line number Diff line number Diff line change
@@ -1,21 +1,25 @@
import { headers } from "next/headers";

import Text from "src/components/text/Text";
import { Locale } from "src/i18n/routing";
import { getDraftModeInfo } from "src/utils/draftmode";
import { domainFromHostname } from "src/utils/url";
import { CustomerCasesEntrySection } from "studio/lib/interfaces/pages";
import { CUSTOMER_CASES_PAGE_SITEMAP_QUERY } from "studio/lib/queries/specialPages";
import { loadStudioQuery } from "studio/lib/store";
import { CustomerCaseEntry } from "studioShared/lib/interfaces/customerCases";
import { CUSTOMER_CASE_ENTRY_QUERY } from "studioShared/lib/queries/customerCases";
import { loadSharedQuery } from "studioShared/lib/store";

import styles from "./customerCasesEntry.module.css";
import CustomerCasesList from "./CustomerCasesList";

interface CustomerCasesProps {
language: Locale;
section: CustomerCasesEntrySection;
}

async function CustomerCasesEntry({ language }: CustomerCasesProps) {
async function CustomerCasesEntry({ language, section }: CustomerCasesProps) {
const { perspective } = getDraftModeInfo();
const domain = domainFromHostname(headers().get("host"));

Expand All @@ -42,6 +46,11 @@ async function CustomerCasesEntry({ language }: CustomerCasesProps) {
return (
customerCaseResult && (
<div>
<div className={styles.titleWrapper}>
<Text type="h3" className={styles.title}>
{section.basicTitle}
</Text>
</div>
<CustomerCasesList
customerCases={customerCaseResult.data}
language={language}
Expand Down
4 changes: 2 additions & 2 deletions src/utils/renderSection.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -195,9 +195,9 @@ const renderCustomerCasesEntrySection = (
language: Locale,
) => {
return isDraftMode ? (
<CustomerCasesEntry language={language} />
<CustomerCasesEntry language={language} section={section} />
) : (
<CustomerCasesEntry language={language} />
<CustomerCasesEntry language={language} section={section} />
);
};

Expand Down
3 changes: 3 additions & 0 deletions studio/lib/queries/pages.ts
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,9 @@ const SECTIONS_FRAGMENT = groq`
_type == "employeeHighlight" => {
"basicTitle": ${translatedFieldFragment("basicTitle")},
"description": ${translatedFieldFragment("description")},
},
_type == "customerCasesEntry" => {
"basicTitle":${translatedFieldFragment("basicTitle")},
}
}
`;
Expand Down
22 changes: 21 additions & 1 deletion studio/schemas/objects/sections/customerCasesEntry.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,36 @@
import { CaseIcon } from "@sanity/icons";
import { defineField } from "sanity";

import { isInternationalizedString } from "studio/lib/interfaces/global";
import { firstTranslation } from "studio/utils/i18n";

export const customerCasesEntry = defineField({
name: "customerCasesEntry",
title: "Customer Cases Entry",
type: "object",
icon: CaseIcon,
fields: [
{
name: "basicTitle",
title: "Basic Title",
type: "string",
type: "internationalizedArrayString",
description:
"This will be the title of the customer cases entry section. Make it engaging to capture the attention of your audience.",
},
],
preview: {
select: {
title: "basicTitle",
},
prepare({ title }) {
if (!isInternationalizedString(title)) {
throw new TypeError(
`Expected 'title' to be InternationalizedString, was ${typeof title}`,
);
}
return {
title: firstTranslation(title) ?? undefined,
};
},
},
});

0 comments on commit 466cea1

Please sign in to comment.