grafana/public/app/features/explore/SecondaryActions.tsx
2023-08-22 14:36:53 +01:00

68 lines
1.9 KiB
TypeScript

import { css } from '@emotion/css';
import React from 'react';
import { GrafanaTheme2 } from '@grafana/data';
import { Components } from '@grafana/e2e-selectors';
import { HorizontalGroup, ToolbarButton, useTheme2 } from '@grafana/ui';
type Props = {
addQueryRowButtonDisabled?: boolean;
addQueryRowButtonHidden?: boolean;
richHistoryRowButtonHidden?: boolean;
richHistoryButtonActive?: boolean;
queryInspectorButtonActive?: boolean;
onClickAddQueryRowButton: () => void;
onClickRichHistoryButton: () => void;
onClickQueryInspectorButton: () => void;
};
const getStyles = (theme: GrafanaTheme2) => {
return {
containerMargin: css`
margin-top: ${theme.spacing(2)};
`,
};
};
export function SecondaryActions(props: Props) {
const theme = useTheme2();
const styles = getStyles(theme);
return (
<div className={styles.containerMargin}>
<HorizontalGroup>
{!props.addQueryRowButtonHidden && (
<ToolbarButton
variant="canvas"
aria-label="Add query"
onClick={props.onClickAddQueryRowButton}
disabled={props.addQueryRowButtonDisabled}
icon="plus"
>
Add query
</ToolbarButton>
)}
{!props.richHistoryRowButtonHidden && (
<ToolbarButton
variant={props.richHistoryButtonActive ? 'active' : 'canvas'}
aria-label="Query history"
onClick={props.onClickRichHistoryButton}
data-testid={Components.QueryTab.queryHistoryButton}
icon="history"
>
Query history
</ToolbarButton>
)}
<ToolbarButton
variant={props.queryInspectorButtonActive ? 'active' : 'canvas'}
aria-label="Query inspector"
onClick={props.onClickQueryInspectorButton}
icon="info-circle"
>
Query inspector
</ToolbarButton>
</HorizontalGroup>
</div>
);
}