shlink-web-client/src/visits/DomainVisits.tsx

45 lines
1.8 KiB
TypeScript
Raw Normal View History

2022-04-24 19:36:25 +03:00
import { useParams } from 'react-router-dom';
2023-02-18 12:40:37 +03:00
import type { ShlinkVisitsParams } from '../api/types';
import type { ReportExporter } from '../common/services/ReportExporter';
2022-04-24 19:36:25 +03:00
import { boundToMercureHub } from '../mercure/helpers/boundToMercureHub';
import { Topics } from '../mercure/helpers/Topics';
import { useGoBack } from '../utils/helpers/hooks';
2023-02-18 13:11:01 +03:00
import type { DomainVisits as DomainVisitsState, LoadDomainVisits } from './reducers/domainVisits';
2023-02-18 12:40:37 +03:00
import type { NormalizedVisit } from './types';
2023-02-18 13:11:01 +03:00
import type { CommonVisitsProps } from './types/CommonVisitsProps';
import { toApiParams } from './types/helpers';
import { VisitsHeader } from './VisitsHeader';
2023-02-18 13:11:01 +03:00
import { VisitsStats } from './VisitsStats';
2022-04-24 19:36:25 +03:00
export interface DomainVisitsProps extends CommonVisitsProps {
getDomainVisits: (params: LoadDomainVisits) => void;
2022-04-24 19:36:25 +03:00
domainVisits: DomainVisitsState;
cancelGetDomainVisits: () => void;
}
export const DomainVisits = ({ exportVisits }: ReportExporter) => boundToMercureHub(({
getDomainVisits,
domainVisits,
cancelGetDomainVisits,
settings,
}: DomainVisitsProps) => {
const goBack = useGoBack();
const { domain = '' } = useParams();
const [authority, domainId = authority] = domain.split('_');
const loadVisits = (params: ShlinkVisitsParams, doIntervalFallback?: boolean) =>
getDomainVisits({ domain: domainId, query: toApiParams(params), doIntervalFallback });
2022-04-24 19:36:25 +03:00
const exportCsv = (visits: NormalizedVisit[]) => exportVisits(`domain_${authority}_visits.csv`, visits);
return (
<VisitsStats
getVisits={loadVisits}
cancelGetVisits={cancelGetDomainVisits}
visitsInfo={domainVisits}
settings={settings}
exportCsv={exportCsv}
>
<VisitsHeader goBack={goBack} visits={domainVisits.visits} title={`"${authority}" visits`} />
</VisitsStats>
);
}, () => [Topics.visits]);