mirror of
https://github.com/grafana/grafana.git
synced 2025-09-23 01:43:36 +08:00
59 lines
1.8 KiB
TypeScript
59 lines
1.8 KiB
TypeScript
// Copyright (c) 2019 The Jaeger Authors.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
import React from 'react';
|
|
import { TraceSpanReference } from '@grafana/data';
|
|
import ExternalLinkContext from './externalLinkContext';
|
|
|
|
type ReferenceLinkProps = {
|
|
reference: TraceSpanReference;
|
|
children: React.ReactNode;
|
|
className?: string;
|
|
focusSpan: (spanID: string) => void;
|
|
onClick?: () => void;
|
|
};
|
|
|
|
export default function ReferenceLink(props: ReferenceLinkProps) {
|
|
const { reference, children, className, focusSpan, ...otherProps } = props;
|
|
delete otherProps.onClick;
|
|
if (reference.span) {
|
|
return (
|
|
<a role="button" onClick={() => focusSpan(reference.spanID)} className={className} {...otherProps}>
|
|
{children}
|
|
</a>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<ExternalLinkContext.Consumer>
|
|
{createLinkToExternalSpan => {
|
|
if (!createLinkToExternalSpan) {
|
|
throw new Error("ExternalLinkContext does not have a value, you probably forgot to setup it's provider");
|
|
}
|
|
return (
|
|
<a
|
|
href={createLinkToExternalSpan(reference.traceID, reference.spanID)}
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
className={className}
|
|
{...otherProps}
|
|
>
|
|
{children}
|
|
</a>
|
|
);
|
|
}}
|
|
</ExternalLinkContext.Consumer>
|
|
);
|
|
}
|