From 5eb0cd62b1c22fe348abfc7df860b7c578df52a2 Mon Sep 17 00:00:00 2001 From: Ida Marie Andreassen <43541032+idamand@users.noreply.github.com> Date: Wed, 11 Dec 2024 15:11:46 +0100 Subject: [PATCH] Refactor contact module according to design (#954) * Refactor contact module according to design * Fix aria-role --- .../contactInformation/ContactInformation.tsx | 45 ++++++----- .../contactInformation/ContactSelector.tsx | 75 ++++++++++++++++++ .../contactInformation.module.css | 76 ++++++++++++++----- .../contactSelector/ContactSelector.tsx | 72 ------------------ .../contactSelector.module.css | 9 --- 5 files changed, 161 insertions(+), 116 deletions(-) create mode 100644 src/components/customerCases/customerCase/contactInformation/ContactSelector.tsx delete mode 100644 src/components/customerCases/customerCase/contactInformation/contactSelector/ContactSelector.tsx delete mode 100644 src/components/customerCases/customerCase/contactInformation/contactSelector/contactSelector.module.css diff --git a/src/components/customerCases/customerCase/contactInformation/ContactInformation.tsx b/src/components/customerCases/customerCase/contactInformation/ContactInformation.tsx index 667643fb8..471a2828d 100644 --- a/src/components/customerCases/customerCase/contactInformation/ContactInformation.tsx +++ b/src/components/customerCases/customerCase/contactInformation/ContactInformation.tsx @@ -1,5 +1,7 @@ import { getTranslations } from "next-intl/server"; +import { Suspense } from "react"; +import { EmployeeCardSkeleton } from "src/components/employeeCard/EmployeeCard"; import Text from "src/components/text/Text"; import { fetchEmployeesByEmails } from "src/utils/employees"; import { CompanyLocation } from "studio/lib/interfaces/companyDetails"; @@ -8,9 +10,7 @@ import { EMPLOYEE_PAGE_SLUG_QUERY } from "studio/lib/queries/siteSettings"; import { loadStudioQuery } from "studio/lib/store"; import styles from "./contactInformation.module.css"; -import ContactSelector, { - ContactByLocationMap, -} from "./contactSelector/ContactSelector"; +import ContactSelector, { ContactByLocationMap } from "./ContactSelector"; interface ContactInformationProps { language: string; @@ -54,21 +54,30 @@ export default async function ContactInformation({ ); const t = await getTranslations("contact_information"); return ( -
-
-
- {t("help")} - {t("contact_sale")} + <> +
+
+
+ + {t("help")} + + {t("contact_sale")} +
+
+ }> + + +
-
- -
-
-
+ + ); } diff --git a/src/components/customerCases/customerCase/contactInformation/ContactSelector.tsx b/src/components/customerCases/customerCase/contactInformation/ContactSelector.tsx new file mode 100644 index 000000000..9ff75782a --- /dev/null +++ b/src/components/customerCases/customerCase/contactInformation/ContactSelector.tsx @@ -0,0 +1,75 @@ +"use client"; + +import { useState } from "react"; + +import EmployeeCard from "src/components/employeeCard/EmployeeCard"; +import { Tag } from "src/components/tag"; +import { ChewbaccaEmployee } from "src/types/employees"; +import { CompanyLocation } from "studio/lib/interfaces/companyDetails"; + +import styles from "./contactInformation.module.css"; + +export type ContactByLocationMap = { + [locationId: string]: ChewbaccaEmployee; +}; + +export interface ContactSelectorProps { + language: string; + locations: CompanyLocation[]; + contactByLocation: ContactByLocationMap; + employeePageSlug?: string; + background: "dark" | "light"; +} + +export default function ContactSelector({ + language, + locations, + contactByLocation, + employeePageSlug, + background = "light", +}: ContactSelectorProps) { + const locationIds = Object.keys(contactByLocation); + + const [selectedLocationId, setSelectedLocationId] = useState( + locationIds[0], + ); + + if (locationIds.length === 0) { + return; + } + + const selectedOrDefaultLocationId = selectedLocationId ?? locationIds[0]; + console.log(selectedLocationId); + + return ( + <> +
+
+ {locations.map((location) => ( + setSelectedLocationId(location._id)} + text={location.companyLocationName} + /> + ))} +
+
+
+ +
+
+
+ + ); +} diff --git a/src/components/customerCases/customerCase/contactInformation/contactInformation.module.css b/src/components/customerCases/customerCase/contactInformation/contactInformation.module.css index e86f6bf9c..c79175a9d 100644 --- a/src/components/customerCases/customerCase/contactInformation/contactInformation.module.css +++ b/src/components/customerCases/customerCase/contactInformation/contactInformation.module.css @@ -1,32 +1,74 @@ -.wrapper { - display: flex; +.contactBox { + max-width: var(--max-content-width-large); +} + +.contactBox__inner { + --_contactBox__background: var(--background-bg-dark); + --_contactBox__color: var(--text-primary-light); + + display: grid; + grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); + + padding: 1.5rem 3rem; flex-direction: column; - margin: 4rem 0; + justify-content: flex-end; + align-items: flex-start; + gap: var(--Padding-l, 48px); + align-self: stretch; - @media (min-width: 1024px) { - align-items: center; - } + border-radius: var(--radius-small); + background: var(--_contactBox__background); + color: var(--_contactBox__color); +} +.contactBox__inner--light { + --_contactBox__background: var(--background-bg-light-secondary); + --_contactBox__color: var(--text-primary); } -.content { +.textContent { + height: 100%; display: flex; - flex-direction: row; + flex-direction: column; gap: 1rem; - max-width: 960px; - @media (max-width: 1024px) { - flex-direction: column; - gap: 2rem; - } + justify-content: flex-end; } -.titleSection { +.contactSelectorWrapper { + container-type: inline-size; + container-name: contactSelectorWrapper; +} + +.contactSelector { + display: flex; + gap: 1rem; +} + +.tagList { display: flex; flex-direction: column; gap: 0.75rem; + + align-items: flex-start; + min-width: 120px; } -.contactSection { - display: flex; - gap: 1.5rem; +.employeeCard { + flex: 1; +} + +@media (max-width: 400px) { + .contactBox__inner { + padding: 1rem 1rem; + } +} + +@container contactSelectorWrapper (max-width: 350px) { + .contactSelector { + flex-direction: column; + } + + .tagList { + flex-direction: row; + } } diff --git a/src/components/customerCases/customerCase/contactInformation/contactSelector/ContactSelector.tsx b/src/components/customerCases/customerCase/contactInformation/contactSelector/ContactSelector.tsx deleted file mode 100644 index e086b10b2..000000000 --- a/src/components/customerCases/customerCase/contactInformation/contactSelector/ContactSelector.tsx +++ /dev/null @@ -1,72 +0,0 @@ -"use client"; - -import { useState } from "react"; - -import Button from "src/components/buttons/Button"; -import CustomerCaseEmployeeCard from "src/components/customerCaseEmployeeCard/CustomerCaseEmployeeCard"; -import { ChewbaccaEmployee } from "src/types/employees"; -import { CompanyLocation } from "studio/lib/interfaces/companyDetails"; - -import styles from "./contactSelector.module.css"; - -export type ContactByLocationMap = { - [locationId: string]: ChewbaccaEmployee; -}; - -export interface ContactSelectorProps { - language: string; - locations: CompanyLocation[]; - contactByLocation: ContactByLocationMap; - employeePageSlug?: string; -} - -export default function ContactSelector({ - language, - locations, - contactByLocation, - employeePageSlug, -}: ContactSelectorProps) { - const locationIds = Object.keys(contactByLocation); - - const [selectedLocationId, setSelectedLocationId] = useState( - locationIds.length === 0 ? locationIds[0] : null, - ); - - if (locationIds.length === 0) { - return; - } - - const selectedOrDefaultLocationId = selectedLocationId ?? locationIds[0]; - - return ( - <> -
- {locations.map((location) => ( - //Todo: replace this with tag component - - ))} -
-
- -
- - ); -} diff --git a/src/components/customerCases/customerCase/contactInformation/contactSelector/contactSelector.module.css b/src/components/customerCases/customerCase/contactInformation/contactSelector/contactSelector.module.css deleted file mode 100644 index e0f2ce2ef..000000000 --- a/src/components/customerCases/customerCase/contactInformation/contactSelector/contactSelector.module.css +++ /dev/null @@ -1,9 +0,0 @@ -.locationSection { - display: flex; - flex-direction: column; - gap: 0.75rem; -} - -.consultantSection { - min-width: 400px; -}