2024-02-03 06:20:13 +00:00
|
|
|
'use client';
|
2024-01-29 09:32:05 +00:00
|
|
|
import useStore, { setUser } from 'store/app';
|
2024-01-29 02:33:40 +00:00
|
|
|
import useApi from './useApi';
|
2024-02-03 01:49:17 +00:00
|
|
|
import { UseQueryResult } from '@tanstack/react-query';
|
2024-01-29 09:32:05 +00:00
|
|
|
|
|
|
|
|
const selector = (state: { user: any }) => state.user;
|
2023-11-29 22:03:10 +00:00
|
|
|
|
2024-02-03 01:49:17 +00:00
|
|
|
export function useLogin(): {
|
|
|
|
|
user: any;
|
|
|
|
|
setUser: (data: any) => void;
|
|
|
|
|
} & UseQueryResult {
|
2023-11-29 22:03:10 +00:00
|
|
|
const { get, useQuery } = useApi();
|
2024-01-29 09:32:05 +00:00
|
|
|
const user = useStore(selector);
|
2023-11-29 22:03:10 +00:00
|
|
|
|
|
|
|
|
const query = useQuery({
|
|
|
|
|
queryKey: ['login'],
|
|
|
|
|
queryFn: async () => {
|
|
|
|
|
const data = await get('/auth/verify');
|
|
|
|
|
|
|
|
|
|
setUser(data);
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
|
},
|
2024-01-29 09:32:05 +00:00
|
|
|
enabled: !user,
|
2023-11-29 22:03:10 +00:00
|
|
|
});
|
|
|
|
|
|
2024-02-03 01:49:17 +00:00
|
|
|
return { user, setUser, ...query };
|
2023-11-29 22:03:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default useLogin;
|