2023-12-03 12:07:03 +01:00
|
|
|
import { UseQueryOptions } from '@tanstack/react-query';
|
2023-12-02 05:27:59 +01:00
|
|
|
import { useState, Dispatch, SetStateAction } from 'react';
|
2023-09-29 14:29:22 +02:00
|
|
|
import { useApi } from 'components/hooks/useApi';
|
2023-12-03 12:07:03 +01:00
|
|
|
import { FilterResult, SearchFilter } from 'lib/types';
|
2023-09-29 14:29:22 +02:00
|
|
|
|
2023-12-02 05:27:59 +01:00
|
|
|
export interface FilterQueryResult<T> {
|
2023-12-03 12:07:03 +01:00
|
|
|
result: FilterResult<T>;
|
2023-12-02 05:27:59 +01:00
|
|
|
query: any;
|
|
|
|
params: SearchFilter;
|
|
|
|
setParams: Dispatch<SetStateAction<T | SearchFilter>>;
|
|
|
|
}
|
|
|
|
|
2023-12-03 12:07:03 +01:00
|
|
|
export function useFilterQuery<T>({
|
|
|
|
queryKey,
|
|
|
|
queryFn,
|
|
|
|
...options
|
|
|
|
}: UseQueryOptions): FilterQueryResult<T> {
|
2023-12-02 05:27:59 +01:00
|
|
|
const [params, setParams] = useState<T | SearchFilter>({
|
2023-09-29 14:29:22 +02:00
|
|
|
query: '',
|
|
|
|
page: 1,
|
|
|
|
});
|
|
|
|
const { useQuery } = useApi();
|
2023-12-03 12:07:03 +01:00
|
|
|
const { data, ...query } = useQuery({
|
|
|
|
queryKey: [...queryKey, params],
|
|
|
|
queryFn: (data: any) => queryFn({ ...data, ...params }),
|
|
|
|
...options,
|
|
|
|
});
|
2023-09-29 14:29:22 +02:00
|
|
|
|
2023-10-04 10:46:00 +02:00
|
|
|
return {
|
2023-12-03 12:07:03 +01:00
|
|
|
result: data as FilterResult<any>,
|
2023-12-02 05:27:59 +01:00
|
|
|
query,
|
2023-10-04 10:46:00 +02:00
|
|
|
params,
|
|
|
|
setParams,
|
|
|
|
};
|
2023-09-29 14:29:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export default useFilterQuery;
|