diff options
author | zirops <zirops@gmail.com> | 2021-01-26 10:57:25 +0100 |
---|---|---|
committer | zirops <zirops@gmail.com> | 2021-01-26 10:57:25 +0100 |
commit | 12184a5ef570593ab492c1499f2d7a23e3be2569 (patch) | |
tree | bc2f7ed0d098bbaef247d0e5ab7f5a57f08ab3be /modern/src/LoginPage.js | |
parent | 2201f5417f41204453e3cd53da003296925282aa (diff) | |
download | trackermap-web-12184a5ef570593ab492c1499f2d7a23e3be2569.tar.gz trackermap-web-12184a5ef570593ab492c1499f2d7a23e3be2569.tar.bz2 trackermap-web-12184a5ef570593ab492c1499f2d7a23e3be2569.zip |
user self registration
Diffstat (limited to 'modern/src/LoginPage.js')
-rw-r--r-- | modern/src/LoginPage.js | 29 |
1 files changed, 27 insertions, 2 deletions
diff --git a/modern/src/LoginPage.js b/modern/src/LoginPage.js index 2636c807..cbe50fe4 100644 --- a/modern/src/LoginPage.js +++ b/modern/src/LoginPage.js @@ -7,6 +7,9 @@ import FormControl from '@material-ui/core/FormControl'; import Paper from '@material-ui/core/Paper'; import { makeStyles } from '@material-ui/core'; import TextField from '@material-ui/core/TextField'; +import RegisterDialog from './RegisterDialog'; +import Snackbar from '@material-ui/core/Snackbar'; +import { useSelector } from 'react-redux'; import t from './common/localization'; @@ -47,10 +50,19 @@ const LoginPage = () => { const [failed, setFailed] = useState(false); const [email, setEmail] = useState(''); const [password, setPassword] = useState(''); + const [registerDialogShown, setRegisterDialogShown] = useState(false); + const [snackbarOpen, setSnackbarOpen] = useState(false); const classes = useStyles(); const history = useHistory(); + const server = useSelector(state => state.session.server); + + let registrationPref = false; + if (server) { + registrationPref = server['registration'] + } + const handleEmailChange = (event) => { setEmail(event.target.value); } @@ -60,7 +72,14 @@ const LoginPage = () => { } const handleRegister = () => { - // TODO: Implement registration + setRegisterDialogShown(true); + } + + const handleRegisterResult = (resultOk) => { + setRegisterDialogShown(false); + if (resultOk) { + setSnackbarOpen(true); + } } const handleLogin = async (event) => { @@ -109,7 +128,7 @@ const LoginPage = () => { <FormControl fullWidth margin='normal'> <div className={classes.buttons}> - <Button type='button' variant='contained' disabled onClick={handleRegister}> + <Button type='button' variant='contained' onClick={handleRegister} disabled={!registrationPref}> {t('loginRegister')} </Button> <Button type='submit' variant='contained' color='primary' disabled={!email || !password}> @@ -118,6 +137,12 @@ const LoginPage = () => { </div> </FormControl> </form> + {registerDialogShown && <RegisterDialog open={registerDialogShown} onResult={handleRegisterResult} />} + <Snackbar + anchorOrigin={{ vertical: 'bottom', horizontal: 'center', }} + open={snackbarOpen} autoHideDuration={6000} + onClose={()=>{setSnackbarOpen(false);}} message={t('loginCreated')} + /> </Paper> </main> ); |