| | |
| | | } |
| | | </> |
| | | )} |
| | | {/* 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 ( |