keycloak-scim/src/components/external-link/FormattedLink.tsx

36 lines
865 B
TypeScript
Raw Normal View History

import React, { AnchorHTMLAttributes } from "react";
import { ExternalLinkAltIcon } from "@patternfly/react-icons";
import { IFormatter, IFormatterValueType } from "@patternfly/react-table";
2020-09-01 08:25:24 +00:00
export type FormattedLinkProps = AnchorHTMLAttributes<HTMLAnchorElement> & {
isInline?: boolean;
};
export const FormattedLink = ({
title,
href,
isInline,
...rest
}: FormattedLinkProps) => {
2020-09-01 08:25:24 +00:00
return (
<a
2020-09-21 20:12:53 +00:00
href={href}
target="_blank"
rel="noreferrer noopener"
className={isInline ? "pf-m-link pf-m-inline" : ""}
2020-09-21 20:12:53 +00:00
{...rest}
>
{title ? title : href}{" "}
{href?.startsWith("http") && <ExternalLinkAltIcon />}
</a>
2020-09-01 08:25:24 +00:00
);
};
export const formattedLinkTableCell = (): IFormatter => (
data?: IFormatterValueType
) => {
return (data ? (
<FormattedLink href={data.toString()} />
) : undefined) as object;
};