Files
Josh Hunt 3c6e0e8ef8 Chore: ESlint import order (#44959)
* Add and configure eslint-plugin-import

* Fix the lint:ts npm command

* Autofix + prettier all the files

* Manually fix remaining files

* Move jquery code in jest-setup to external file to safely reorder imports

* Resolve issue caused by circular dependencies within Prometheus

* Update .betterer.results

* Fix missing // @ts-ignore

* ignore iconBundle.ts

* Fix missing // @ts-ignore
2022-04-22 14:33:13 +01:00

86 lines
2.2 KiB
TypeScript

import { Observable, of } from 'rxjs';
import { catchError, map, share } from 'rxjs/operators';
import {
dataFrameFromJSON,
DataFrameJSON,
getDefaultTimeRange,
LoadingState,
PanelData,
withLoadingIndicator,
} from '@grafana/data';
import { getBackendSrv, toDataQueryError } from '@grafana/runtime';
import {
CloudPreviewRuleRequest,
GrafanaPreviewRuleRequest,
isCloudPreviewRequest,
isGrafanaPreviewRequest,
PreviewRuleRequest,
PreviewRuleResponse,
} from '../types/preview';
import { RuleFormType } from '../types/rule-form';
export function previewAlertRule(request: PreviewRuleRequest): Observable<PreviewRuleResponse> {
if (isCloudPreviewRequest(request)) {
return previewCloudAlertRule(request);
}
if (isGrafanaPreviewRequest(request)) {
return previewGrafanaAlertRule(request);
}
throw new Error('unsupported preview rule request');
}
type GrafanaPreviewRuleResponse = {
instances: DataFrameJSON[];
};
function previewGrafanaAlertRule(request: GrafanaPreviewRuleRequest): Observable<PreviewRuleResponse> {
const type = RuleFormType.grafana;
return withLoadingIndicator({
whileLoading: createResponse(type),
source: getBackendSrv()
.fetch<GrafanaPreviewRuleResponse>({
method: 'POST',
url: `/api/v1/rule/test/grafana`,
data: request,
})
.pipe(
map(({ data }) => {
return createResponse(type, {
state: LoadingState.Done,
series: data.instances.map(dataFrameFromJSON),
});
}),
catchError((error: Error) => {
return of(
createResponse(type, {
state: LoadingState.Error,
error: toDataQueryError(error),
})
);
}),
share()
),
});
}
function createResponse(ruleType: RuleFormType, data: Partial<PanelData> = {}): PreviewRuleResponse {
return {
ruleType,
data: {
state: LoadingState.Loading,
series: [],
timeRange: getDefaultTimeRange(),
...data,
},
};
}
function previewCloudAlertRule(request: CloudPreviewRuleRequest): Observable<PreviewRuleResponse> {
throw new Error('preview for cloud alerting rules is not implemented');
}