diff options
author | lonkaars <l.leblansch@gmail.com> | 2021-03-21 12:20:28 +0100 |
---|---|---|
committer | lonkaars <l.leblansch@gmail.com> | 2021-03-21 12:20:28 +0100 |
commit | 7c296536cae54a645e075b1e00bcd3d34d494bb9 (patch) | |
tree | 084dfff28b8f310e326a59c6350338033fc6d39b /pages/login.tsx | |
parent | de522de148edd2e36ce4e7d911a343a3caf2c833 (diff) |
DOM -> toast :tada:
Diffstat (limited to 'pages/login.tsx')
-rw-r--r-- | pages/login.tsx | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/pages/login.tsx b/pages/login.tsx index 1cbacb1..e33883f 100644 --- a/pages/login.tsx +++ b/pages/login.tsx @@ -1,12 +1,17 @@ import axios from 'axios'; -import { FormEvent } from 'react'; +import { FormEvent, useContext } from 'react'; import { NavBar } from '../components/navbar'; import { CenteredPage } from '../components/page'; import { Vierkant, Input, Button } from '../components/ui'; +import { ToastContext, toastType } from '../components/toast'; -function submitLogin(event?: FormEvent<HTMLFormElement>) { - event.preventDefault(); +import ReportProblemOutlinedIcon from '@material-ui/icons/ReportProblemOutlined'; +import VpnKeyIcon from '@material-ui/icons/VpnKey'; +import ErrorOutlineIcon from '@material-ui/icons/ErrorOutline'; + +function submitLogin(event?: FormEvent<HTMLFormElement>, toast?: toastType) { + event?.preventDefault(); var formData = { email: (document.getElementById("email") as HTMLInputElement).value, @@ -15,7 +20,7 @@ function submitLogin(event?: FormEvent<HTMLFormElement>) { if ( !formData.email || !formData.password ) { - alert("Vul alsjeblieft alle velden in!"); + toast("Vul alsjeblieft alle velden in!", "error", <ReportProblemOutlinedIcon style={{ fontSize: 32 }}/>); return; } @@ -28,14 +33,16 @@ function submitLogin(event?: FormEvent<HTMLFormElement>) { .then(() => window.location.pathname = "/") .catch(error => { if (error.response.status === 401) { - alert("Verkeerde gebruikersnaam/wachtwoord combinatie!") + toast("Verkeerde gebruikersnaam of wachtwoord!", "error", <VpnKeyIcon style={{ fontSize: 32 }}/>); return; } - alert("Er is iets fout gegaan!"); + toast("Er is iets fout gegaan", "error", <ErrorOutlineIcon style={{ fontSize: 32 }}/>); }); } export default function LoginPage() { + var { toast } = useContext(ToastContext); + return ( <div> <NavBar/> @@ -48,7 +55,7 @@ export default function LoginPage() { textAlign: "center" }}> <Vierkant> - <form onSubmit={submitLogin}> + <form onSubmit={(e) => submitLogin(e, toast)}> <Input autofocus autocomplete="username" id="email" label="email of gebruikersnaam" style={{ marginBottom: 12 }}></Input> <Input autocomplete="current-password" id="password" label="wachtwoord" type="password"></Input> <div style={{ @@ -58,7 +65,7 @@ export default function LoginPage() { gridTemplateColumns: "1fr 1fr" }}> <Button href="/register" text="Registreren" style={{ backgroundColor: "var(--background-alt)"}}></Button> - <Button text="Inloggen" onclick={submitLogin}></Button> + <Button text="Inloggen" onclick={() => submitLogin(null, toast)}></Button> </div> <input type="submit" style={{ display: "none" }}/> </form> |