Merged in feat/SW-1512-selectrateenterdetails-room- (pull request #2407)

feat: SW-1512 Moved room description below amenities & bed options in sidepeek

* feat: SW-1512 Moved room description below amenities & bed options in sidepeek

* feat: SW-1512 Added sub-title for room description

* feat: SW-1512 Optimized styles


Approved-by: Erik Tiekstra
This commit is contained in:
Hrishikesh Vaipurkar
2025-06-25 11:04:44 +00:00
parent d4894c1647
commit c0efbd17ff
2 changed files with 99 additions and 90 deletions

View File

@@ -1,11 +1,10 @@
import { useIntl } from "react-intl" import { useIntl } from "react-intl"
import { Typography } from "@scandic-hotels/design-system/Typography"
import { BED_TYPE_ICONS, type BedTypes } from "@/constants/booking" import { BED_TYPE_ICONS, type BedTypes } from "@/constants/booking"
import ImageGallery from "@/components/ImageGallery" import ImageGallery from "@/components/ImageGallery"
import Body from "@/components/TempDesignSystem/Text/Body"
import Caption from "@/components/TempDesignSystem/Text/Caption"
import Subtitle from "@/components/TempDesignSystem/Text/Subtitle"
import { mapApiImagesToGalleryImages } from "@/utils/imageGallery" import { mapApiImagesToGalleryImages } from "@/utils/imageGallery"
import { FacilityIcon } from "../facilityIcon" import { FacilityIcon } from "../facilityIcon"
@@ -30,7 +29,8 @@ export function RoomSidePeekContent({ room }: RoomSidePeekContentProps) {
<div className={styles.wrapper}> <div className={styles.wrapper}>
<div className={styles.mainContent}> <div className={styles.mainContent}>
{totalOccupancy && ( {totalOccupancy && (
<Caption color="uiTextMediumContrast"> <Typography variant="Body/Supporting text (caption)/smRegular">
<p>
{intl.formatMessage( {intl.formatMessage(
{ {
defaultMessage: defaultMessage:
@@ -41,10 +41,12 @@ export function RoomSidePeekContent({ room }: RoomSidePeekContentProps) {
range: totalOccupancy.range, range: totalOccupancy.range,
} }
)} )}
</Caption> </p>
</Typography>
)} )}
{roomSize && ( {roomSize && (
<Caption color="uiTextMediumContrast"> <Typography variant="Body/Supporting text (caption)/smRegular">
<p>
{roomSize.min === roomSize.max {roomSize.min === roomSize.max
? intl.formatMessage( ? intl.formatMessage(
{ {
@@ -63,19 +65,22 @@ export function RoomSidePeekContent({ room }: RoomSidePeekContentProps) {
roomSizeMax: roomSize.max, roomSizeMax: roomSize.max,
} }
)} )}
</Caption> </p>
</Typography>
)} )}
<div className={styles.imageContainer}> <div className={styles.imageContainer}>
<ImageGallery images={galleryImages} title={room.name} height={280} /> <ImageGallery images={galleryImages} title={room.name} height={280} />
</div> </div>
<Body color="uiTextHighContrast">{roomDescription}</Body>
</div> </div>
<div className={styles.listContainer}> <div className={styles.listContainer}>
<Subtitle type="two" color="uiTextHighContrast"> <Typography variant="Title/Subtitle/md">
<p>
{intl.formatMessage({ {intl.formatMessage({
defaultMessage: "Room amenities", defaultMessage: "Room amenities",
})} })}
</Subtitle> </p>
</Typography>
<Typography variant="Body/Paragraph/mdRegular">
<ul className={styles.facilityList}> <ul className={styles.facilityList}>
{room.roomFacilities {room.roomFacilities
.sort((a, b) => a.sortOrder - b.sortOrder) .sort((a, b) => a.sortOrder - b.sortOrder)
@@ -87,7 +92,6 @@ export function RoomSidePeekContent({ room }: RoomSidePeekContentProps) {
size={24} size={24}
color="Icon/Default" color="Icon/Default"
/> />
<Body asChild color="uiTextMediumContrast">
<span> <span>
{facility.availableInAllRooms {facility.availableInAllRooms
? facility.name ? facility.name
@@ -101,23 +105,27 @@ export function RoomSidePeekContent({ room }: RoomSidePeekContentProps) {
} }
)} )}
</span> </span>
</Body>
</li> </li>
) )
})} })}
</ul> </ul>
</Typography>
</div> </div>
<div className={styles.listContainer}> <div className={styles.listContainer}>
<Subtitle type="two" color="uiTextHighContrast"> <Typography variant="Title/Subtitle/md">
<p>
{intl.formatMessage({ {intl.formatMessage({
defaultMessage: "Bed options", defaultMessage: "Bed options",
})} })}
</Subtitle> </p>
<Body color="grey"> </Typography>
<Typography variant="Body/Paragraph/mdRegular">
<p>
{intl.formatMessage({ {intl.formatMessage({
defaultMessage: "Subject to availability", defaultMessage: "Subject to availability",
})} })}
</Body> </p>
</Typography>
<ul className={styles.bedOptions}> <ul className={styles.bedOptions}>
{room.roomTypes.map((roomType) => { {room.roomTypes.map((roomType) => {
const description = const description =
@@ -131,14 +139,26 @@ export function RoomSidePeekContent({ room }: RoomSidePeekContentProps) {
<li key={roomType.code}> <li key={roomType.code}>
{MainBedIcon ? <MainBedIcon height={24} width={24} /> : null} {MainBedIcon ? <MainBedIcon height={24} width={24} /> : null}
{ExtraBedIcon ? <ExtraBedIcon height={24} width={30} /> : null} {ExtraBedIcon ? <ExtraBedIcon height={24} width={30} /> : null}
<Body color="uiTextMediumContrast" asChild> <Typography variant="Body/Paragraph/mdRegular">
<span>{description}</span> <span>{description}</span>
</Body> </Typography>
</li> </li>
) )
})} })}
</ul> </ul>
</div> </div>
<div className={styles.listContainer}>
<Typography variant="Title/Subtitle/md">
<p>
{intl.formatMessage({
defaultMessage: "About the hotel",
})}
</p>
</Typography>
<Typography variant="Body/Paragraph/mdRegular">
<p>{roomDescription}</p>
</Typography>
</div>
</div> </div>
) )
} }

View File

@@ -1,9 +1,3 @@
.button {
margin-left: auto;
padding: 0 0 0 var(--Spacing-x-half);
text-decoration: none;
}
.wrapper { .wrapper {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@@ -14,6 +8,10 @@
); /* Creates space between the wrapper and buttonContainer */ ); /* Creates space between the wrapper and buttonContainer */
} }
.mainContent {
color: var(--Text-Secondary);
}
.mainContent, .mainContent,
.listContainer { .listContainer {
display: flex; display: flex;
@@ -36,6 +34,7 @@
.facilityList { .facilityList {
column-count: 2; column-count: 2;
column-gap: var(--Spacing-x2); column-gap: var(--Spacing-x2);
color: var(--Text-Secondary);
} }
.facilityList li { .facilityList li {
@@ -44,6 +43,10 @@
margin-bottom: var(--Spacing-x-half); margin-bottom: var(--Spacing-x-half);
} }
.bedOptions {
color: var(--Text-Secondary);
}
.bedOptions li { .bedOptions li {
display: flex; display: flex;
gap: var(--Spacing-x1); gap: var(--Spacing-x1);
@@ -53,17 +56,3 @@
.facilityList li svg { .facilityList li svg {
flex-shrink: 0; flex-shrink: 0;
} }
.noIcon {
margin-left: var(--Spacing-x4);
}
.buttonContainer {
background-color: var(--Background-Primary);
border-top: 1px solid var(--Base-Border-Subtle);
padding: var(--Spacing-x4) var(--Spacing-x2);
width: 100%;
position: absolute;
left: 0;
bottom: 0;
}