| | |
| | | Print as PrintIcon, |
| | | Share as ShareIcon, |
| | | } from '@mui/icons-material'; |
| | | import { MAP_MODE } from "./constants"; |
| | | import Player from './player'; |
| | | import * as Tool from './tool'; |
| | | import { NotificationProvider, useNotification } from './Notification'; |
| | |
| | | const [app, setApp] = useState(null); |
| | | const [mapContainer, setMapContainer] = useState(null); |
| | | |
| | | const [mode, setMode] = useState(MapMode.OBSERVER_MODE); |
| | | const [mode, setMode] = useState(MAP_MODE.OBSERVER_MODE); |
| | | const [insightVisible, setInsightVisible] = useState(false); |
| | | const [deviceVisible, setDeviceVisible] = useState(false); |
| | | const [settingsVisible, setSettingsVisible] = useState(false); |
| | |
| | | setBatchSprites([]); |
| | | |
| | | switch (mode) { |
| | | case MapMode.OBSERVER_MODE: |
| | | case MAP_MODE.OBSERVER_MODE: |
| | | player.hideGridLines(); |
| | | player.hideStarryBackground(); |
| | | |
| | |
| | | }); |
| | | |
| | | break |
| | | case MapMode.MOVABLE_MODE: |
| | | case MAP_MODE.MOVABLE_MODE: |
| | | player.showGridLines(); |
| | | player.hideStarryBackground(); |
| | | |
| | |
| | | Tool.beMovable(child); |
| | | }) |
| | | break |
| | | case MapMode.SETTINGS_MODE: |
| | | case MAP_MODE.SETTINGS_MODE: |
| | | player.hideGridLines(); |
| | | player.showStarryBackground(); // 0x2f68ac |
| | | |
| | |
| | | /> |
| | | <Box sx={{ flexGrow: 1 }} /> |
| | | |
| | | {mode === MapMode.OBSERVER_MODE && ( |
| | | {mode === MAP_MODE.OBSERVER_MODE && ( |
| | | <> |
| | | <Button |
| | | variant="contained" |
| | |
| | | </> |
| | | )} |
| | | |
| | | {mode === MapMode.MOVABLE_MODE && ( |
| | | {mode === MAP_MODE.MOVABLE_MODE && ( |
| | | <> |
| | | <Button |
| | | variant="outlined" |
| | |
| | | </> |
| | | )} |
| | | |
| | | {mode === MapMode.SETTINGS_MODE && ( |
| | | {mode === MAP_MODE.SETTINGS_MODE && ( |
| | | <> |
| | | <Button |
| | | variant="outlined" |
| | |
| | | borderRadius: 1, |
| | | }} |
| | | > |
| | | <MenuItem value={MapMode.OBSERVER_MODE}>监控模式</MenuItem> |
| | | <MenuItem value={MapMode.MOVABLE_MODE}>编辑模式</MenuItem> |
| | | <MenuItem value={MapMode.SETTINGS_MODE}>配置模式</MenuItem> |
| | | <MenuItem value={MAP_MODE.OBSERVER_MODE}>监控模式</MenuItem> |
| | | <MenuItem value={MAP_MODE.MOVABLE_MODE}>编辑模式</MenuItem> |
| | | <MenuItem value={MAP_MODE.SETTINGS_MODE}>配置模式</MenuItem> |
| | | </Select> |
| | | </Box> |
| | | {/* content */} |
| | |
| | | onCancel={() => { |
| | | setBatchSelectionVisible(false); |
| | | }} |
| | | batchSprites={batchSprites} |
| | | mode={mode} |
| | | width={570} |
| | | /> |
| | | |
| | |
| | | </NotificationProvider> |
| | | ) |
| | | } |
| | | |
| | | export const MapMode = Object.freeze({ |
| | | OBSERVER_MODE: "1", |
| | | MOVABLE_MODE: "2", |
| | | SETTINGS_MODE: "3", |
| | | }) |
| | | |
| | | export default MapPage; |