Newer
Older
taehui / taehui-fe / src / forum / usePostAutoEssay.ts
@Taehui Taehui on 13 Mar 1 KB v1.0.0
import { useMutation, useQueryClient } from "@tanstack/react-query";
import { wwwAXIOS } from "src/Www";
import { getMillis } from "taehui-ts/date";
import { toast } from "react-toastify";
import { useTranslation } from "react-i18next";

import { useAvatarStore } from "src/Stores";

export default function usePostAutoEssay() {
  const { totem } = useAvatarStore();

  const { t } = useTranslation();

  const queryClient = useQueryClient();

  return useMutation({
    mutationFn: async ({
      forumID,
      title,
      text,
    }: {
      forumID: string;
      title: string;
      text: string;
    }) => {
      const {
        data: { autoEssayID },
      } = await wwwAXIOS.post(
        `/autoEssay/${forumID}`,
        {
          title,
          text,
        },
        {
          headers: {
            millis: getMillis(),
            totem,
          },
        },
      );

      return autoEssayID;
    },
    onSuccess: async (data) => {
      await queryClient.invalidateQueries({ queryKey: ["autoEssay"] });
      toast.success(t("postedAutoEssay"));
    },
  });
}