47 lines
884 B
TypeScript
47 lines
884 B
TypeScript
import React from "react";
|
|
|
|
import StyledText from "./Link.styled";
|
|
import { LinkProps } from "./Link.types";
|
|
import { LinkType, LinkTarget } from "./Link.enums";
|
|
|
|
export { LinkType, LinkTarget };
|
|
|
|
const Link = ({
|
|
isTextOverflow,
|
|
children,
|
|
noHover,
|
|
enableUserSelect,
|
|
...rest
|
|
}: LinkProps) => {
|
|
return (
|
|
<StyledText
|
|
tag="a"
|
|
isTextOverflow={isTextOverflow}
|
|
noHover={noHover}
|
|
truncate={isTextOverflow || false}
|
|
enableUserSelect={enableUserSelect}
|
|
data-testid="link"
|
|
{...rest}
|
|
>
|
|
{children}
|
|
</StyledText>
|
|
);
|
|
};
|
|
|
|
Link.defaultProps = {
|
|
className: "",
|
|
fontSize: "13px",
|
|
href: undefined,
|
|
isBold: false,
|
|
isHovered: false,
|
|
isSemitransparent: false,
|
|
isTextOverflow: false,
|
|
noHover: false,
|
|
rel: "noopener noreferrer",
|
|
tabIndex: -1,
|
|
type: LinkType.page,
|
|
enableUserSelect: false,
|
|
};
|
|
|
|
export { Link };
|