2024-04-03 05:43:03 -07:00
|
|
|
import { Anchor, Badge, Group } from "@mantine/core";
|
2024-04-03 07:15:50 -07:00
|
|
|
import { FC } from "react";
|
2024-04-03 05:43:03 -07:00
|
|
|
|
|
|
|
export interface EndpointLinkProps {
|
|
|
|
endpoint: string;
|
|
|
|
globalUrl: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const EndpointLink: FC<EndpointLinkProps> = ({ endpoint, globalUrl }) => {
|
|
|
|
let url: URL;
|
|
|
|
let search = "";
|
|
|
|
let invalidURL = false;
|
|
|
|
try {
|
|
|
|
url = new URL(endpoint);
|
|
|
|
} catch (err: unknown) {
|
|
|
|
// In cases of IPv6 addresses with a Zone ID, URL may not be parseable.
|
|
|
|
// See https://github.com/prometheus/prometheus/issues/9760
|
|
|
|
// In this case, we attempt to prepare a synthetic URL with the
|
|
|
|
// same query parameters, for rendering purposes.
|
|
|
|
invalidURL = true;
|
|
|
|
if (endpoint.indexOf("?") > -1) {
|
|
|
|
search = endpoint.substring(endpoint.indexOf("?"));
|
|
|
|
}
|
|
|
|
url = new URL("http://0.0.0.0" + search);
|
|
|
|
}
|
|
|
|
|
|
|
|
const { host, pathname, protocol, searchParams }: URL = url;
|
|
|
|
const params = Array.from(searchParams.entries());
|
|
|
|
const displayLink = invalidURL
|
|
|
|
? endpoint.replace(search, "")
|
|
|
|
: `${protocol}//${host}${pathname}`;
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<Anchor size="sm" href={globalUrl}>
|
|
|
|
{displayLink}
|
|
|
|
</Anchor>
|
|
|
|
{params.length > 0 && (
|
|
|
|
<Group gap="xs" my="md">
|
|
|
|
{params.map(([labelName, labelValue]: [string, string]) => {
|
|
|
|
return (
|
|
|
|
<Badge
|
|
|
|
size="sm"
|
|
|
|
variant="light"
|
|
|
|
color="gray.9"
|
|
|
|
key={`${labelName}/${labelValue}`}
|
|
|
|
style={{ textTransform: "none" }}
|
|
|
|
>
|
|
|
|
{`${labelName}="${labelValue}"`}
|
|
|
|
</Badge>
|
|
|
|
);
|
|
|
|
})}
|
|
|
|
</Group>
|
|
|
|
)}
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default EndpointLink;
|