2021-05-14 18:02:50 +10:00
|
|
|
import React from "react";
|
2021-05-20 13:50:19 +10:00
|
|
|
import { Grid } from "theme-ui";
|
2021-05-14 18:02:50 +10:00
|
|
|
|
2021-05-24 13:34:21 +10:00
|
|
|
import Tile from "../tile/Tile";
|
2021-05-25 16:56:37 +10:00
|
|
|
import MapImage from "./MapImage";
|
2021-05-14 18:02:50 +10:00
|
|
|
|
2021-05-24 13:34:21 +10:00
|
|
|
import useResponsiveLayout from "../../hooks/useResponsiveLayout";
|
|
|
|
|
|
|
|
|
|
function MapTileGroup({ group, maps, isSelected, onSelect, onDoubleClick }) {
|
|
|
|
|
const layout = useResponsiveLayout();
|
|
|
|
|
|
2021-05-14 18:02:50 +10:00
|
|
|
return (
|
|
|
|
|
<Tile
|
|
|
|
|
title={group.name}
|
|
|
|
|
isSelected={isSelected}
|
2021-05-24 13:34:21 +10:00
|
|
|
onSelect={() => onSelect(group.id)}
|
|
|
|
|
onDoubleClick={onDoubleClick}
|
2021-05-14 18:02:50 +10:00
|
|
|
>
|
2021-05-25 15:47:52 +10:00
|
|
|
<Grid
|
|
|
|
|
columns={`repeat(${layout.groupGridColumns}, 1fr)`}
|
|
|
|
|
p={2}
|
2021-06-12 21:25:03 +10:00
|
|
|
sx={{
|
|
|
|
|
gridGap: 2,
|
|
|
|
|
gridTemplateRows: `repeat(${layout.groupGridColumns}, 1fr)`,
|
|
|
|
|
}}
|
2021-05-25 15:47:52 +10:00
|
|
|
>
|
2021-06-12 21:25:03 +10:00
|
|
|
{maps
|
|
|
|
|
.slice(0, layout.groupGridColumns * layout.groupGridColumns)
|
|
|
|
|
.map((map) => (
|
|
|
|
|
<MapImage
|
|
|
|
|
sx={{ borderRadius: "8px" }}
|
|
|
|
|
map={map}
|
|
|
|
|
key={`${map.id}-group-tile`}
|
|
|
|
|
/>
|
|
|
|
|
))}
|
2021-05-20 13:50:19 +10:00
|
|
|
</Grid>
|
2021-05-14 18:02:50 +10:00
|
|
|
</Tile>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default MapTileGroup;
|