Files
fast_api_template/new-frontend/src/hooks/useAuth.tsx
T

38 lines
1.1 KiB
TypeScript
Raw Normal View History

import { useUserStore } from '../store/user-store';
import { Body_login_login_access_token as AccessToken, LoginService } from '../client';
import { useUsersStore } from '../store/users-store';
import { useItemsStore } from '../store/items-store';
import { useNavigate } from 'react-router-dom';
2024-02-29 09:47:13 -05:00
const isLoggedIn = () => {
return localStorage.getItem('access_token') !== null;
};
const useAuth = () => {
2024-02-29 09:47:13 -05:00
const { getUser, resetUser } = useUserStore();
const { resetUsers } = useUsersStore();
const { resetItems } = useItemsStore();
const navigate = useNavigate();
const login = async (data: AccessToken) => {
const response = await LoginService.loginAccessToken({
formData: data,
});
localStorage.setItem('access_token', response.access_token);
await getUser();
2024-02-29 09:47:13 -05:00
navigate('/');
};
const logout = () => {
localStorage.removeItem('access_token');
resetUser();
resetUsers();
resetItems();
navigate('/login');
};
2024-02-29 09:47:13 -05:00
return { login, logout };
}
2024-02-29 09:47:13 -05:00
export { isLoggedIn };
export default useAuth;