mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
53 lines
1.6 KiB
TypeScript
53 lines
1.6 KiB
TypeScript
import React, { useEffect, useState } from 'react';
|
|
import { usePrevious } from 'react-use';
|
|
|
|
import { PanelData } from '@grafana/data';
|
|
import { Icon } from '@grafana/ui';
|
|
|
|
import { AwsUrl, encodeUrl } from '../aws_url';
|
|
import { CloudWatchDatasource } from '../datasource';
|
|
import { CloudWatchLogsQuery } from '../types';
|
|
|
|
interface Props {
|
|
query: CloudWatchLogsQuery;
|
|
panelData?: PanelData;
|
|
datasource: CloudWatchDatasource;
|
|
}
|
|
|
|
export function CloudWatchLink({ panelData, query, datasource }: Props) {
|
|
const [href, setHref] = useState('');
|
|
const prevPanelData = usePrevious<PanelData | undefined>(panelData);
|
|
|
|
useEffect(() => {
|
|
if (prevPanelData !== panelData && panelData?.request?.range) {
|
|
const arns = (query.logGroups ?? [])
|
|
.filter((group) => group?.arn)
|
|
.map((group) => (group.arn ?? '').replace(/:\*$/, '')); // remove `:*` from end of arn
|
|
const logGroupNames = query.logGroupNames;
|
|
let sources = arns?.length ? arns : logGroupNames;
|
|
|
|
const range = panelData?.request?.range;
|
|
const start = range.from.toISOString();
|
|
const end = range.to.toISOString();
|
|
|
|
const urlProps: AwsUrl = {
|
|
end,
|
|
start,
|
|
timeType: 'ABSOLUTE',
|
|
tz: 'UTC',
|
|
editorString: query.expression ?? '',
|
|
isLiveTail: false,
|
|
source: sources ?? [],
|
|
};
|
|
|
|
setHref(encodeUrl(urlProps, datasource.resources.getActualRegion(query.region)));
|
|
}
|
|
}, [panelData, prevPanelData, datasource, query]);
|
|
|
|
return (
|
|
<a href={href} target="_blank" rel="noopener noreferrer">
|
|
<Icon name="share-alt" /> CloudWatch Logs Insights
|
|
</a>
|
|
);
|
|
}
|