Newer
Older
taehui / qwilight-fe / src / hof / useGetTotalTotalHOF.ts
@Taehui Taehui on 12 Mar 1 KB 2024-03-12 오후 7:02
import { useQuery } from "@tanstack/react-query";
import { useLocation } from "react-router-dom";
import { sprintf } from "sprintf-js";
import { useTranslation } from "react-i18next";

import { wwwAXIOS } from "src/Www";
import { GetHOFAPI } from "src/wwwAPI";
import { useHOFStore } from "src/Stores";
import { formatText } from "src/Utility";

export default function useGetTotalTotalHOF() {
  const { tabPosition, totalTabPosition } = useHOFStore();

  const { t } = useTranslation();

  const { pathname } = useLocation();

  return useQuery<
    {
      avatarID: string;
      avatarName: string;
      text: string;
    }[]
  >({
    enabled:
      tabPosition === 0 &&
      totalTabPosition === 0 &&
      pathname.startsWith("/qwilight/hof"),
    queryKey: ["totalTotalHOF"],
    queryFn: async () => {
      const { data } = await wwwAXIOS.get<GetHOFAPI[]>("/hof/totalTotal");
      return data.map((hof) => ({
        ...hof,
        text: sprintf(t("textHandled"), formatText(hof.value)),
      }));
    },
    initialData: [],
  });
}