mirror of
https://github.com/grafana/grafana.git
synced 2025-02-13 00:55:47 -06:00
51 lines
1.4 KiB
TypeScript
51 lines
1.4 KiB
TypeScript
import { PanelPluginMeta, PluginState, unEscapeStringFromRegex } from '@grafana/data';
|
|
import { config } from 'app/core/config';
|
|
|
|
export function getAllPanelPluginMeta(): PanelPluginMeta[] {
|
|
const allPanels = config.panels;
|
|
|
|
return Object.keys(allPanels)
|
|
.filter((key) => allPanels[key]['hideFromList'] === false)
|
|
.map((key) => allPanels[key])
|
|
.sort((a: PanelPluginMeta, b: PanelPluginMeta) => a.sort - b.sort);
|
|
}
|
|
|
|
export function filterPluginList(
|
|
pluginsList: PanelPluginMeta[],
|
|
searchQuery: string, // Note: this will be an escaped regex string as it comes from `FilterInput`
|
|
current: PanelPluginMeta
|
|
): PanelPluginMeta[] {
|
|
if (!searchQuery.length) {
|
|
return pluginsList.filter((p) => {
|
|
if (p.state === PluginState.deprecated) {
|
|
return current.id === p.id;
|
|
}
|
|
return true;
|
|
});
|
|
}
|
|
|
|
const query = unEscapeStringFromRegex(searchQuery).toLowerCase();
|
|
const first: PanelPluginMeta[] = [];
|
|
const match: PanelPluginMeta[] = [];
|
|
const isGraphQuery = 'graph'.startsWith(query);
|
|
|
|
for (const item of pluginsList) {
|
|
if (item.state === PluginState.deprecated && current.id !== item.id) {
|
|
continue;
|
|
}
|
|
|
|
const name = item.name.toLowerCase();
|
|
const idx = name.indexOf(query);
|
|
|
|
if (idx === 0) {
|
|
first.push(item);
|
|
} else if (idx > 0) {
|
|
match.push(item);
|
|
} else if (isGraphQuery && item.id === 'timeseries') {
|
|
first.push(item);
|
|
}
|
|
}
|
|
|
|
return first.concat(match);
|
|
}
|