diff --git a/apps/admin-ui/gql/gql-types.ts b/apps/admin-ui/gql/gql-types.ts index 2f57bd3b9..c5d1dcda7 100644 --- a/apps/admin-ui/gql/gql-types.ts +++ b/apps/admin-ui/gql/gql-types.ts @@ -5520,6 +5520,51 @@ export type ReserveeBillingFieldsFragment = { billingAddressZip?: string | null; }; +export type MetaFieldsFragment = { + applyingForFreeOfCharge?: boolean | null; + freeOfChargeReason?: string | null; + description?: string | null; + numPersons?: number | null; + reserveeFirstName?: string | null; + reserveeLastName?: string | null; + reserveeEmail?: string | null; + reserveePhone?: string | null; + reserveeType?: CustomerTypeChoice | null; + reserveeOrganisationName?: string | null; + reserveeId?: string | null; + reserveeIsUnregisteredAssociation?: boolean | null; + reserveeAddressStreet?: string | null; + reserveeAddressCity?: string | null; + reserveeAddressZip?: string | null; + billingFirstName?: string | null; + billingLastName?: string | null; + billingPhone?: string | null; + billingEmail?: string | null; + billingAddressStreet?: string | null; + billingAddressCity?: string | null; + billingAddressZip?: string | null; + ageGroup?: { + id: string; + pk?: number | null; + maximum?: number | null; + minimum: number; + } | null; + purpose?: { + id: string; + pk?: number | null; + nameFi?: string | null; + nameEn?: string | null; + nameSv?: string | null; + } | null; + homeCity?: { + id: string; + pk?: number | null; + nameFi?: string | null; + nameSv?: string | null; + nameEn?: string | null; + } | null; +}; + export type TermsOfUseNameFieldsFragment = { nameFi?: string | null; nameEn?: string | null; @@ -5990,8 +6035,6 @@ export type UnitQuery = { } | null; }>; location?: { - longitude?: string | null; - latitude?: string | null; id: string; addressStreetFi?: string | null; addressZip: string; @@ -8552,6 +8595,65 @@ export type SpaceQuery = { } | null; }; +export const ReserveeNameFieldsFragmentDoc = gql` + fragment ReserveeNameFields on ReservationNode { + reserveeFirstName + reserveeLastName + reserveeEmail + reserveePhone + reserveeType + reserveeOrganisationName + reserveeId + } +`; +export const ReserveeBillingFieldsFragmentDoc = gql` + fragment ReserveeBillingFields on ReservationNode { + reserveeId + reserveeIsUnregisteredAssociation + reserveeAddressStreet + reserveeAddressCity + reserveeAddressZip + billingFirstName + billingLastName + billingPhone + billingEmail + billingAddressStreet + billingAddressCity + billingAddressZip + } +`; +export const MetaFieldsFragmentDoc = gql` + fragment MetaFields on ReservationNode { + ...ReserveeNameFields + ...ReserveeBillingFields + applyingForFreeOfCharge + freeOfChargeReason + description + numPersons + ageGroup { + id + pk + maximum + minimum + } + purpose { + id + pk + nameFi + nameEn + nameSv + } + homeCity { + id + pk + nameFi + nameSv + nameEn + } + } + ${ReserveeNameFieldsFragmentDoc} + ${ReserveeBillingFieldsFragmentDoc} +`; export const TermsOfUseNameFieldsFragmentDoc = gql` fragment TermsOfUseNameFields on TermsOfUseNode { nameFi @@ -9054,33 +9156,6 @@ export const ReservationsInIntervalFragmentDoc = gql` } } `; -export const ReserveeNameFieldsFragmentDoc = gql` - fragment ReserveeNameFields on ReservationNode { - reserveeFirstName - reserveeLastName - reserveeEmail - reserveePhone - reserveeType - reserveeOrganisationName - reserveeId - } -`; -export const ReserveeBillingFieldsFragmentDoc = gql` - fragment ReserveeBillingFields on ReservationNode { - reserveeId - reserveeIsUnregisteredAssociation - reserveeAddressStreet - reserveeAddressCity - reserveeAddressZip - billingFirstName - billingLastName - billingPhone - billingEmail - billingAddressStreet - billingAddressCity - billingAddressZip - } -`; export const ReservationMetaFieldsFragmentDoc = gql` fragment ReservationMetaFields on ReservationNode { ageGroup { @@ -9530,8 +9605,6 @@ export const UnitDocument = gql` } location { ...LocationFields - longitude - latitude } } } diff --git a/apps/admin-ui/src/common/queries.tsx b/apps/admin-ui/src/common/queries.tsx index 2545e8d41..5b13b9ed2 100644 --- a/apps/admin-ui/src/common/queries.tsx +++ b/apps/admin-ui/src/common/queries.tsx @@ -43,8 +43,6 @@ export const UNIT_QUERY = gql` } location { ...LocationFields - longitude - latitude } } } diff --git a/apps/ui/components/Instructions.tsx b/apps/ui/components/Instructions.tsx index e5aec7a58..de1a55812 100644 --- a/apps/ui/components/Instructions.tsx +++ b/apps/ui/components/Instructions.tsx @@ -1,8 +1,9 @@ import { + type InstructionsFragment, type Maybe, - type ReservationQuery, ReservationStateChoice, } from "@/gql/gql-types"; +import { gql } from "@apollo/client"; import { H4 } from "common"; import { convertLanguageCode, @@ -11,12 +12,28 @@ import { import { Sanitize } from "common/src/components/Sanitize"; import { useTranslation } from "next-i18next"; -// TODO replace with a fragment -type NodeT = NonNullable; +export const INSTRUCTIOSN_FRAGMENT = gql` + fragment Instructions on ReservationNode { + id + state + reservationUnits { + id + reservationPendingInstructionsFi + reservationPendingInstructionsEn + reservationPendingInstructionsSv + reservationConfirmedInstructionsFi + reservationConfirmedInstructionsEn + reservationConfirmedInstructionsSv + reservationCancelledInstructionsFi + reservationCancelledInstructionsEn + reservationCancelledInstructionsSv + } + } +`; + type Props = { - reservation: Pick; + reservation: InstructionsFragment; }; - export function Instructions({ reservation }: Props): JSX.Element | null { const { t, i18n } = useTranslation(); diff --git a/apps/ui/components/reservation-unit/Address.tsx b/apps/ui/components/reservation-unit/Address.tsx index da7e00181..80dc5c365 100644 --- a/apps/ui/components/reservation-unit/Address.tsx +++ b/apps/ui/components/reservation-unit/Address.tsx @@ -5,7 +5,7 @@ import { fontMedium, H4 } from "common/src/common/typography"; import type { Maybe, LocationFieldsI18nFragment, - UnitFieldsFragment, + AddressFieldsFragment, } from "@gql/gql-types"; import { IconLinkExternal } from "hds-react"; import { IconButton } from "common/src/components"; @@ -16,6 +16,7 @@ import { getTranslationSafe, } from "common/src/common/util"; import { type LocalizationLanguages } from "common/src/helpers"; +import { gql } from "@apollo/client"; const AddressSpan = styled.span` font-size: var(--fontsize-body-l); @@ -39,7 +40,7 @@ type UrlReturn = string; function createHslUrl( locale: LocalizationLanguages, - location?: Maybe + location: Maybe | undefined ): UrlReturn { if (!location) { return ""; @@ -61,18 +62,14 @@ function createHslUrl( function createGoogleUrl( locale: LocalizationLanguages, - location?: Maybe + location: Maybe | undefined ): UrlReturn { if (!location) { return ""; } - const addressStreet = - getTranslationSafe(location, "addressStreet", locale) || - location.addressStreetFi; - const addressCity = - getTranslationSafe(location, "addressCity", locale) || - location.addressCityFi; + const addressStreet = getTranslationSafe(location, "addressStreet", locale); + const addressCity = getTranslationSafe(location, "addressCity", locale); const destination = addressStreet ? encodeURI(`${addressStreet},${addressCity}`) @@ -83,7 +80,7 @@ function createGoogleUrl( function createMapUrl( locale: LocalizationLanguages, - unit?: Maybe> + unit: Maybe> | undefined ): string { if (!unit?.tprekId) { return ""; @@ -94,7 +91,7 @@ function createMapUrl( function createAccessibilityUrl( locale: LocalizationLanguages, - unit?: Maybe> + unit: Maybe> | undefined ): UrlReturn { if (!unit?.tprekId) { return ""; @@ -105,7 +102,7 @@ function createAccessibilityUrl( type Props = { title: string; - unit?: Maybe | undefined; + unit: Maybe | undefined; }; export function AddressSection({ title, unit }: Props): JSX.Element { @@ -114,12 +111,12 @@ export function AddressSection({ title, unit }: Props): JSX.Element { const { location } = unit ?? {}; const lang = convertLanguageCode(i18n.language); - const addressStreet = - (location && getTranslationSafe(location, "addressStreet", lang)) || - location?.addressStreetFi; - const addressCity = - (location && getTranslationSafe(location, "addressCity", lang)) || - location?.addressCityFi; + const addressStreet = location + ? getTranslationSafe(location, "addressStreet", lang) + : undefined; + const addressCity = location + ? getTranslationSafe(location, "addressCity", lang) + : undefined; const unitMapUrl = createMapUrl(lang, unit); const googleUrl = createGoogleUrl(lang, location); @@ -137,24 +134,32 @@ export function AddressSection({ title, unit }: Props): JSX.Element { } + icon={