From a19b70e1af79238c298ef8af6d0265bf6a22c92d Mon Sep 17 00:00:00 2001 From: vincentlu <t1341870251@gmail.com> Date: 星期五, 07 二月 2025 16:15:50 +0800 Subject: [PATCH] # --- rsf-admin/src/page/login/Login.jsx | 26 +++++++++++++++++++++++--- 1 files changed, 23 insertions(+), 3 deletions(-) diff --git a/rsf-admin/src/page/login/Login.jsx b/rsf-admin/src/page/login/Login.jsx index aa5dcf4..c4e4825 100644 --- a/rsf-admin/src/page/login/Login.jsx +++ b/rsf-admin/src/page/login/Login.jsx @@ -7,7 +7,9 @@ Button, TextField, Stack, - Autocomplete + Autocomplete, + InputAdornment, + IconButton, } from '@mui/material'; import { useTranslate, @@ -16,6 +18,8 @@ } from 'react-admin'; import { useForm, Controller } from 'react-hook-form'; import ProviderChoices from "./ProviderChoices"; +import Visibility from '@mui/icons-material/Visibility'; +import VisibilityOff from '@mui/icons-material/VisibilityOff'; const Login = (props) => { const translate = useTranslate(); @@ -27,6 +31,7 @@ const { control, watch, handleSubmit, setValue } = useForm(); const [loading, setLoading] = useState(false); + const [showPassword, setShowPassword] = useState(false); const username = watch('username'); const password = watch('password'); @@ -122,6 +127,7 @@ variant="standard" disabled={loading} autoFocus + autoComplete="off" /> )} /> @@ -135,10 +141,24 @@ <TextField {...field} label={translate('ra.auth.password')} - type="password" + type={showPassword ? 'text' : 'password'} variant="standard" disabled={loading} - + autoComplete="off" + InputProps={{ + endAdornment: ( + <InputAdornment position="end"> + <IconButton + aria-label="toggle password visibility" + onClick={() => setShowPassword((show) => !show)} + onMouseDown={(event) => { event.preventDefault() }} + edge="end" + > + {showPassword ? <VisibilityOff /> : <Visibility />} + </IconButton> + </InputAdornment> + ), + }} /> )} /> -- Gitblit v1.9.1