aboutsummaryrefslogtreecommitdiff
path: root/src/containers
diff options
context:
space:
mode:
Diffstat (limited to 'src/containers')
-rw-r--r--src/containers/Login/Login.tsx104
-rw-r--r--src/containers/Registration/Registration.tsx17
2 files changed, 72 insertions, 49 deletions
diff --git a/src/containers/Login/Login.tsx b/src/containers/Login/Login.tsx
index bec0db5..9814d01 100644
--- a/src/containers/Login/Login.tsx
+++ b/src/containers/Login/Login.tsx
@@ -1,14 +1,24 @@
-import React, { useState, useRef } from 'react';
+import React, { useState } from 'react';
import { useHistory } from 'react-router-dom';
+import { Formik, Form, Field } from 'formik';
import { makeStyles } from '@material-ui/core/styles';
import {
TextField,
Button,
FormControlLabel,
- Switch
+ Switch,
+ InputAdornment,
+ IconButton
} from '@material-ui/core';
+import { Visibility, VisibilityOff } from '@material-ui/icons';
import { useAuth } from '../../hooks/useAuth';
+interface Fields {
+ username: string;
+ password: string;
+ remember: boolean;
+}
+
const useStyles = makeStyles(theme => ({
root: {
'& > *': {
@@ -37,54 +47,76 @@ const useStyles = makeStyles(theme => ({
const Login: React.FC = () => {
const [error, setError] = useState<boolean>(false);
- const [remember, setRemember] = useState<boolean>(true);
+ const [showPassword, setShowPassword] = useState<boolean>(false);
const classes = useStyles();
- const nameRef = useRef<HTMLInputElement>();
- const passwordRef = useRef<HTMLInputElement>();
const { login } = useAuth();
const history = useHistory();
- const handleCheck = () => {
- setRemember(!remember);
- };
-
- const handleSubmit = async () => {
- const name = nameRef.current?.value?.toLowerCase();
- const password = passwordRef.current?.value;
- if (name && password) {
- login(name, password, remember).then(success => {
- if (success) history.push(`/profile/${name}`);
+ const handleSubmit = async ({ username, password, remember }: Fields) => {
+ console.log({ username, password, remember })
+ if (username && password) {
+ login(username, password, remember).then(success => {
+ if (success) history.push(`/profile/${username}`);
else setError(true);
});
- }
+ } else setError(true);
};
-
const handleRegistration = () => {
history.push('/registration');
};
+ const toggleShowPassword = () => {
+ setShowPassword(prevState => !prevState);
+ };
+
return (
<>
<div className={classes.formHeader}>Sign In</div>
- <form className={classes.root} noValidate autoComplete="off">
- <TextField
- inputRef={nameRef}
- error={error}
- label="Login"
- />
- <TextField
- inputRef={passwordRef}
- error={error}
- helperText={error && 'Invalid credentials'}
- label="Password"
- type="password"
- />
- <FormControlLabel
- control={<Switch color="primary" onClick={handleCheck} checked={remember} size="small" />}
- label="Remember me"
- />
- <Button variant="contained" onClick={handleSubmit}>submit</Button>
- </form>
+ <Formik
+ initialValues={{ username: '', password: '', remember: true }}
+ onSubmit={handleSubmit}
+ >
+ {({ values, touched, isSubmitting }) => (
+ <Form className={classes.root} autoComplete="off">
+ <Field
+ name="username"
+ label="Login"
+ value={values.username}
+ error={error}
+ as={TextField}
+ />
+ <Field
+ name="password"
+ label="Password"
+ as={TextField}
+ value={values.password}
+ error={error}
+ helperText={error && 'Invalid credentials'}
+ type={showPassword ? 'text' : 'password'}
+ InputProps={{
+ endAdornment: (
+ <InputAdornment position="end">
+ <IconButton
+ size="small"
+ aria-label="toggle password visibility"
+ onClick={toggleShowPassword}
+ >
+ {showPassword ? <Visibility /> : <VisibilityOff />}
+ </IconButton>
+ </InputAdornment>
+ )
+ }}
+ />
+ <Field
+ name="remember"
+ label="Remember me"
+ as={FormControlLabel}
+ control={<Switch color="primary" checked={values.remember} size="small" />}
+ />
+ <Button variant="contained" type="submit" disabled={isSubmitting}>submit</Button>
+ </Form>
+ )}
+ </Formik>
<div className={classes.formTransfer}>
<div>{'Don\'t have an account?'}</div>
<span
diff --git a/src/containers/Registration/Registration.tsx b/src/containers/Registration/Registration.tsx
index b5c56e6..fb2dc8c 100644
--- a/src/containers/Registration/Registration.tsx
+++ b/src/containers/Registration/Registration.tsx
@@ -21,6 +21,7 @@ interface Fields {
const validationSchema = Yup.object({
username: Yup.string()
+ .lowercase('Must be lowercase')
.required('This field is required'),
email: Yup.string()
.email('Invalid email address')
@@ -54,9 +55,6 @@ const useStyles = makeStyles(theme => ({
color: 'green',
cursor: 'pointer'
},
- textField: {
- height: theme.spacing(8)
- }
}));
const Registration: React.FC = () => {
@@ -75,7 +73,7 @@ const Registration: React.FC = () => {
.then(() => history.push(`/profile/${username}`));
}
- const handleClickShowPassword = () => {
+ const toggleShowPassword = () => {
setShowPassword(prevState => !prevState);
};
@@ -88,7 +86,7 @@ const Registration: React.FC = () => {
onSubmit={handleSubmit}
>
{({ values, errors, touched, isSubmitting }) => (
- <Form className={classes.root}>
+ <Form className={classes.root} autoComplete="off">
<Field
id="username"
name="username"
@@ -97,7 +95,6 @@ const Registration: React.FC = () => {
error={touched.username && !!errors.username}
helperText={touched.username && errors.username}
required
- className={classes.textField}
as={TextField}
/>
<Field
@@ -107,7 +104,6 @@ const Registration: React.FC = () => {
error={touched.email && !!errors.email}
helperText={touched.email && errors.email}
required
- className={classes.textField}
as={TextField}
/>
<Field
@@ -122,17 +118,12 @@ const Registration: React.FC = () => {
InputProps={{
endAdornment: (
<InputAdornment position="end">
- <IconButton
- size="small"
- aria-label="toggle password visibility"
- onClick={handleClickShowPassword}
- >
+ <IconButton size="small" onClick={toggleShowPassword} >
{showPassword ? <Visibility /> : <VisibilityOff />}
</IconButton>
</InputAdornment>
)
}}
- className={classes.textField}
/>
<Button variant="contained" type="submit" disabled={isSubmitting}>submit</Button>
</Form>