school-dashboard-exercise/src/api/helper/useGetQuery.ts
2024-07-27 14:57:06 +03:00

42 lines
1.0 KiB
TypeScript

import { useQuery } from "react-query";
import useAxios from "./useAxios";
import { useLocation } from "react-router-dom";
import { PaginationParams } from "../utils/PaginationParams";
import { filterParams } from "../utils/filterParams";
import useAuthState from "../../zustand/AuthState";
function useGetQuery(
KEY: string | string[],
url: string,
params: any = {},
options: any = {},
) {
const axios = useAxios();
const { show, pagination, ...remainingParams } = params;
const location = useLocation();
const { page, per_page } = PaginationParams(location);
const paramToSend = pagination
? { ...remainingParams, page: page, per_page: per_page }
: { ...remainingParams };
const filteredParams = filterParams(paramToSend);
return useQuery(
[KEY, filteredParams, show],
async () => {
const response = await axios.get(url + (show ? `/${show}` : ""), {
params: filteredParams,
});
return response?.data ?? [];
},
options,
);
}
export default useGetQuery;