30 lines
890 B
TypeScript
30 lines
890 B
TypeScript
import Puffs from "./Asides/Puffs"
|
|
import Contact from "./Asides/Contacts"
|
|
|
|
import { AsideTypenameEnum } from "@/types/requests/utils/typename"
|
|
import type { AsideProps } from "@/types/components/current/aside"
|
|
|
|
export default function Aside({ blocks }: AsideProps) {
|
|
if (!blocks?.length) {
|
|
return null
|
|
}
|
|
|
|
return (
|
|
<aside>
|
|
{blocks.map((block, idx) => {
|
|
const type = block.__typename
|
|
switch (type) {
|
|
case AsideTypenameEnum.CurrentBlocksPageAsideContact:
|
|
return block.contact.contactConnection.edges.map((contact) => (
|
|
<Contact key={`contact-${idx}`} {...contact.node} />
|
|
))
|
|
case AsideTypenameEnum.CurrentBlocksPageAsidePuff:
|
|
return <Puffs key={`block-${idx}`} puffs={block.puff.puffConnection.edges} />
|
|
default:
|
|
return null
|
|
}
|
|
})}
|
|
</aside>
|
|
)
|
|
}
|