Quiz_dashboard/src/api/helper/useGetQuery.ts
2024-09-15 17:13:37 +03:00

43 lines
1.1 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 { useFilterStateState } from "../../zustand/Filter";
function useGetQuery(
KEY: string | string[],
url: string,
params: any = {},
options: any = {},
) {
const axios = useAxios();
const { show, pagination, ...remainingParams } = params;
const location = useLocation();
const { Filter ,setFilter } = useFilterStateState();
const page = Filter?.page ;
const per_page = Filter?.per_page ;
// const { per_page } = PaginationParams(location);
const paramToSend = pagination
? { page: page, per_page: per_page, ...remainingParams }
: { ...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;