Files
mtdb_movie/common/resources/client/auth/requests/use-login.ts
maher 703f50a09d
Some checks failed
Build / run (push) Has been cancelled
first commit
2025-10-29 11:42:25 +01:00

58 lines
1.6 KiB
TypeScript
Executable File

import {useMutation} from '@tanstack/react-query';
import {UseFormReturn} from 'react-hook-form';
import {BackendResponse} from '../../http/backend-response/backend-response';
import {onFormQueryError} from '../../errors/on-form-query-error';
import {useNavigate} from '../../utils/hooks/use-navigate';
import {apiClient} from '../../http/query-client';
import {useAuth} from '../use-auth';
import {useBootstrapData} from '../../core/bootstrap-data/bootstrap-data-context';
import {useCallback} from 'react';
interface LoginResponse extends BackendResponse {
bootstrapData: string;
two_factor: false;
}
interface TwoFactorResponse {
two_factor: true;
}
type Response = LoginResponse | TwoFactorResponse;
export interface LoginPayload {
email: string;
password: string;
remember: boolean;
token_name: string;
}
export function useLogin(form: UseFormReturn<LoginPayload>) {
const handleSuccess = useHandleLoginSuccess();
return useMutation({
mutationFn: login,
onSuccess: response => {
if (!response.two_factor) {
handleSuccess(response);
}
},
onError: r => onFormQueryError(r, form),
});
}
export function useHandleLoginSuccess() {
const navigate = useNavigate();
const {getRedirectUri} = useAuth();
const {setBootstrapData} = useBootstrapData();
return useCallback(
(response: LoginResponse) => {
setBootstrapData(response.bootstrapData);
navigate(getRedirectUri(), {replace: true});
},
[navigate, setBootstrapData, getRedirectUri],
);
}
function login(payload: LoginPayload): Promise<Response> {
return apiClient.post('auth/login', payload).then(response => response.data);
}