mirror of
https://github.com/grafana/grafana.git
synced 2025-02-15 10:03:33 -06:00
* Fix query preview add tabs to options * break out tabs to components * add refresh button * minor things after PR review * hide queries * Add simple error screen if there's an error * dropdown with different frames * move onrunqueries to redux * cleanup * show actual error
109 lines
3.3 KiB
TypeScript
109 lines
3.3 KiB
TypeScript
import React, { FC, useMemo, useState } from 'react';
|
|
import { useObservable } from 'react-use';
|
|
import { css } from 'emotion';
|
|
import AutoSizer from 'react-virtualized-auto-sizer';
|
|
import { GrafanaTheme } from '@grafana/data';
|
|
import { TabsBar, TabContent, Tab, useStyles, Icon } from '@grafana/ui';
|
|
import { PanelQueryRunner } from '../../query/state/PanelQueryRunner';
|
|
import { PreviewQueryTab } from './PreviewQueryTab';
|
|
import { PreviewInstancesTab } from './PreviewInstancesTab';
|
|
|
|
enum Tabs {
|
|
Query = 'query',
|
|
Instances = 'instances',
|
|
}
|
|
|
|
const tabs = [
|
|
{ id: Tabs.Query, text: 'Query result' },
|
|
{ id: Tabs.Instances, text: 'Alerting instances' },
|
|
];
|
|
|
|
interface Props {
|
|
queryRunner: PanelQueryRunner;
|
|
}
|
|
|
|
export const AlertingQueryPreview: FC<Props> = ({ queryRunner }) => {
|
|
const [activeTab, setActiveTab] = useState<string>(Tabs.Query);
|
|
const styles = useStyles(getStyles);
|
|
|
|
const observable = useMemo(() => queryRunner.getData({ withFieldConfig: true, withTransforms: true }), []);
|
|
const data = useObservable(observable);
|
|
|
|
return (
|
|
<div className={styles.wrapper}>
|
|
<TabsBar>
|
|
{tabs.map((tab, index) => {
|
|
return (
|
|
<Tab
|
|
key={`${tab.id}-${index}`}
|
|
label={tab.text}
|
|
onChangeTab={() => setActiveTab(tab.id)}
|
|
active={activeTab === tab.id}
|
|
/>
|
|
);
|
|
})}
|
|
</TabsBar>
|
|
<TabContent className={styles.tabContent}>
|
|
{data && data.state === 'Error' ? (
|
|
<div className={styles.noQueries}>
|
|
<h4 className={styles.noQueriesHeader}>There was an error :(</h4>
|
|
<div>{data.error?.data?.error}</div>
|
|
</div>
|
|
) : data && data.series.length > 0 ? (
|
|
<AutoSizer style={{ width: '100%', height: '100%' }}>
|
|
{({ width, height }) => {
|
|
switch (activeTab) {
|
|
case Tabs.Instances:
|
|
return <PreviewInstancesTab isTested={false} data={data} styles={styles} />;
|
|
|
|
case Tabs.Query:
|
|
default:
|
|
return <PreviewQueryTab data={data} width={width} height={height} />;
|
|
}
|
|
}}
|
|
</AutoSizer>
|
|
) : (
|
|
<div className={styles.noQueries}>
|
|
<h4 className={styles.noQueriesHeader}>No queries added.</h4>
|
|
<div>Start adding queries to this alert and a visualisation for your queries will appear here.</div>
|
|
<div>
|
|
Learn more about how to create alert definitions <Icon name="external-link-alt" />
|
|
</div>
|
|
</div>
|
|
)}
|
|
</TabContent>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
const getStyles = (theme: GrafanaTheme) => {
|
|
return {
|
|
wrapper: css`
|
|
label: alertDefinitionPreviewTabs;
|
|
display: flex;
|
|
flex-direction: column;
|
|
width: 100%;
|
|
height: 100%;
|
|
padding: ${theme.spacing.md} 0 0 ${theme.spacing.md};
|
|
`,
|
|
tabContent: css`
|
|
background: ${theme.colors.panelBg};
|
|
height: 100%;
|
|
`,
|
|
noQueries: css`
|
|
color: ${theme.colors.textSemiWeak};
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
align-items: center;
|
|
height: 100%;
|
|
width: 100%;
|
|
`,
|
|
noQueriesHeader: css`
|
|
color: ${theme.colors.textSemiWeak};
|
|
`,
|
|
};
|
|
};
|
|
|
|
export type PreviewStyles = ReturnType<typeof getStyles>;
|