import React, {useEffect, useState} from 'react' import {Link, useNavigate} from 'react-router-dom' import {useDispatch, useSelector} from 'react-redux' import {withSwalInstance} from 'sweetalert2-react' import swal from 'sweetalert2' import {Loader} from '../Loader/Loader' import ErrorBoundary from "../../hoc/ErrorBoundary"; import {auth, selectAuth, setUserInfo} from '../../redux/outstaffingSlice' import {loading} from '../../redux/loaderSlice' import {setRole} from '../../redux/roleSlice' import {selectIsLoading} from '../../redux/loaderSlice' import {apiRequest} from "../../api/request"; import ellipse from '../../images/ellipse.png' import './authBox.scss' const {useRef} = require("react"); const SweetAlert = withSwalInstance(swal); export const AuthBox = ({title, altTitle, roleChangeLink}) => { const dispatch = useDispatch(); const ref = useRef(); const navigate = useNavigate(); const isAuth = useSelector(selectAuth); const isLoading = useSelector(selectIsLoading); const [error, setError] = useState(null); if (isAuth) { navigate('/') } useEffect(()=> { if (!localStorage.getItem('auth_token')) { dispatch(auth(false)) } }, []); const submitHandler = () => { let formData = new FormData(ref.current) if (!isLoading) { dispatch(loading(true)); apiRequest('/user/login', { method: 'POST', data: formData }).then((res) => { if (!res.access_token) { setError('Некорректные данные для входа'); dispatch(loading(false)) } else { localStorage.setItem('auth_token', res.access_token); localStorage.setItem('id', res.id); localStorage.setItem('cardId', res.card_id); localStorage.setItem( 'access_token_expired_at', res.access_token_expired_at ); dispatch(auth(true)); dispatch(setUserInfo(res)); dispatch(loading(false)); dispatch(setRole('ROLE_PARTNER')) } }) } }; return (

Войти в систему

{title}
{error && (
setError(null)} />
)}
) };