Files
web/apps/scandic-web/components/Blocks/DynamicContent/Stays/Previous/Cards.tsx
Chuma Mcphoy (We Ahead) 30b9d14fb0 Merged in feat/LOY-424-Sidepeek-Past-Stays (pull request #3270)
feat(LOY-424): Load More Past Stays via Sidepeek

* feat(LOY-424): Load More Past Stays via Sidepeek

* chore(LOY-424): use new section header

* fix(LOY-424): remove uneeded nextCursor check


Approved-by: Emma Zettervall
2025-12-03 15:19:25 +00:00

39 lines
1.1 KiB
TypeScript

"use client"
import { useState } from "react"
import ListContainer from "../ListContainer"
import { Card } from "./Card"
import { INITIAL_STAYS_FETCH_LIMIT } from "./data"
import { PreviousStaysSidePeek } from "./PreviousStaysSidePeek"
import { SeeAllCard } from "./SeeAllCard"
import styles from "./cards.module.css"
import type { PreviousStaysClientProps } from "@/types/components/myPages/stays/previous"
const MAX_VISIBLE_STAYS = 5
export function Cards({ initialPreviousStays }: PreviousStaysClientProps) {
const [isSidePeekOpen, setIsSidePeekOpen] = useState(false)
const stays = initialPreviousStays.data
const visibleStays = stays.slice(0, MAX_VISIBLE_STAYS)
const hasMoreStays = stays.length >= INITIAL_STAYS_FETCH_LIMIT
return (
<ListContainer>
<div className={styles.grid}>
{visibleStays.map((stay) => (
<Card key={stay.attributes.confirmationNumber} stay={stay} />
))}
{hasMoreStays && <SeeAllCard onPress={() => setIsSidePeekOpen(true)} />}
</div>
<PreviousStaysSidePeek
isOpen={isSidePeekOpen}
onClose={() => setIsSidePeekOpen(false)}
/>
</ListContainer>
)
}