mirror of
https://github.com/grafana/grafana.git
synced 2025-02-16 18:34:52 -06:00
* FormField to LegacyForms * FormLabel to InlineFormLabel * Move SecretFormField to LeagcyForms
52 lines
1.5 KiB
TypeScript
52 lines
1.5 KiB
TypeScript
// Libraries
|
|
import React, { PureComponent } from 'react';
|
|
|
|
// Components
|
|
import { LegacyForms, InlineFormLabel, PanelOptionsGroup } from '@grafana/ui';
|
|
const { Select, FormField } = LegacyForms;
|
|
|
|
// Types
|
|
import { PanelEditorProps } from '@grafana/data';
|
|
import { PieChartType } from '@grafana/ui';
|
|
import { PieChartOptions } from './types';
|
|
|
|
const labelWidth = 8;
|
|
|
|
const pieChartOptions = [
|
|
{ value: PieChartType.PIE, label: 'Pie' },
|
|
{ value: PieChartType.DONUT, label: 'Donut' },
|
|
];
|
|
|
|
export class PieChartOptionsBox extends PureComponent<PanelEditorProps<PieChartOptions>> {
|
|
onPieTypeChange = (pieType: any) => this.props.onOptionsChange({ ...this.props.options, pieType: pieType.value });
|
|
onStrokeWidthChange = ({ target }: any) =>
|
|
this.props.onOptionsChange({ ...this.props.options, strokeWidth: target.value });
|
|
|
|
render() {
|
|
const { options } = this.props;
|
|
const { pieType, strokeWidth } = options;
|
|
|
|
return (
|
|
<PanelOptionsGroup title="PieChart">
|
|
<div className="gf-form">
|
|
<InlineFormLabel width={labelWidth}>Type</InlineFormLabel>
|
|
<Select
|
|
width={12}
|
|
options={pieChartOptions}
|
|
onChange={this.onPieTypeChange}
|
|
value={pieChartOptions.find(option => option.value === pieType)}
|
|
/>
|
|
</div>
|
|
<div className="gf-form">
|
|
<FormField
|
|
label="Divider width"
|
|
labelWidth={labelWidth}
|
|
onChange={this.onStrokeWidthChange}
|
|
value={strokeWidth}
|
|
/>
|
|
</div>
|
|
</PanelOptionsGroup>
|
|
);
|
|
}
|
|
}
|