Newer
Older
taehui / qwilight-fe / src / app / [language] / avatar / query / useGetAvatarLasts.ts
@Taehui Taehui on 17 Mar 837 bytes 2024-03-17 오후 2:12
import { GetAvatarLastsAPI } from "@/type/wwwAPI";
import { toDate } from "@/utilities/Utility";

import { wwwAPI } from "@/utilities/wwwAPI";
import { useQuery } from "@tanstack/react-query";
import { useIsPath } from "taehui-ts/fe-utilities";

export default function useGetAvatarLasts(
  inputMode: "6K" | "5K" | "7K" | "9K" | "10K" | "14K" | "24K" | "48K",
  avatarID?: string,
) {
  const isPath = useIsPath();

  return useQuery({
    enabled: !!avatarID && isPath("/avatar"),
    queryKey: ["avatarLasts", inputMode, avatarID],
    queryFn: async () => {
      const { data } = await wwwAPI.get<GetAvatarLastsAPI>(
        `/avatar/lasts/${inputMode}`,
        {
          params: { avatarID },
        },
      );
      return data.map((data) => ({ ...data, fittedText: toDate(data.date) }));
    },
    initialData: [],
  });
}