grafana/public/app/features/trails/DataTrailSettings.tsx
Darren Janeczek ea90f0119c
datatrails: track user interactions (#85909)
* chore: add interaction tracking
2024-04-16 15:55:07 -04:00

83 lines
2.6 KiB
TypeScript

import { css } from '@emotion/css';
import React from 'react';
import { GrafanaTheme2 } from '@grafana/data';
import { SceneComponentProps, SceneObjectBase, SceneObjectState } from '@grafana/scenes';
import { Dropdown, Switch, ToolbarButton, useStyles2 } from '@grafana/ui';
import { reportExploreMetrics } from './interactions';
export interface DataTrailSettingsState extends SceneObjectState {
stickyMainGraph?: boolean;
isOpen?: boolean;
}
export class DataTrailSettings extends SceneObjectBase<DataTrailSettingsState> {
constructor(state: Partial<DataTrailSettingsState>) {
super({
stickyMainGraph: state.stickyMainGraph ?? true,
isOpen: state.isOpen ?? false,
});
}
public onToggleStickyMainGraph = () => {
const stickyMainGraph = !this.state.stickyMainGraph;
reportExploreMetrics('settings_changed', { stickyMainGraph });
this.setState({ stickyMainGraph });
};
public onToggleOpen = (isOpen: boolean) => {
this.setState({ isOpen });
};
static Component = ({ model }: SceneComponentProps<DataTrailSettings>) => {
const { stickyMainGraph, isOpen } = model.useState();
const styles = useStyles2(getStyles);
const renderPopover = () => {
return (
/* eslint-disable-next-line jsx-a11y/no-static-element-interactions, jsx-a11y/click-events-have-key-events */
<div className={styles.popover} onClick={(evt) => evt.stopPropagation()}>
<div className={styles.heading}>Settings</div>
<div className={styles.options}>
<div>Always keep selected metric graph in-view</div>
<Switch value={stickyMainGraph} onChange={model.onToggleStickyMainGraph} />
</div>
</div>
);
};
return (
<Dropdown overlay={renderPopover} placement="bottom" onVisibleChange={model.onToggleOpen}>
<ToolbarButton icon="cog" variant="canvas" isOpen={isOpen} />
</Dropdown>
);
};
}
function getStyles(theme: GrafanaTheme2) {
return {
popover: css({
display: 'flex',
padding: theme.spacing(2),
flexDirection: 'column',
background: theme.colors.background.primary,
boxShadow: theme.shadows.z3,
borderRadius: theme.shape.borderRadius(),
border: `1px solid ${theme.colors.border.weak}`,
zIndex: 1,
marginRight: theme.spacing(2),
}),
heading: css({
fontWeight: theme.typography.fontWeightMedium,
paddingBottom: theme.spacing(2),
}),
options: css({
display: 'grid',
gridTemplateColumns: '1fr 50px',
rowGap: theme.spacing(1),
columnGap: theme.spacing(2),
}),
};
}