mirror of
https://github.com/umami-software/umami.git
synced 2026-02-04 04:37:11 +01:00
35 lines
1.1 KiB
TypeScript
35 lines
1.1 KiB
TypeScript
import type { UseQueryOptions } from '@tanstack/react-query';
|
|
import { useDateParameters } from '@/components/hooks/useDateParameters';
|
|
import { useApi } from '../useApi';
|
|
import { useFilterParameters } from '../useFilterParameters';
|
|
|
|
export interface WebsiteStatsData {
|
|
pageviews: number;
|
|
visitors: number;
|
|
visits: number;
|
|
bounces: number;
|
|
totaltime: number;
|
|
comparison: {
|
|
pageviews: number;
|
|
visitors: number;
|
|
visits: number;
|
|
bounces: number;
|
|
totaltime: number;
|
|
};
|
|
}
|
|
|
|
export function useWebsiteStatsQuery(
|
|
{ websiteId, compare }: { websiteId: string; compare?: string },
|
|
options?: UseQueryOptions<WebsiteStatsData, Error, WebsiteStatsData>,
|
|
) {
|
|
const { get, useQuery } = useApi();
|
|
const { startAt, endAt } = useDateParameters();
|
|
const filters = useFilterParameters();
|
|
|
|
return useQuery<WebsiteStatsData>({
|
|
queryKey: ['websites:stats', { websiteId, compare, startAt, endAt, ...filters }],
|
|
queryFn: () => get(`/websites/${websiteId}/stats`, { compare, startAt, endAt, ...filters }),
|
|
enabled: !!websiteId,
|
|
...options,
|
|
});
|
|
}
|