grafana/public/app/features/datasources/state/selectors.ts

38 lines
1.4 KiB
TypeScript
Raw Normal View History

import { DataSourcePluginMeta, DataSourceSettings, UrlQueryValue } from '@grafana/data';
import { DataSourcesState } from '../../../types/datasources';
2018-10-08 07:09:02 -05:00
export const getDataSources = (state: DataSourcesState) => {
const regex = new RegExp(state.searchQuery, 'i');
return state.dataSources.filter((dataSource: DataSourceSettings) => {
return regex.test(dataSource.name) || regex.test(dataSource.database) || regex.test(dataSource.type);
});
};
export const getDataSourcePlugins = (state: DataSourcesState) => {
2018-10-04 04:42:17 -05:00
const regex = new RegExp(state.dataSourceTypeSearchQuery, 'i');
return state.plugins.filter((type: DataSourcePluginMeta) => {
2018-10-04 04:42:17 -05:00
return regex.test(type.name);
});
};
export const getDataSource = (state: DataSourcesState, dataSourceId: UrlQueryValue): DataSourceSettings => {
if (state.dataSource.uid === dataSourceId) {
2018-10-08 07:09:02 -05:00
return state.dataSource;
}
return {} as DataSourceSettings;
2018-10-08 07:09:02 -05:00
};
export const getDataSourceMeta = (state: DataSourcesState, type: string): DataSourcePluginMeta => {
2018-10-31 07:23:05 -05:00
if (state.dataSourceMeta.id === type) {
return state.dataSourceMeta;
}
return {} as DataSourcePluginMeta;
2018-10-31 07:23:05 -05:00
};
export const getDataSourcesSearchQuery = (state: DataSourcesState) => state.searchQuery;
export const getDataSourcesLayoutMode = (state: DataSourcesState) => state.layoutMode;
export const getDataSourcesCount = (state: DataSourcesState) => state.dataSourcesCount;