From 6a05567014939c6ff847a4665a8c3019f24b450d Mon Sep 17 00:00:00 2001
From: vincentlu <t1341870251@gmail.com>
Date: 星期一, 24 二月 2025 15:50:06 +0800
Subject: [PATCH] #

---
 zy-acs-flow/src/page/settings/Settings.jsx |  109 ++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 73 insertions(+), 36 deletions(-)

diff --git a/zy-acs-flow/src/page/settings/Settings.jsx b/zy-acs-flow/src/page/settings/Settings.jsx
index c8a2594..7833c47 100644
--- a/zy-acs-flow/src/page/settings/Settings.jsx
+++ b/zy-acs-flow/src/page/settings/Settings.jsx
@@ -1,4 +1,5 @@
 import React, { useState, useRef, useEffect, useMemo } from "react";
+import { useNavigate } from 'react-router-dom';
 import {
     Edit,
     SimpleForm,
@@ -15,43 +16,28 @@
     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 * as Common from '@/utils/common';
 import { } from '@/config/setting';
 
-function TabPanel(props) {
-    const { children, value, index, ...other } = props;
-
-    return (
-        <div
-            role="tabpanel"
-            hidden={value !== index}
-            id={`vertical-tabpanel-${index}`}
-            aria-labelledby={`vertical-tab-${index}`}
-            {...other}
-        >
-            {value === index && (
-                <Box sx={{ p: 3 }}>
-                    <Typography>{children}</Typography>
-                </Box>
-            )}
-        </div>
-    );
-}
-
-function a11yProps(index) {
-    return {
-        id: `vertical-tab-${index}`,
-        'aria-controls': `vertical-tabpanel-${index}`,
-    };
-}
-
 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 (
         <>
@@ -80,18 +66,25 @@
                             sx={{
                                 borderRight: 1,
                                 borderColor: 'divider',
-                                width: 150
+                                width: 150,
                             }}
                         >
-                            <Tab label={translate('settings.base')} {...a11yProps(0)} />
-                            <Tab label={translate('settings.security')} {...a11yProps(1)} />
+                            <Tab
+                                label={translate('settings.base')}
+                                id='vertical-tab-0'
+                                aria-controls='vertical-tabpanel-0'
+                            />
+                            <Tab label={translate('settings.security')}
+                                id='vertical-tab-1'
+                                aria-controls='vertical-tabpanel-1'
+                            />
                         </Tabs>
-                        <TabPanel value={value} index={0}>
-                            {translate('settings.base')}
-                        </TabPanel>
-                        <TabPanel value={value} index={1}>
-                            {translate('settings.security')}
-                        </TabPanel>
+                        <BaseSettings
+                            value={value}
+                        />
+                        <SecuritySettings
+                            value={value}
+                        />
                     </Box>
                 </CardContent>
             </Card>
@@ -99,4 +92,48 @@
     )
 }
 
+const BaseSettings = (props) => {
+    const { children, value, ...other } = props;
+
+    return (
+        <Box
+            hidden={value !== 0}
+            sx={{ p: 3 }}
+            {...other}
+        >
+            <Grid container spacing={6}>
+                <Grid item xs={12}>
+                    {/* https://github.com/themeselection/materio-mui-nextjs-admin-template-free/blob/main/javascript-version/src/views/account-settings/account/AccountDetails.jsx */}
+                    <Card>
+                        <CardContent className='mbe-5'>
+                            <Typography>
+                                Base Settings
+                            </Typography>
+                        </CardContent>
+                    </Card>
+
+                </Grid>
+            </Grid>
+        </Box>
+
+    )
+}
+
+const SecuritySettings = (props) => {
+    const { children, value, ...other } = props;
+
+    return (
+        <Box
+            hidden={value !== 1}
+            sx={{ p: 3 }}
+            {...other}
+        >
+            <Typography>
+                Security Settings
+            </Typography>
+        </Box>
+
+    )
+}
+
 export default Settings;
\ No newline at end of file

--
Gitblit v1.9.1