mirror of
https://github.com/kremalicious/umami.git
synced 2025-02-14 21:10:34 +01:00
41 lines
1.0 KiB
TypeScript
41 lines
1.0 KiB
TypeScript
import { UseQueryOptions } from '@tanstack/react-query';
|
|
import { useApi } from '../useApi';
|
|
import { useFilterParams } from '../useFilterParams';
|
|
import { useSearchParams } from 'next/navigation';
|
|
|
|
export function useWebsiteMetrics(
|
|
websiteId: string,
|
|
queryParams: { type: string; limit?: number; search?: string; startAt?: number; endAt?: number },
|
|
options?: Omit<UseQueryOptions & { onDataLoad?: (data: any) => void }, 'queryKey' | 'queryFn'>,
|
|
) {
|
|
const { get, useQuery } = useApi();
|
|
const params = useFilterParams(websiteId);
|
|
const searchParams = useSearchParams();
|
|
|
|
return useQuery({
|
|
queryKey: [
|
|
'websites:metrics',
|
|
{
|
|
websiteId,
|
|
...params,
|
|
...queryParams,
|
|
},
|
|
],
|
|
queryFn: async () => {
|
|
const data = await get(`/websites/${websiteId}/metrics`, {
|
|
...params,
|
|
[searchParams.get('view')]: undefined,
|
|
...queryParams,
|
|
});
|
|
|
|
options?.onDataLoad?.(data);
|
|
|
|
return data;
|
|
},
|
|
enabled: !!websiteId,
|
|
...options,
|
|
});
|
|
}
|
|
|
|
export default useWebsiteMetrics;
|