All files / app/features/profile/hooks useUpdateUserProfile.ts

100% Statements 18/18
50% Branches 1/2
100% Functions 5/5
100% Lines 18/18

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 422x 2x 2x   2x 2x 2x               350x 350x 350x 350x             350x 4x   1x     4x     3x 3x 3x       350x    
import { useMutation, useQueryClient } from "@tanstack/react-query";
import { useAuthContext } from "features/auth/AuthProvider";
import { accountInfoQueryKey, userKey } from "features/queryKeys";
import { Empty } from "google-protobuf/google/protobuf/empty_pb";
import { useRouter } from "next/router";
import { routeToProfile } from "routes";
import { service, UpdateUserProfileData } from "service/index";
import { SetMutationError } from "utils/setMutationError";
 
interface UpdateUserProfileVariables {
  profileData: UpdateUserProfileData;
  setMutationError: SetMutationError;
}
 
export default function useUpdateUserProfile() {
  const queryClient = useQueryClient();
  const router = useRouter();
  const userId = useAuthContext().authState.userId;
  const {
    mutate: updateUserProfile,
    reset,
    isPending,
    isError,
    status,
  } = useMutation<Empty, Error, UpdateUserProfileVariables>({
    mutationFn: ({ profileData }) => service.user.updateProfile(profileData),
    onError: (error, { setMutationError }) => {
      setMutationError(error.message);
    },
    onMutate: ({ setMutationError }) => {
      setMutationError(null);
    },
    onSuccess: () => {
      queryClient.invalidateQueries({ queryKey: userKey(userId ?? 0) });
      queryClient.invalidateQueries({ queryKey: [accountInfoQueryKey] });
      router.push(routeToProfile("about"));
    },
  });
 
  return { reset, updateUserProfile, isPending, isError, status };
}