2020-09-05 09:49:18 +03:00
|
|
|
import React, { useEffect } from 'react';
|
2020-09-04 20:05:41 +03:00
|
|
|
import qs from 'qs';
|
|
|
|
import { RouteComponentProps } from 'react-router';
|
|
|
|
import { MercureBoundProps, useMercureTopicBinding } from '../mercure/helpers';
|
|
|
|
import { ShlinkVisitsParams } from '../utils/services/types';
|
|
|
|
import { ShortUrlVisits as ShortUrlVisitsState } from './reducers/shortUrlVisits';
|
|
|
|
import ShortUrlVisitsHeader from './ShortUrlVisitsHeader';
|
|
|
|
import { ShortUrlDetail } from './reducers/shortUrlDetail';
|
2020-09-05 09:49:18 +03:00
|
|
|
import VisitsStats from './VisitsStats';
|
2020-09-04 20:05:41 +03:00
|
|
|
|
2020-09-04 20:33:16 +03:00
|
|
|
export interface ShortUrlVisitsProps extends RouteComponentProps<{ shortCode: string }>, MercureBoundProps {
|
2020-09-04 20:05:41 +03:00
|
|
|
getShortUrlVisits: (shortCode: string, query?: ShlinkVisitsParams) => void;
|
|
|
|
shortUrlVisits: ShortUrlVisitsState;
|
|
|
|
getShortUrlDetail: Function;
|
|
|
|
shortUrlDetail: ShortUrlDetail;
|
2020-09-05 09:49:18 +03:00
|
|
|
cancelGetShortUrlVisits: () => void;
|
2020-09-04 20:05:41 +03:00
|
|
|
}
|
|
|
|
|
2020-09-05 09:49:18 +03:00
|
|
|
const ShortUrlVisits = ({
|
2020-09-04 20:05:41 +03:00
|
|
|
history: { goBack },
|
|
|
|
match,
|
|
|
|
location: { search },
|
|
|
|
shortUrlVisits,
|
|
|
|
shortUrlDetail,
|
|
|
|
getShortUrlVisits,
|
|
|
|
getShortUrlDetail,
|
|
|
|
cancelGetShortUrlVisits,
|
|
|
|
createNewVisit,
|
|
|
|
loadMercureInfo,
|
|
|
|
mercureInfo,
|
|
|
|
}: ShortUrlVisitsProps) => {
|
|
|
|
const { params } = match;
|
|
|
|
const { shortCode } = params;
|
|
|
|
const { domain } = qs.parse(search, { ignoreQueryPrefix: true }) as { domain?: string };
|
|
|
|
|
2020-09-05 09:49:18 +03:00
|
|
|
const loadVisits = (params: Partial<ShlinkVisitsParams>) => getShortUrlVisits(shortCode, { ...params, domain });
|
2020-09-04 20:05:41 +03:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
getShortUrlDetail(shortCode, domain);
|
|
|
|
}, []);
|
|
|
|
useMercureTopicBinding(mercureInfo, `https://shlink.io/new-visit/${shortCode}`, createNewVisit, loadMercureInfo);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<VisitsStats getVisits={loadVisits} cancelGetVisits={cancelGetShortUrlVisits} visitsInfo={shortUrlVisits}>
|
|
|
|
<ShortUrlVisitsHeader shortUrlDetail={shortUrlDetail} shortUrlVisits={shortUrlVisits} goBack={goBack} />
|
|
|
|
</VisitsStats>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default ShortUrlVisits;
|