Newer
Older
taehui / taehui-fe / src / query / usePostGetTotem.ts
@Taehui Taehui on 17 Mar 1 KB 2024-03-17 오후 3:50
import { useTaehuiStore } from "@/state/Stores";
import { isClientFault, wwwAPI } from "@/utilities/wwwAPI";
import { useMutation } from "@tanstack/react-query";
import { useTranslations } from "next-intl";
import { toast } from "react-toastify";
import { getMillis } from "taehui-ts/date";

export default function usePostGetTotem() {
  const { setSession, saveTotem } = useTaehuiStore();

  const t = useTranslations();

  return useMutation({
    mutationFn: async ({
      avatarID,
      avatarCipher,
    }: {
      avatarID: string;
      avatarCipher: string;
    }) => {
      const { data } = await wwwAPI.post(
        "/avatar/getTotem",
        {
          avatarID,
          avatarCipher,
        },
        {
          headers: {
            millis: getMillis(),
          },
        },
      );
      return data;
    },
    onSuccess: (data) => {
      setSession(data);
      saveTotem();
      toast.success(t("loggedInText", { avatarName: data.avatarName }));
    },
    onError: (e) => {
      if (isClientFault(e)) {
        toast.warning(t("wrongAvatar"));
      }
    },
  });
}