2022-02-25 21:20:35 +01:00
|
|
|
import { ReactNode } from "react";
|
2022-02-18 20:22:56 +01:00
|
|
|
import { Link as LinkRouter } from "react-router-dom";
|
|
|
|
|
|
|
|
interface ILinkPropsBase {
|
2022-02-25 21:20:35 +01:00
|
|
|
children?: ReactNode;
|
2022-02-18 20:22:56 +01:00
|
|
|
className?: string;
|
|
|
|
onClick?: () => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface ILinkPropsExternal extends ILinkPropsBase {
|
|
|
|
url: string;
|
2022-02-25 21:20:35 +01:00
|
|
|
newTab?: boolean;
|
2022-02-18 20:22:56 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
interface ILinkPropsInternal extends ILinkPropsBase {
|
|
|
|
to: string;
|
|
|
|
}
|
|
|
|
|
2022-02-25 21:20:35 +01:00
|
|
|
type LinkProps =
|
2022-02-18 20:22:56 +01:00
|
|
|
| ILinkPropsExternal
|
|
|
|
| ILinkPropsInternal
|
|
|
|
| ILinkPropsBase;
|
|
|
|
|
|
|
|
export function Link(props: LinkProps) {
|
|
|
|
const isExternal = !!(props as ILinkPropsExternal).url;
|
|
|
|
const isInternal = !!(props as ILinkPropsInternal).to;
|
|
|
|
const content = (
|
2022-02-25 21:20:35 +01:00
|
|
|
<span className="text-bink-600 hover:text-bink-700 cursor-pointer font-bold">
|
|
|
|
{props.children}
|
2022-02-18 20:22:56 +01:00
|
|
|
</span>
|
|
|
|
);
|
|
|
|
|
|
|
|
if (isExternal)
|
2022-02-25 21:50:43 +01:00
|
|
|
return <a target={(props as ILinkPropsExternal).newTab ? "_blank" : undefined} rel="noopener" href={(props as ILinkPropsExternal).url}>{content}</a>;
|
2022-02-18 20:22:56 +01:00
|
|
|
else if (isInternal)
|
|
|
|
return (
|
|
|
|
<LinkRouter to={(props as ILinkPropsInternal).to}>{content}</LinkRouter>
|
|
|
|
);
|
|
|
|
return (
|
|
|
|
<span onClick={() => props.onClick && props.onClick()}>{content}</span>
|
|
|
|
);
|
|
|
|
}
|