Files
web/packages/booking-flow/lib/components/EnterDetails/Section/index.tsx
Anton Gunnarsson 3e3b15940f Merged in fix/booking-flow-eslint-fix (pull request #3342)
fix: Upgrade booking-flow eslint config

* Upgrade booking-flow eslint config


Approved-by: Bianca Widstam
2025-12-12 11:40:45 +00:00

91 lines
2.4 KiB
TypeScript

"use client"
import { useEffect, useState } from "react"
import { useIntl } from "react-intl"
import { Typography } from "@scandic-hotels/design-system/Typography"
import { useRoomContext } from "../../../contexts/EnterDetails/RoomContext"
import { EnterDetailsStepEnum } from "../../../stores/enter-details/enterDetailsStep"
import styles from "./section.module.css"
type SectionProps = {
header: string
label: string
additionalInfo?: string | null
step: EnterDetailsStepEnum
disabled?: boolean
}
export default function Section({
children,
header,
label,
additionalInfo,
step,
disabled,
}: React.PropsWithChildren<SectionProps>) {
const intl = useIntl()
const {
room: { bedType, breakfast },
} = useRoomContext()
const [title, setTitle] = useState(label)
const noBreakfastTitle = intl.formatMessage({
id: "common.noBreakfast",
defaultMessage: "No breakfast",
})
const breakfastTitle = intl.formatMessage({
id: "common.breakfastBuffet",
defaultMessage: "Breakfast buffet",
})
useEffect(() => {
if (step === EnterDetailsStepEnum.selectBed && bedType) {
// eslint-disable-next-line react-hooks/set-state-in-effect
setTitle(bedType.description)
}
// If breakfast step, check if an option has been selected
if (step === EnterDetailsStepEnum.breakfast && breakfast !== undefined) {
if (breakfast === false) {
setTitle(noBreakfastTitle)
} else {
setTitle(breakfastTitle)
}
}
}, [bedType, breakfast, setTitle, step, breakfastTitle, noBreakfastTitle])
return (
<div
className={`${styles.section} ${disabled ? styles.disabled : ""}`}
data-step={step}
>
<header className={styles.header}>
<Typography variant="Title/Overline/sm">
<h2 data-at-id="details-section-heading" className={styles.heading}>
{header}
</h2>
</Typography>
<Typography variant="Title/Subtitle/md">
<p
data-at-id="details-section-subheading"
className={styles.subheading}
>
{title}
</p>
</Typography>
{additionalInfo ? (
<Typography variant="Body/Paragraph/mdRegular">
<p className={styles.additionalInfo}>{additionalInfo}</p>
</Typography>
) : null}
</header>
<div className={styles.content}>
<div className={styles.contentWrapper}>{children}</div>
</div>
</div>
)
}