2019-10-31 04:48:05 -05:00
|
|
|
import { PanelPlugin } from '@grafana/data';
|
2019-03-05 18:07:46 -06:00
|
|
|
import { TablePanel } from './TablePanel';
|
2020-04-08 12:21:26 -05:00
|
|
|
import { CustomFieldConfig, Options } from './types';
|
2020-09-01 10:06:35 -05:00
|
|
|
import { tableMigrationHandler, tablePanelChangedHandler } from './migrations';
|
2020-04-23 06:57:08 -05:00
|
|
|
import { TableCellDisplayMode } from '@grafana/ui';
|
2019-03-05 18:07:46 -06:00
|
|
|
|
2020-04-01 08:33:10 -05:00
|
|
|
export const plugin = new PanelPlugin<Options, CustomFieldConfig>(TablePanel)
|
2020-04-14 14:14:06 -05:00
|
|
|
.setPanelChangeHandler(tablePanelChangedHandler)
|
|
|
|
.setMigrationHandler(tableMigrationHandler)
|
2020-04-20 02:27:40 -05:00
|
|
|
.setNoPadding()
|
2020-04-06 09:24:41 -05:00
|
|
|
.useFieldConfig({
|
2021-01-20 00:59:48 -06:00
|
|
|
useCustomConfig: (builder) => {
|
2020-04-06 09:24:41 -05:00
|
|
|
builder
|
|
|
|
.addNumberInput({
|
|
|
|
path: 'width',
|
|
|
|
name: 'Column width',
|
|
|
|
settings: {
|
|
|
|
placeholder: 'auto',
|
|
|
|
min: 20,
|
|
|
|
max: 300,
|
|
|
|
},
|
2020-04-20 02:27:40 -05:00
|
|
|
shouldApply: () => true,
|
2020-04-06 09:24:41 -05:00
|
|
|
})
|
2020-04-07 07:02:18 -05:00
|
|
|
.addRadio({
|
|
|
|
path: 'align',
|
|
|
|
name: 'Column alignment',
|
|
|
|
settings: {
|
|
|
|
options: [
|
|
|
|
{ label: 'auto', value: null },
|
|
|
|
{ label: 'left', value: 'left' },
|
|
|
|
{ label: 'center', value: 'center' },
|
|
|
|
{ label: 'right', value: 'right' },
|
|
|
|
],
|
|
|
|
},
|
|
|
|
defaultValue: null,
|
|
|
|
})
|
2020-04-06 09:24:41 -05:00
|
|
|
.addSelect({
|
|
|
|
path: 'displayMode',
|
|
|
|
name: 'Cell display mode',
|
2020-04-09 00:42:31 -05:00
|
|
|
description: 'Color text, background, show as gauge, etc',
|
2020-04-06 09:24:41 -05:00
|
|
|
settings: {
|
|
|
|
options: [
|
2020-04-20 13:10:03 -05:00
|
|
|
{ value: TableCellDisplayMode.Auto, label: 'Auto' },
|
|
|
|
{ value: TableCellDisplayMode.ColorText, label: 'Color text' },
|
|
|
|
{ value: TableCellDisplayMode.ColorBackground, label: 'Color background' },
|
|
|
|
{ value: TableCellDisplayMode.GradientGauge, label: 'Gradient gauge' },
|
|
|
|
{ value: TableCellDisplayMode.LcdGauge, label: 'LCD gauge' },
|
2020-07-26 09:52:42 -05:00
|
|
|
{ value: TableCellDisplayMode.BasicGauge, label: 'Basic gauge' },
|
2020-04-20 13:10:03 -05:00
|
|
|
{ value: TableCellDisplayMode.JSONView, label: 'JSON View' },
|
2020-09-24 13:09:01 -05:00
|
|
|
{ value: TableCellDisplayMode.Image, label: 'Image' },
|
2020-04-06 09:24:41 -05:00
|
|
|
],
|
|
|
|
},
|
2020-09-01 10:06:35 -05:00
|
|
|
})
|
|
|
|
.addBooleanSwitch({
|
|
|
|
path: 'filterable',
|
|
|
|
name: 'Column filter',
|
|
|
|
description: 'Enables/disables field filters in table',
|
|
|
|
defaultValue: false,
|
2020-04-06 09:24:41 -05:00
|
|
|
});
|
|
|
|
},
|
2020-03-26 15:48:46 -05:00
|
|
|
})
|
2021-01-20 00:59:48 -06:00
|
|
|
.setPanelOptions((builder) => {
|
2020-04-20 02:27:40 -05:00
|
|
|
builder.addBooleanSwitch({
|
|
|
|
path: 'showHeader',
|
|
|
|
name: 'Show header',
|
|
|
|
description: "To display table's header or not to display",
|
|
|
|
defaultValue: true,
|
|
|
|
});
|
2020-03-26 15:48:46 -05:00
|
|
|
});
|