diff options
| author | eug-vs <eug-vs@keemail.me> | 2020-08-29 15:30:48 +0300 | 
|---|---|---|
| committer | eug-vs <eug-vs@keemail.me> | 2020-08-29 15:30:48 +0300 | 
| commit | bf7c63cd53dde93bffe24eb1426b8bfc2037646b (patch) | |
| tree | 601fcf42413527dc279d8b1a2bed307529654717 /src/containers | |
| parent | 868e380262dcef15d9645ceb912d18701ecb61fb (diff) | |
| download | which-ui-bf7c63cd53dde93bffe24eb1426b8bfc2037646b.tar.gz | |
feat: use Formik in Login form
Diffstat (limited to 'src/containers')
| -rw-r--r-- | src/containers/Login/Login.tsx | 104 | ||||
| -rw-r--r-- | src/containers/Registration/Registration.tsx | 17 | 
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> | 
