mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* Refactor: Makes PanelEditor use state and shows validation message on AlerTab * Refactor: Makes validation message nicer looking * Refactor: Changes imports * Refactor: Removes conditional props * Refactor: Changes after feedback from PR review * Refactor: Removes unused action
50 lines
1.4 KiB
TypeScript
50 lines
1.4 KiB
TypeScript
import { DataQuery } from '@grafana/ui';
|
|
import { DataSourceSrv } from '@grafana/runtime';
|
|
import { DataTransformerConfig } from '@grafana/data';
|
|
|
|
export const getDefaultCondition = () => ({
|
|
type: 'query',
|
|
query: { params: ['A', '5m', 'now'] },
|
|
reducer: { type: 'avg', params: [] as any[] },
|
|
evaluator: { type: 'gt', params: [null] as any[] },
|
|
operator: { type: 'and' },
|
|
});
|
|
|
|
export const getAlertingValidationMessage = async (
|
|
transformations: DataTransformerConfig[],
|
|
targets: DataQuery[],
|
|
datasourceSrv: DataSourceSrv,
|
|
datasourceName: string
|
|
): Promise<string> => {
|
|
if (targets.length === 0) {
|
|
return 'Could not find any metric queries';
|
|
}
|
|
|
|
if (transformations && transformations.length) {
|
|
return 'Transformations are not supported in alert queries';
|
|
}
|
|
|
|
let alertingNotSupported = 0;
|
|
let templateVariablesNotSupported = 0;
|
|
|
|
for (const target of targets) {
|
|
const dsName = target.datasource || datasourceName;
|
|
const ds = await datasourceSrv.get(dsName);
|
|
if (!ds.meta.alerting) {
|
|
alertingNotSupported++;
|
|
} else if (ds.targetContainsTemplate && ds.targetContainsTemplate(target)) {
|
|
templateVariablesNotSupported++;
|
|
}
|
|
}
|
|
|
|
if (alertingNotSupported === targets.length) {
|
|
return 'The datasource does not support alerting queries';
|
|
}
|
|
|
|
if (templateVariablesNotSupported === targets.length) {
|
|
return 'Template variables are not supported in alert queries';
|
|
}
|
|
|
|
return '';
|
|
};
|