mirror of
https://github.com/grafana/grafana.git
synced 2025-02-12 08:35:43 -06:00
385 lines
11 KiB
TypeScript
385 lines
11 KiB
TypeScript
import React from 'react';
|
|
|
|
import {
|
|
FieldConfigPropertyItem,
|
|
FieldType,
|
|
standardEditorsRegistry,
|
|
StandardEditorsRegistryItem,
|
|
ThresholdsConfig,
|
|
ThresholdsFieldConfigSettings,
|
|
ThresholdsMode,
|
|
thresholdsOverrideProcessor,
|
|
ValueMapping,
|
|
ValueMappingFieldConfigSettings,
|
|
valueMappingsOverrideProcessor,
|
|
DataLink,
|
|
dataLinksOverrideProcessor,
|
|
NumberFieldConfigSettings,
|
|
numberOverrideProcessor,
|
|
StringFieldConfigSettings,
|
|
stringOverrideProcessor,
|
|
identityOverrideProcessor,
|
|
TimeZone,
|
|
FieldColor,
|
|
FieldColorConfigSettings,
|
|
StatsPickerConfigSettings,
|
|
displayNameOverrideProcessor,
|
|
FieldNamePickerConfigSettings,
|
|
} from '@grafana/data';
|
|
import { RadioButtonGroup, TimeZonePicker, Switch } from '@grafana/ui';
|
|
import { FieldNamePicker } from '@grafana/ui/src/components/MatchersUI/FieldNamePicker';
|
|
import { ThresholdsValueEditor } from 'app/features/dimensions/editors/ThresholdsEditor/thresholds';
|
|
import { ValueMappingsEditor } from 'app/features/dimensions/editors/ValueMappingsEditor/ValueMappingsEditor';
|
|
|
|
import { DashboardPicker, DashboardPickerOptions } from './DashboardPicker';
|
|
import { ColorValueEditor } from './color';
|
|
import { FieldColorEditor } from './fieldColor';
|
|
import { DataLinksValueEditor } from './links';
|
|
import { MultiSelectValueEditor } from './multiSelect';
|
|
import { NumberValueEditor } from './number';
|
|
import { SelectValueEditor } from './select';
|
|
import { SliderValueEditor } from './slider';
|
|
import { StatsPickerEditor } from './stats';
|
|
import { StringValueEditor } from './string';
|
|
import { StringArrayEditor } from './strings';
|
|
import { UnitValueEditor } from './units';
|
|
|
|
/**
|
|
* Returns collection of standard option editors definitions
|
|
*/
|
|
export const getAllOptionEditors = () => {
|
|
const number: StandardEditorsRegistryItem<number> = {
|
|
id: 'number',
|
|
name: 'Number',
|
|
description: 'Allows numeric values input',
|
|
editor: NumberValueEditor as any,
|
|
};
|
|
|
|
const slider: StandardEditorsRegistryItem<number> = {
|
|
id: 'slider',
|
|
name: 'Slider',
|
|
description: 'Allows numeric values input',
|
|
editor: SliderValueEditor as any,
|
|
};
|
|
|
|
const text: StandardEditorsRegistryItem<string> = {
|
|
id: 'text',
|
|
name: 'Text',
|
|
description: 'Allows string values input',
|
|
editor: StringValueEditor as any,
|
|
};
|
|
|
|
const strings: StandardEditorsRegistryItem<string[]> = {
|
|
id: 'strings',
|
|
name: 'String array',
|
|
description: 'An array of strings',
|
|
editor: StringArrayEditor as any,
|
|
};
|
|
|
|
const boolean: StandardEditorsRegistryItem<boolean> = {
|
|
id: 'boolean',
|
|
name: 'Boolean',
|
|
description: 'Allows boolean values input',
|
|
editor(props) {
|
|
return <Switch {...props} onChange={(e) => props.onChange(e.currentTarget.checked)} />;
|
|
},
|
|
};
|
|
|
|
const select: StandardEditorsRegistryItem<any> = {
|
|
id: 'select',
|
|
name: 'Select',
|
|
description: 'Allows option selection',
|
|
editor: SelectValueEditor as any,
|
|
};
|
|
|
|
const multiSelect: StandardEditorsRegistryItem<any> = {
|
|
id: 'multi-select',
|
|
name: 'Multi select',
|
|
description: 'Allows for multiple option selection',
|
|
editor: MultiSelectValueEditor as any,
|
|
};
|
|
|
|
const radio: StandardEditorsRegistryItem<any> = {
|
|
id: 'radio',
|
|
name: 'Radio',
|
|
description: 'Allows option selection',
|
|
editor(props) {
|
|
return <RadioButtonGroup {...props} options={props.item.settings?.options} />;
|
|
},
|
|
};
|
|
|
|
const unit: StandardEditorsRegistryItem<string> = {
|
|
id: 'unit',
|
|
name: 'Unit',
|
|
description: 'Allows unit input',
|
|
editor: UnitValueEditor as any,
|
|
};
|
|
|
|
const color: StandardEditorsRegistryItem<string> = {
|
|
id: 'color',
|
|
name: 'Color',
|
|
description: 'Allows color selection',
|
|
editor(props) {
|
|
return <ColorValueEditor value={props.value} onChange={props.onChange} />;
|
|
},
|
|
};
|
|
|
|
const fieldColor: StandardEditorsRegistryItem<FieldColor> = {
|
|
id: 'fieldColor',
|
|
name: 'Field Color',
|
|
description: 'Field color selection',
|
|
editor: FieldColorEditor as any,
|
|
};
|
|
|
|
const links: StandardEditorsRegistryItem<DataLink[]> = {
|
|
id: 'links',
|
|
name: 'Links',
|
|
description: 'Allows defining data links',
|
|
editor: DataLinksValueEditor as any,
|
|
};
|
|
|
|
const statsPicker: StandardEditorsRegistryItem<string[], StatsPickerConfigSettings> = {
|
|
id: 'stats-picker',
|
|
name: 'Stats Picker',
|
|
editor: StatsPickerEditor as any,
|
|
description: '',
|
|
};
|
|
|
|
const timeZone: StandardEditorsRegistryItem<TimeZone> = {
|
|
id: 'timezone',
|
|
name: 'Time zone',
|
|
description: 'Time zone selection',
|
|
editor: TimeZonePicker as any,
|
|
};
|
|
|
|
const fieldName: StandardEditorsRegistryItem<string, FieldNamePickerConfigSettings> = {
|
|
id: 'field-name',
|
|
name: 'Field name',
|
|
description: 'Allows selecting a field name from a data frame',
|
|
editor: FieldNamePicker as any,
|
|
};
|
|
|
|
const dashboardPicker: StandardEditorsRegistryItem<string, DashboardPickerOptions> = {
|
|
id: 'dashboard-uid',
|
|
name: 'Dashboard',
|
|
description: 'Select dashboard',
|
|
editor: DashboardPicker as any,
|
|
};
|
|
|
|
const mappings: StandardEditorsRegistryItem<ValueMapping[]> = {
|
|
id: 'mappings',
|
|
name: 'Mappings',
|
|
description: 'Allows defining value mappings',
|
|
editor: ValueMappingsEditor as any,
|
|
};
|
|
|
|
const thresholds: StandardEditorsRegistryItem<ThresholdsConfig> = {
|
|
id: 'thresholds',
|
|
name: 'Thresholds',
|
|
description: 'Allows defining thresholds',
|
|
editor: ThresholdsValueEditor as any,
|
|
};
|
|
|
|
return [
|
|
text,
|
|
number,
|
|
slider,
|
|
boolean,
|
|
radio,
|
|
select,
|
|
unit,
|
|
links,
|
|
statsPicker,
|
|
strings,
|
|
timeZone,
|
|
fieldColor,
|
|
color,
|
|
multiSelect,
|
|
fieldName,
|
|
dashboardPicker,
|
|
mappings,
|
|
thresholds,
|
|
];
|
|
};
|
|
|
|
/**
|
|
* Returns collection of common field config properties definitions
|
|
*/
|
|
export const getAllStandardFieldConfigs = () => {
|
|
const category = ['Standard options'];
|
|
const displayName: FieldConfigPropertyItem<any, string, StringFieldConfigSettings> = {
|
|
id: 'displayName',
|
|
path: 'displayName',
|
|
name: 'Display name',
|
|
description: 'Change the field or series name',
|
|
editor: standardEditorsRegistry.get('text').editor as any,
|
|
override: standardEditorsRegistry.get('text').editor as any,
|
|
process: displayNameOverrideProcessor,
|
|
settings: {
|
|
placeholder: 'none',
|
|
expandTemplateVars: true,
|
|
},
|
|
shouldApply: () => true,
|
|
category,
|
|
};
|
|
|
|
const unit: FieldConfigPropertyItem<any, string, StringFieldConfigSettings> = {
|
|
id: 'unit',
|
|
path: 'unit',
|
|
name: 'Unit',
|
|
description: '',
|
|
|
|
editor: standardEditorsRegistry.get('unit').editor as any,
|
|
override: standardEditorsRegistry.get('unit').editor as any,
|
|
process: stringOverrideProcessor,
|
|
|
|
settings: {
|
|
placeholder: 'none',
|
|
},
|
|
|
|
shouldApply: () => true,
|
|
category,
|
|
};
|
|
|
|
const min: FieldConfigPropertyItem<any, number, NumberFieldConfigSettings> = {
|
|
id: 'min',
|
|
path: 'min',
|
|
name: 'Min',
|
|
description: 'Leave empty to calculate based on all values',
|
|
|
|
editor: standardEditorsRegistry.get('number').editor as any,
|
|
override: standardEditorsRegistry.get('number').editor as any,
|
|
process: numberOverrideProcessor,
|
|
|
|
settings: {
|
|
placeholder: 'auto',
|
|
},
|
|
shouldApply: (field) => field.type === FieldType.number,
|
|
category,
|
|
};
|
|
|
|
const max: FieldConfigPropertyItem<any, number, NumberFieldConfigSettings> = {
|
|
id: 'max',
|
|
path: 'max',
|
|
name: 'Max',
|
|
description: 'Leave empty to calculate based on all values',
|
|
|
|
editor: standardEditorsRegistry.get('number').editor as any,
|
|
override: standardEditorsRegistry.get('number').editor as any,
|
|
process: numberOverrideProcessor,
|
|
|
|
settings: {
|
|
placeholder: 'auto',
|
|
},
|
|
|
|
shouldApply: (field) => field.type === FieldType.number,
|
|
category,
|
|
};
|
|
|
|
const decimals: FieldConfigPropertyItem<any, number, NumberFieldConfigSettings> = {
|
|
id: 'decimals',
|
|
path: 'decimals',
|
|
name: 'Decimals',
|
|
|
|
editor: standardEditorsRegistry.get('number').editor as any,
|
|
override: standardEditorsRegistry.get('number').editor as any,
|
|
process: numberOverrideProcessor,
|
|
|
|
settings: {
|
|
placeholder: 'auto',
|
|
min: 0,
|
|
max: 15,
|
|
integer: true,
|
|
},
|
|
|
|
shouldApply: (field) => field.type === FieldType.number,
|
|
category,
|
|
};
|
|
|
|
const noValue: FieldConfigPropertyItem<any, string, StringFieldConfigSettings> = {
|
|
id: 'noValue',
|
|
path: 'noValue',
|
|
name: 'No value',
|
|
description: 'What to show when there is no value',
|
|
|
|
editor: standardEditorsRegistry.get('text').editor as any,
|
|
override: standardEditorsRegistry.get('text').editor as any,
|
|
process: stringOverrideProcessor,
|
|
|
|
settings: {
|
|
placeholder: '-',
|
|
},
|
|
// ??? any optionsUi with no value
|
|
shouldApply: () => true,
|
|
category,
|
|
};
|
|
|
|
const links: FieldConfigPropertyItem<any, DataLink[], StringFieldConfigSettings> = {
|
|
id: 'links',
|
|
path: 'links',
|
|
name: 'Data links',
|
|
editor: standardEditorsRegistry.get('links').editor as any,
|
|
override: standardEditorsRegistry.get('links').editor as any,
|
|
process: dataLinksOverrideProcessor,
|
|
settings: {
|
|
placeholder: '-',
|
|
},
|
|
shouldApply: () => true,
|
|
category: ['Data links'],
|
|
getItemsCount: (value) => (value ? value.length : 0),
|
|
};
|
|
|
|
const color: FieldConfigPropertyItem<any, FieldColor | undefined, FieldColorConfigSettings> = {
|
|
id: 'color',
|
|
path: 'color',
|
|
name: 'Color scheme',
|
|
editor: standardEditorsRegistry.get('fieldColor').editor as any,
|
|
override: standardEditorsRegistry.get('fieldColor').editor as any,
|
|
process: identityOverrideProcessor,
|
|
shouldApply: () => true,
|
|
settings: {
|
|
byValueSupport: true,
|
|
preferThresholdsMode: true,
|
|
},
|
|
category,
|
|
};
|
|
|
|
const mappings: FieldConfigPropertyItem<any, ValueMapping[], ValueMappingFieldConfigSettings> = {
|
|
id: 'mappings',
|
|
path: 'mappings',
|
|
name: 'Value mappings',
|
|
description: 'Modify the display text based on input value',
|
|
|
|
editor: standardEditorsRegistry.get('mappings').editor as any,
|
|
override: standardEditorsRegistry.get('mappings').editor as any,
|
|
process: valueMappingsOverrideProcessor,
|
|
settings: {},
|
|
defaultValue: [],
|
|
shouldApply: (x) => x.type !== FieldType.time,
|
|
category: ['Value mappings'],
|
|
getItemsCount: (value?) => (value ? value.length : 0),
|
|
};
|
|
|
|
const thresholds: FieldConfigPropertyItem<any, ThresholdsConfig, ThresholdsFieldConfigSettings> = {
|
|
id: 'thresholds',
|
|
path: 'thresholds',
|
|
name: 'Thresholds',
|
|
editor: standardEditorsRegistry.get('thresholds').editor as any,
|
|
override: standardEditorsRegistry.get('thresholds').editor as any,
|
|
process: thresholdsOverrideProcessor,
|
|
settings: {},
|
|
defaultValue: {
|
|
mode: ThresholdsMode.Absolute,
|
|
steps: [
|
|
{ value: -Infinity, color: 'green' },
|
|
{ value: 80, color: 'red' },
|
|
],
|
|
},
|
|
shouldApply: () => true,
|
|
category: ['Thresholds'],
|
|
getItemsCount: (value) => (value ? value.steps.length : 0),
|
|
};
|
|
|
|
return [unit, min, max, decimals, displayName, color, noValue, links, mappings, thresholds];
|
|
};
|