The open and composable observability and data visualization platform. Visualize metrics, logs, and traces from multiple sources like Prometheus, Loki, Elasticsearch, InfluxDB, Postgres and many more.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
grafana/public/app/plugins/panel/geomap/module.tsx

152 lines
4.6 KiB

import { PanelPlugin } from '@grafana/data';
import { Trans } from '@grafana/i18n';
import { config } from '@grafana/runtime';
import { commonOptionsBuilder } from '@grafana/ui';
import { GeomapPanel } from './GeomapPanel';
import { LayersEditor } from './editor/LayersEditor';
import { MapViewEditor } from './editor/MapViewEditor';
import { getLayerEditor } from './editor/layerEditor';
import { mapPanelChangedHandler, mapMigrationHandler } from './migrations';
import { defaultMapViewConfig, Options, TooltipMode, GeomapInstanceState } from './types';
export const plugin = new PanelPlugin<Options>(GeomapPanel)
.setNoPadding()
.setPanelChangeHandler(mapPanelChangedHandler)
.setMigrationHandler(mapMigrationHandler)
.useFieldConfig({
useCustomConfig: (builder) => {
commonOptionsBuilder.addHideFrom(builder);
},
})
.setPanelOptions((builder, context) => {
let category = ['Map view'];
builder.addCustomEditor({
category,
id: 'view',
path: 'view',
name: 'Initial view', // don't show it
description: 'This location will show when the panel first loads.',
editor: MapViewEditor,
defaultValue: defaultMapViewConfig,
});
builder.addBooleanSwitch({
category,
path: 'view.shared',
description: 'Use the same view across multiple panels. Note: this may require a dashboard reload.',
name: 'Share view',
defaultValue: defaultMapViewConfig.shared,
});
// eslint-disable-next-line
const state = context.instanceState as GeomapInstanceState;
if (!state?.layers) {
// TODO? show spinner?
} else {
const layersCategory = ['Map layers'];
const basemapCategory = ['Basemap layer'];
builder.addCustomEditor({
category: layersCategory,
id: 'layers',
path: '',
name: '',
editor: LayersEditor,
});
const selected = state.layers[state.selected];
if (state.selected && selected) {
builder.addNestedOptions(
getLayerEditor({
state: selected,
category: layersCategory,
basemaps: false,
})
);
}
const baselayer = state.layers[0];
if (config.geomapDisableCustomBaseLayer) {
builder.addCustomEditor({
category: basemapCategory,
id: 'layers',
path: '',
name: '',
// eslint-disable-next-line react/display-name
editor: () => (
<div>
<Trans i18nKey="geomap.plugin.basemap-layer-configured-server-admin">
The basemap layer is configured by the server admin.
</Trans>
</div>
),
});
} else if (baselayer) {
builder.addNestedOptions(
getLayerEditor({
state: baselayer,
category: basemapCategory,
basemaps: true,
})
);
}
}
// The controls section
category = ['Map controls'];
builder
.addBooleanSwitch({
category,
path: 'controls.showZoom',
description: 'Show zoom control buttons in the upper left corner',
name: 'Show zoom control',
defaultValue: true,
})
.addBooleanSwitch({
category,
path: 'controls.mouseWheelZoom',
description: 'Enable zoom control via mouse wheel',
name: 'Mouse wheel zoom',
defaultValue: true,
})
.addBooleanSwitch({
category,
path: 'controls.showAttribution',
name: 'Show attribution',
description: 'Show the map source attribution info in the lower right',
defaultValue: true,
})
.addBooleanSwitch({
category,
path: 'controls.showScale',
name: 'Show scale',
description: 'Indicate map scale',
defaultValue: false,
})
.addBooleanSwitch({
category,
path: 'controls.showMeasure',
name: 'Show measure tools',
description: 'Show tools for making measurements on the map',
defaultValue: false,
})
.addBooleanSwitch({
category,
path: 'controls.showDebug',
name: 'Show debug',
description: 'Show map info',
defaultValue: false,
})
.addRadio({
category,
path: 'tooltip.mode',
name: 'Tooltip',
defaultValue: TooltipMode.Details,
settings: {
options: [
{ label: 'None', value: TooltipMode.None, description: 'Show contents on click, not hover' },
{ label: 'Details', value: TooltipMode.Details, description: 'Show popup on hover' },
],
},
});
});