| | |
| | | import * as Http from './http'; |
| | | import WebSocketClient from './websocket' |
| | | import ConfirmButton from "../page/components/ConfirmButton"; |
| | | import { FitScreen } from '@mui/icons-material'; |
| | | import { FitScreen, AltRoute } from '@mui/icons-material'; |
| | | import MapSearch from "./header/MapSearch"; |
| | | import { startupOrShutdown } from "./http"; |
| | | import PulseSignal from "../page/components/PulseSignal"; |
| | | |
| | | let player; |
| | | let websocket; |
| | |
| | | const prevCurSpriteRef = useRef(); |
| | | const [batchSprites, setBatchSprites] = useState([]); |
| | | |
| | | const [rcsStatus, setRcsStatus] = useState(null); |
| | | const [showRoutes, setShowRoutes] = useState(false); |
| | | const [curZone, setCurZone] = useState(() => { |
| | | const storedValue = localStorage.getItem('curZone'); |
| | | return storedValue !== null ? JSON.parse(storedValue) : null; |
| | |
| | | Http.setMapContainer(player.mapContainer); |
| | | websocket = new WebSocketClient('/ws/map/websocket'); |
| | | |
| | | await Http.fetchMapData(); |
| | | await Http.fetchMapData(curZone, setRcsStatus); |
| | | websocket.connect(); |
| | | websocket.onMessage = (wsMsg) => { |
| | | Tool.generateDynamicGraphic(curZone, JSON.parse(wsMsg), setCurSprite); |
| | |
| | | |
| | | const switchMode = (mode) => { |
| | | Tool.removeSelectedEffect(); |
| | | player.hideGridLines(); |
| | | |
| | | setInsightVisible(false); |
| | | setDeviceVisible(false); |
| | |
| | | |
| | | switch (mode) { |
| | | case MAP_MODE.OBSERVER_MODE: |
| | | player.hideGridLines(); |
| | | player.hideStarryBackground(); |
| | | |
| | | player.activateMapMultiSelect((selectedSprites, restartFn) => { |
| | | Tool.multipleSelectEnhancer(selectedSprites, setCurSprite, setBatchSprites); |
| | | }); |
| | |
| | | break |
| | | case MAP_MODE.MOVABLE_MODE: |
| | | player.showGridLines(); |
| | | player.hideStarryBackground(); |
| | | Tool.hideRoutes(curZone, setShowRoutes); |
| | | |
| | | player.activateMapMultiSelect((selectedSprites, restartFn) => { |
| | | Tool.spriteListBeMovable(selectedSprites, () => { |
| | |
| | | }) |
| | | break |
| | | case MAP_MODE.SETTINGS_MODE: |
| | | player.hideGridLines(); |
| | | // player.showStarryBackground(); // 0x2f68ac |
| | | |
| | | player.activateMapMultiSelect((selectedSprites, restartFn) => { |
| | | Tool.multipleSelectEnhancer(selectedSprites, setCurSprite, setBatchSprites); |
| | | }); |
| | |
| | | } |
| | | if (curSprite) { |
| | | if (mode === MAP_MODE.OBSERVER_MODE) { |
| | | Tool.showSelectedEffect(curSprite) |
| | | setInsightVisible(true) |
| | | Tool.showSelectedEffect(curSprite); |
| | | setInsightVisible(true); |
| | | } |
| | | if (mode === MAP_MODE.SETTINGS_MODE) { |
| | | Tool.showSelectedEffect(curSprite) |
| | | setSettingsVisible(true) |
| | | Tool.showSelectedEffect(curSprite); |
| | | setSettingsVisible(true); |
| | | } |
| | | } else { |
| | | Tool.removeSelectedEffect(); |
| | | setInsightVisible(false); |
| | | setSettingsVisible(false); |
| | | } |
| | | }, [curSprite]); |
| | | const prevCurSprite = prevCurSpriteRef.current; |
| | |
| | | |
| | | {mode === MAP_MODE.OBSERVER_MODE && ( |
| | | <> |
| | | <Box sx={{ mr: 2, display: 'flex', alignItems: 'center' }}> |
| | | <PulseSignal |
| | | negative |
| | | negativeColor = '#a4b0be' |
| | | flag={rcsStatus} |
| | | width={12} |
| | | /> |
| | | </Box> |
| | | <Button |
| | | variant="contained" |
| | | color="primary" |
| | | color={rcsStatus ? 'inherit' : 'primary'} |
| | | sx={{ mr: 2 }} |
| | | onClick={() => { |
| | | startupOrShutdown(() => { |
| | | setRcsStatus(!rcsStatus); |
| | | }); |
| | | }} |
| | | > |
| | | {translate('page.map.action.startup')} |
| | | {rcsStatus ? translate('page.map.action.shutdown') : translate('page.map.action.startup')} |
| | | </Button> |
| | | <Button variant="contained" color="primary"> |
| | | {translate('page.map.action.monitor')} |
| | |
| | | bottom: 30, |
| | | display: 'flex', |
| | | flexDirection: 'column', |
| | | gap: 1 |
| | | gap: 2 |
| | | }} |
| | | > |
| | | {mode !== MAP_MODE.MOVABLE_MODE && ( |
| | | <Fab |
| | | variant="extended" |
| | | color={showRoutes ? 'primary' : 'default'} |
| | | size="small" |
| | | onClick={() => { |
| | | showRoutes ? Tool.hideRoutes(curZone, setShowRoutes) : Tool.showRoutes(curZone, setShowRoutes) |
| | | }} |
| | | > |
| | | <AltRoute /> |
| | | </Fab> |
| | | )} |
| | | <Fab |
| | | variant="extended" |
| | | color="primary" |
| | | size="medium" |
| | | size="small" |
| | | onClick={() => { |
| | | player.adaptScreen(); |
| | | }} |
| | | > |
| | | <FitScreen /> |
| | | {translate('page.map.action.adapt')} |
| | | {/* {translate('page.map.action.adapt')} */} |
| | | </Fab> |
| | | </Box> |
| | | </Box> |
| | |
| | | open={insightVisible} |
| | | onCancel={() => { |
| | | setCurSprite(null); |
| | | setInsightVisible(false); |
| | | }} |
| | | sprite={curSprite} |
| | | width={570} |
| | |
| | | open={settingsVisible} |
| | | onCancel={() => { |
| | | setCurSprite(null); |
| | | setSettingsVisible(false); |
| | | }} |
| | | sprite={curSprite} |
| | | setSpriteSettings={setCurSprite} |
| | |
| | | open={batchSelectionVisible} |
| | | onCancel={() => { |
| | | setBatchSprites([]); |
| | | setBatchSelectionVisible(false); |
| | | }} |
| | | batchSprites={batchSprites} |
| | | mode={mode} |