From bbc8a16a1db4ce234968889a1c7fc271eda7b7ea Mon Sep 17 00:00:00 2001
From: verou <857149855@qq.com>
Date: 星期四, 20 三月 2025 15:14:40 +0800
Subject: [PATCH] feat:动态字段

---
 rsf-admin/src/page/settings/BaseSettings.jsx |   49 ++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 38 insertions(+), 11 deletions(-)

diff --git a/rsf-admin/src/page/settings/BaseSettings.jsx b/rsf-admin/src/page/settings/BaseSettings.jsx
index 51e48da..3a7ff59 100644
--- a/rsf-admin/src/page/settings/BaseSettings.jsx
+++ b/rsf-admin/src/page/settings/BaseSettings.jsx
@@ -17,6 +17,7 @@
     MenuItem,
     FormHelperText,
     CircularProgress,
+    LinearProgress,
 } from '@mui/material';
 import { updateUserInfo } from '@/api/auth';
 import avatar from '/avatar.jpg'
@@ -24,9 +25,23 @@
 const BaseSettings = (props) => {
     const translate = useTranslate();
     const notify = useNotify();
-    const { children, value, userInfo } = props;
+    const { children, userInfo } = props;
 
-    const { control, handleSubmit, watch, setValue, getValues, formState: { isDirty } } = useForm();
+    const {
+        control,
+        handleSubmit,
+        watch,
+        setValue,
+        getValues,
+        reset,
+        formState: {
+            errors,
+            isDirty,
+        },
+        setError,
+        clearErrors,
+    } = useForm();
+
     const [loading, setLoading] = useState(false);
 
     useEffect(() => {
@@ -56,6 +71,10 @@
                     username: data.username
                 }
                 localStorage.setItem("user", JSON.stringify(userToPersist));
+            } else if (code === 10005 || code === 10006) {
+                setError('email', {
+                    message: msg
+                })
             } else {
                 notify(msg, { type: 'error', messageArgs: { _: msg } });
             }
@@ -67,15 +86,23 @@
     }
 
     return (
-        <Box
-            hidden={value !== 0}
-            sx={{
-                p: 3,
-                flex: 1,
-                overflow: 'auto',
-            }}
-        >
-            {/* https://github.com/themeselection/materio-mui-nextjs-admin-template-free/blob/main/javascript-version/src/views/account-settings/account/AccountDetails.jsx */}
+        <Box sx={{
+            position: 'relative',
+            p: 3,
+            flex: 1,
+            overflow: 'auto',
+        }}>
+            {!userInfo && (
+                <LinearProgress
+                    sx={{
+                        height: "2px",
+                        position: 'absolute',
+                        top: 0,
+                        left: 0,
+                        right: 0,
+                    }}
+                />
+            )}
             <form onSubmit={handleSubmit(onSubmit)} noValidate>
                 <Stack
                     direction='column'

--
Gitblit v1.9.1