2020-05-03 18:22:09 +10:00
|
|
|
import React, { useContext } from "react";
|
|
|
|
|
import { Flex, Box, Text } from "theme-ui";
|
2020-04-25 00:42:23 +10:00
|
|
|
import SimpleBar from "simplebar-react";
|
2020-04-23 11:54:29 +10:00
|
|
|
|
|
|
|
|
import AddIcon from "../../icons/AddIcon";
|
|
|
|
|
|
2020-04-23 20:32:33 +10:00
|
|
|
import MapTile from "./MapTile";
|
2020-05-03 18:22:09 +10:00
|
|
|
import Link from "../Link";
|
|
|
|
|
|
|
|
|
|
import DatabaseContext from "../../contexts/DatabaseContext";
|
2020-04-23 11:54:29 +10:00
|
|
|
|
2020-04-23 20:32:33 +10:00
|
|
|
function MapTiles({
|
|
|
|
|
maps,
|
|
|
|
|
selectedMap,
|
2020-04-26 17:12:15 +10:00
|
|
|
selectedMapState,
|
2020-04-23 20:32:33 +10:00
|
|
|
onMapSelect,
|
|
|
|
|
onMapAdd,
|
|
|
|
|
onMapRemove,
|
|
|
|
|
onMapReset,
|
2020-05-19 16:21:01 +10:00
|
|
|
onDone,
|
2020-04-23 20:32:33 +10:00
|
|
|
}) {
|
2020-05-03 18:22:09 +10:00
|
|
|
const { databaseStatus } = useContext(DatabaseContext);
|
2020-04-23 11:54:29 +10:00
|
|
|
return (
|
2020-05-03 18:22:09 +10:00
|
|
|
<Box sx={{ position: "relative" }}>
|
|
|
|
|
<SimpleBar style={{ maxHeight: "300px", width: "500px" }}>
|
2020-04-25 00:42:23 +10:00
|
|
|
<Flex
|
2020-05-03 18:22:09 +10:00
|
|
|
py={2}
|
|
|
|
|
bg="muted"
|
2020-04-25 00:42:23 +10:00
|
|
|
sx={{
|
2020-05-03 18:22:09 +10:00
|
|
|
flexWrap: "wrap",
|
|
|
|
|
width: "500px",
|
2020-04-25 00:42:23 +10:00
|
|
|
borderRadius: "4px",
|
|
|
|
|
}}
|
|
|
|
|
>
|
2020-05-03 18:22:09 +10:00
|
|
|
<Flex
|
|
|
|
|
onClick={onMapAdd}
|
|
|
|
|
sx={{
|
|
|
|
|
":hover": {
|
|
|
|
|
color: "primary",
|
|
|
|
|
},
|
|
|
|
|
":focus": {
|
|
|
|
|
outline: "none",
|
|
|
|
|
},
|
|
|
|
|
":active": {
|
|
|
|
|
color: "secondary",
|
|
|
|
|
},
|
|
|
|
|
width: "150px",
|
|
|
|
|
height: "150px",
|
|
|
|
|
borderRadius: "4px",
|
|
|
|
|
justifyContent: "center",
|
|
|
|
|
alignItems: "center",
|
|
|
|
|
cursor: "pointer",
|
|
|
|
|
}}
|
|
|
|
|
m={2}
|
|
|
|
|
bg="muted"
|
|
|
|
|
aria-label="Add Map"
|
|
|
|
|
title="Add Map"
|
|
|
|
|
>
|
|
|
|
|
<AddIcon large />
|
|
|
|
|
</Flex>
|
|
|
|
|
{maps.map((map) => (
|
|
|
|
|
<MapTile
|
|
|
|
|
key={map.id}
|
|
|
|
|
map={map}
|
|
|
|
|
mapState={
|
|
|
|
|
selectedMap && map.id === selectedMap.id && selectedMapState
|
|
|
|
|
}
|
|
|
|
|
isSelected={selectedMap && map.id === selectedMap.id}
|
|
|
|
|
onMapSelect={onMapSelect}
|
|
|
|
|
onMapRemove={onMapRemove}
|
|
|
|
|
onMapReset={onMapReset}
|
2020-05-19 16:21:01 +10:00
|
|
|
onDone={onDone}
|
2020-05-03 18:22:09 +10:00
|
|
|
/>
|
|
|
|
|
))}
|
2020-04-25 00:42:23 +10:00
|
|
|
</Flex>
|
2020-05-03 18:22:09 +10:00
|
|
|
</SimpleBar>
|
|
|
|
|
{databaseStatus === "disabled" && (
|
|
|
|
|
<Box
|
|
|
|
|
sx={{
|
|
|
|
|
position: "absolute",
|
|
|
|
|
top: 0,
|
|
|
|
|
left: 0,
|
|
|
|
|
right: 0,
|
|
|
|
|
textAlign: "center",
|
|
|
|
|
}}
|
|
|
|
|
bg="highlight"
|
|
|
|
|
p={1}
|
|
|
|
|
>
|
|
|
|
|
<Text as="p" variant="body2">
|
2020-05-03 18:30:01 +10:00
|
|
|
Map saving is unavailable. See <Link to="/faq#saving">FAQ</Link> for
|
|
|
|
|
more information.
|
2020-05-03 18:22:09 +10:00
|
|
|
</Text>
|
|
|
|
|
</Box>
|
|
|
|
|
)}
|
|
|
|
|
</Box>
|
2020-04-23 11:54:29 +10:00
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-23 18:01:40 +10:00
|
|
|
export default MapTiles;
|