2020-05-10 19:37:00 +02:00
|
|
|
import { ExternalLink } from 'react-external-link';
|
2023-02-18 11:11:01 +01:00
|
|
|
import { UncontrolledTooltip } from 'reactstrap';
|
2023-02-18 10:40:37 +01:00
|
|
|
import type { ShortUrlDetail } from '../short-urls/reducers/shortUrlDetail';
|
2023-07-31 18:10:34 +02:00
|
|
|
import { Time } from '../utils/dates/Time';
|
2023-02-18 10:40:37 +01:00
|
|
|
import type { ShortUrlVisits } from './reducers/shortUrlVisits';
|
2022-05-28 11:16:59 +02:00
|
|
|
import { VisitsHeader } from './VisitsHeader';
|
2020-05-10 19:37:00 +02:00
|
|
|
import './ShortUrlVisitsHeader.scss';
|
|
|
|
|
2020-09-04 19:33:16 +02:00
|
|
|
interface ShortUrlVisitsHeaderProps {
|
|
|
|
shortUrlDetail: ShortUrlDetail;
|
|
|
|
shortUrlVisits: ShortUrlVisits;
|
|
|
|
goBack: () => void;
|
|
|
|
}
|
2020-05-10 19:37:00 +02:00
|
|
|
|
2022-05-28 11:16:59 +02:00
|
|
|
export const ShortUrlVisitsHeader = ({ shortUrlDetail, shortUrlVisits, goBack }: ShortUrlVisitsHeaderProps) => {
|
2020-05-10 19:37:00 +02:00
|
|
|
const { shortUrl, loading } = shortUrlDetail;
|
|
|
|
const { visits } = shortUrlVisits;
|
2020-09-04 19:33:16 +02:00
|
|
|
const shortLink = shortUrl?.shortUrl ?? '';
|
|
|
|
const longLink = shortUrl?.longUrl ?? '';
|
2021-03-05 15:44:15 +01:00
|
|
|
const title = shortUrl?.title;
|
2020-05-10 19:37:00 +02:00
|
|
|
|
2022-03-26 12:17:42 +01:00
|
|
|
const renderDate = () => (!shortUrl ? <small>Loading...</small> : (
|
2020-05-10 19:37:00 +02:00
|
|
|
<span>
|
|
|
|
<b id="created" className="short-url-visits-header__created-at">
|
2021-06-24 20:13:06 +02:00
|
|
|
<Time date={shortUrl.dateCreated} relative />
|
2020-05-10 19:37:00 +02:00
|
|
|
</b>
|
|
|
|
<UncontrolledTooltip placement="bottom" target="created">
|
2021-06-24 20:13:06 +02:00
|
|
|
<Time date={shortUrl.dateCreated} />
|
2020-05-10 19:37:00 +02:00
|
|
|
</UncontrolledTooltip>
|
|
|
|
</span>
|
2022-03-26 12:17:42 +01:00
|
|
|
));
|
2021-06-24 20:13:06 +02:00
|
|
|
const visitsStatsTitle = <>Visits for <ExternalLink href={shortLink} /></>;
|
2020-05-10 19:37:00 +02:00
|
|
|
|
|
|
|
return (
|
|
|
|
<VisitsHeader title={visitsStatsTitle} goBack={goBack} visits={visits} shortUrl={shortUrl}>
|
|
|
|
<hr />
|
|
|
|
<div>Created: {renderDate()}</div>
|
2022-06-11 08:53:48 +02:00
|
|
|
<div className="long-url-container">
|
2021-03-05 15:44:15 +01:00
|
|
|
{`${title ? 'Title' : 'Long URL'}: `}
|
2020-05-10 19:37:00 +02:00
|
|
|
{loading && <small>Loading...</small>}
|
2021-03-05 15:44:15 +01:00
|
|
|
{!loading && <ExternalLink href={longLink}>{title ?? longLink}</ExternalLink>}
|
2020-05-10 19:37:00 +02:00
|
|
|
</div>
|
|
|
|
</VisitsHeader>
|
|
|
|
);
|
2020-05-10 19:49:58 +02:00
|
|
|
};
|