mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-25 09:13:49 +03:00
29 lines
994 B
TypeScript
29 lines
994 B
TypeScript
import type { FC } from 'react';
|
|
import { Link } from 'react-router-dom';
|
|
import { useRoutesPrefix } from '../../utils/routesPrefix';
|
|
import type { ShortUrl } from '../data';
|
|
import { urlEncodeShortCode } from './index';
|
|
|
|
export type LinkSuffix = 'visits' | 'edit';
|
|
|
|
export interface ShortUrlDetailLinkProps {
|
|
shortUrl?: ShortUrl | null;
|
|
suffix: LinkSuffix;
|
|
asLink?: boolean;
|
|
}
|
|
|
|
const buildUrl = (routePrefix: string, { shortCode, domain }: ShortUrl, suffix: LinkSuffix) => {
|
|
const query = domain ? `?domain=${domain}` : '';
|
|
return `${routePrefix}/short-code/${urlEncodeShortCode(shortCode)}/${suffix}${query}`;
|
|
};
|
|
|
|
export const ShortUrlDetailLink: FC<ShortUrlDetailLinkProps & Record<string | number, any>> = (
|
|
{ shortUrl, suffix, asLink, children, ...rest },
|
|
) => {
|
|
const routePrefix = useRoutesPrefix();
|
|
if (!asLink || !shortUrl) {
|
|
return <span {...rest}>{children}</span>;
|
|
}
|
|
|
|
return <Link to={buildUrl(routePrefix, shortUrl, suffix)} {...rest}>{children}</Link>;
|
|
};
|