Migrate to TanStack Query (React Query) and TanStack Router (#637)

This commit is contained in:
Alejandra
2024-03-07 19:16:23 +01:00
committed by GitHub
parent 7c2b617c09
commit 11c09b50b2
40 changed files with 4967 additions and 658 deletions

View File

@@ -0,0 +1,33 @@
import { useQuery } from 'react-query';
import { useNavigate } from '@tanstack/react-router';
import { Body_login_login_access_token as AccessToken, LoginService, UserOut, UsersService } from '../client';
const isLoggedIn = () => {
return localStorage.getItem('access_token') !== null;
};
const useAuth = () => {
const navigate = useNavigate();
const { data: user, isLoading } = useQuery<UserOut | null, Error>('currentUser', UsersService.readUserMe, {
enabled: isLoggedIn(),
});
const login = async (data: AccessToken) => {
const response = await LoginService.loginAccessToken({
formData: data,
});
localStorage.setItem('access_token', response.access_token);
navigate({ to: '/' });
};
const logout = () => {
localStorage.removeItem('access_token');
navigate({ to: '/login' });
};
return { login, logout, user, isLoading };
}
export { isLoggedIn };
export default useAuth;