|  |  | 
 |  |  |             } | 
 |  |  |           </> | 
 |  |  |         )} | 
 |  |  |         {/* CustomRoutes don't trigger checkAuth */} | 
 |  |  |         <CustomRoutes> | 
 |  |  |           <Route path="/dashboard" element={<Dashboard />} /> | 
 |  |  |           <Route path="/settings" element={<Settings />} /> | 
 
 |  |  | 
 |  |  |     if (user && accessToken) { | 
 |  |  |       const userToPersist = { | 
 |  |  |         avatar: avatar, | 
 |  |  |         // avatar: "", | 
 |  |  |         fullName: user.nickname, | 
 |  |  |         id: user.id, | 
 |  |  |         username: user.username | 
 |  |  | 
 |  |  |     if (!token) { | 
 |  |  |       localStorage.removeItem("user"); | 
 |  |  |       if (window.location.pathname !== "/login") { | 
 |  |  |         window.location.href = "/login"; | 
 |  |  |       } | 
 |  |  |       return Promise.reject(); | 
 |  |  |     } | 
 |  |  | 
 |  |  |       return Promise.resolve(data); | 
 |  |  |     } else if (code === 401) { | 
 |  |  |       localStorage.removeItem("user"); | 
 |  |  |       if (window.location.pathname !== "/login") { | 
 |  |  |         window.location.href = "/login"; | 
 |  |  |         return Promise.reject(); | 
 |  |  |       } | 
 |  |  |       return Promise.reject(); | 
 |  |  |     } else { | 
 |  |  |       return Promise.reject(msg); | 
 |  |  |     } | 
 
 |  |  | 
 |  |  |     let sprite; | 
 |  |  |     switch (deviceType) { | 
 |  |  |         case DEVICE_TYPE.SHELF: | 
 |  |  |             sprite = new PIXI.Sprite(PIXI.Texture.from(shelf, { resourceOptions: { scale: 5 } })); | 
 |  |  |             sprite.width = 50; | 
 |  |  |             sprite.height = 50; | 
 |  |  |             sprite = new PIXI.Sprite(PIXI.Texture.from(shelf, { resourceOptions: { scale: 1 } })); | 
 |  |  |             // sprite.width = 50; | 
 |  |  |             // sprite.height = 50; | 
 |  |  |             sprite.zIndex = DEVICE_Z_INDEX.SHELF; | 
 |  |  |             break; | 
 |  |  |         case DEVICE_TYPE.CHARGE: | 
 |  |  |             sprite = new PIXI.Sprite(PIXI.Texture.from(charge, { resourceOptions: { scale: 1 } })); | 
 |  |  |             sprite.width = 60; | 
 |  |  |             sprite.height = 60; | 
 |  |  |             // sprite.width = 60; | 
 |  |  |             // sprite.height = 60; | 
 |  |  |             sprite.zIndex = DEVICE_Z_INDEX.CHARGE; | 
 |  |  |             break; | 
 |  |  |         case DEVICE_TYPE.DIRECTION: | 
 |  |  |             sprite = new PIXI.Sprite(PIXI.Texture.from(direction, { resourceOptions: { scale: 5 } })); | 
 |  |  |             sprite = new PIXI.Sprite(PIXI.Texture.from(direction, { resourceOptions: { scale: 1 } })); | 
 |  |  |             sprite.width = 112; | 
 |  |  |             sprite.height = 63; | 
 |  |  |             sprite.zIndex = DEVICE_Z_INDEX.DIRECTION; | 
 
 |  |  | 
 |  |  | import React, { useState, useRef, useEffect, useMemo } from "react"; | 
 |  |  | import { useNavigate } from 'react-router-dom'; | 
 |  |  | import { useAuthProvider } from 'react-admin'; | 
 |  |  | import MapPage from "../../map/MapPage"; | 
 |  |  | import Player from "../../map/player"; | 
 |  |  |  | 
 |  |  |  | 
 |  |  |  | 
 |  |  | const Dashboard = () => { | 
 |  |  |     const mapRef = React.useRef(); | 
 |  |  |     const authProvider = useAuthProvider(); | 
 |  |  |     const navigate = useNavigate(); | 
 |  |  |  | 
 |  |  |     useEffect(() => { | 
 |  |  |         // let player = new Player(mapRef.current) | 
 |  |  |     }, []) | 
 |  |  |         authProvider.checkAuth().catch(() => { | 
 |  |  |             navigate('/login'); | 
 |  |  |         }); | 
 |  |  |     }, [authProvider, navigate]); | 
 |  |  |  | 
 |  |  |     return ( | 
 |  |  |         <> | 
 |  |  |             <MapPage /> | 
 |  |  |             {/* <div ref={mapRef} ></div> */} | 
 |  |  |         </> | 
 |  |  |     ) | 
 |  |  | } | 
 
 |  |  | 
 |  |  | import React, { useState, useRef, useEffect, useMemo } from "react"; | 
 |  |  | import { useNavigate } from 'react-router-dom'; | 
 |  |  | import { | 
 |  |  |     Edit, | 
 |  |  |     SimpleForm, | 
 |  |  | 
 |  |  |     required, | 
 |  |  |     useRecordContext, | 
 |  |  |     useTheme, | 
 |  |  |     useAuthProvider, | 
 |  |  | } from 'react-admin'; | 
 |  |  | import { useWatch, useFormContext } from "react-hook-form"; | 
 |  |  | import { Stack, Grid, Box, Typography, Card, CardContent, Tabs, Tab } from '@mui/material'; | 
 |  |  | 
 |  |  | import { } from '@/config/setting'; | 
 |  |  |  | 
 |  |  | const Settings = () => { | 
 |  |  |     const authProvider = useAuthProvider(); | 
 |  |  |     const navigate = useNavigate(); | 
 |  |  |     const translate = useTranslate(); | 
 |  |  |     const theme = useTheme(); | 
 |  |  |     const [value, setValue] = React.useState(0); | 
 |  |  |  | 
 |  |  |     useEffect(() => { | 
 |  |  |         authProvider.checkAuth().catch(() => { | 
 |  |  |             navigate('/login'); | 
 |  |  |         }); | 
 |  |  |     }, [authProvider, navigate]); | 
 |  |  |  | 
 |  |  |     useEffect(() => { | 
 |  |  |     }, [value]); | 
 |  |  |  | 
 |  |  |     return ( |