2025-01-21 20:33:05 +03:00
|
|
|
import { useMutation, useQueryClient } from '@tanstack/react-query';
|
|
|
|
|
2025-01-23 19:41:31 +03:00
|
|
|
import { DataCallback } from '@/backend/apiTransport';
|
2025-01-21 20:33:05 +03:00
|
|
|
import { usersApi } from '@/backend/users/api';
|
|
|
|
import { IUserProfile, IUserSignupData } from '@/models/user';
|
|
|
|
|
|
|
|
export const useSignup = () => {
|
2025-01-23 19:41:31 +03:00
|
|
|
const client = useQueryClient();
|
2025-01-21 20:33:05 +03:00
|
|
|
const mutation = useMutation({
|
|
|
|
mutationKey: ['signup'],
|
|
|
|
mutationFn: usersApi.signup,
|
2025-01-23 19:41:31 +03:00
|
|
|
onSuccess: async () => await client.invalidateQueries({ queryKey: [usersApi.baseKey] })
|
2025-01-21 20:33:05 +03:00
|
|
|
});
|
|
|
|
return {
|
2025-01-23 19:41:31 +03:00
|
|
|
signup: (
|
|
|
|
data: IUserSignupData, //
|
|
|
|
onSuccess?: DataCallback<IUserProfile>
|
|
|
|
) => mutation.mutate(data, { onSuccess: response => onSuccess?.(response.data as IUserProfile) }),
|
2025-01-21 20:33:05 +03:00
|
|
|
isPending: mutation.isPending,
|
|
|
|
error: mutation.error,
|
|
|
|
reset: mutation.reset
|
|
|
|
};
|
|
|
|
};
|