2024-04-04 13:48:45 +00:00
|
|
|
import { Box, Typography, useTheme } from "@mui/material";
|
|
|
|
|
import { FC } from "react";
|
|
|
|
|
import { PartnerItem } from "./PartnerItem/PartnerItem";
|
|
|
|
|
|
|
|
|
|
export type Partner = {
|
|
|
|
|
name: string;
|
|
|
|
|
logo?: string;
|
|
|
|
|
category: string;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
type PartnersBoardProps = {
|
|
|
|
|
partners: Partner[];
|
|
|
|
|
setIsModalOpen: (value: boolean) => void;
|
2024-04-05 10:48:10 +00:00
|
|
|
setCompanyName: (value: string) => void;
|
2024-04-04 13:48:45 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export const PartnersBoard: FC<PartnersBoardProps> = ({
|
|
|
|
|
partners,
|
|
|
|
|
setIsModalOpen,
|
2024-04-05 10:48:10 +00:00
|
|
|
setCompanyName,
|
2024-04-04 13:48:45 +00:00
|
|
|
}) => {
|
|
|
|
|
const theme = useTheme();
|
|
|
|
|
|
|
|
|
|
const partnersByCategory = partners.reduce(
|
|
|
|
|
(acc, partner) => {
|
|
|
|
|
(acc[partner.category] = acc[partner.category] || []).push(partner);
|
|
|
|
|
return acc;
|
|
|
|
|
},
|
|
|
|
|
{} as Record<string, Partner[]>,
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<Box
|
|
|
|
|
sx={{
|
|
|
|
|
width: "100%",
|
|
|
|
|
display: "flex",
|
|
|
|
|
flexDirection: "column",
|
|
|
|
|
justifyContent: { xs: "center", sm: "center", md: "start" },
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
{Object.entries(partnersByCategory).map(([category, partners]) => (
|
|
|
|
|
<Box key={category}>
|
|
|
|
|
<Typography
|
|
|
|
|
variant="h6"
|
|
|
|
|
sx={{
|
|
|
|
|
textAlign: { xs: "center", sm: "start", md: "start" },
|
|
|
|
|
lineHeight: "1",
|
|
|
|
|
marginBottom: "12px",
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
{category}
|
|
|
|
|
</Typography>
|
|
|
|
|
<Box
|
|
|
|
|
sx={{
|
|
|
|
|
display: "flex",
|
|
|
|
|
flexWrap: "wrap",
|
|
|
|
|
justifyContent: { xs: "center", sm: "start", md: "start" },
|
|
|
|
|
}}
|
|
|
|
|
>
|
|
|
|
|
{partners.map((partner) => (
|
|
|
|
|
<PartnerItem
|
|
|
|
|
key={partner.name}
|
|
|
|
|
partner={partner}
|
|
|
|
|
setIsModalOpen={setIsModalOpen}
|
2024-04-05 10:48:10 +00:00
|
|
|
setCompanyName={setCompanyName}
|
2024-04-04 13:48:45 +00:00
|
|
|
/>
|
|
|
|
|
))}
|
|
|
|
|
</Box>
|
|
|
|
|
</Box>
|
|
|
|
|
))}
|
|
|
|
|
</Box>
|
|
|
|
|
);
|
|
|
|
|
};
|