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/datasource/loki/querybuilder/state.ts

82 lines
2.4 KiB

import { useCallback, useState } from 'react';
import store from 'app/core/store';
import { QueryEditorMode } from '../../prometheus/querybuilder/shared/types';
import { LokiQuery, LokiQueryType } from '../types';
const queryEditorModeDefaultLocalStorageKey = 'LokiQueryEditorModeDefault';
export function changeEditorMode(query: LokiQuery, editorMode: QueryEditorMode, onChange: (query: LokiQuery) => void) {
// If empty query store new mode as default
if (query.expr === '') {
store.set(queryEditorModeDefaultLocalStorageKey, editorMode);
}
onChange({ ...query, editorMode });
}
export function getDefaultEditorMode(expr: string) {
// If we already have an expression default to code view
if (expr != null && expr !== '') {
return QueryEditorMode.Code;
}
const value = store.get(queryEditorModeDefaultLocalStorageKey) as QueryEditorMode;
switch (value) {
case QueryEditorMode.Builder:
case QueryEditorMode.Code:
case QueryEditorMode.Explain:
return value;
default:
return QueryEditorMode.Builder;
}
}
/**
* Returns query with defaults, and boolean true/false depending on change was required
*/
export function getQueryWithDefaults(query: LokiQuery): LokiQuery {
// If no expr (ie new query) then default to builder
let result = query;
if (!query.editorMode) {
result = { ...query, editorMode: getDefaultEditorMode(query.expr) };
}
if (query.expr == null) {
result = { ...result, expr: '' };
}
if (query.queryType == null) {
// Default to range query
result = { ...result, queryType: LokiQueryType.Range };
}
return result;
}
const queryEditorRawQueryLocalStorageKey = 'LokiQueryEditorRawQueryDefault';
function getRawQueryVisibility(): boolean {
const val = store.get(queryEditorRawQueryLocalStorageKey);
return val === undefined ? true : Boolean(parseInt(val, 10));
}
function setRawQueryVisibility(value: boolean) {
store.set(queryEditorRawQueryLocalStorageKey, value ? '1' : '0');
}
/**
* Use and store value of raw query switch in local storage.
* Needs to be a hook with local state to trigger rerenders.
*/
export function useRawQuery(): [boolean, (val: boolean) => void] {
const [rawQuery, setRawQuery] = useState(getRawQueryVisibility());
const setter = useCallback((value: boolean) => {
setRawQueryVisibility(value);
setRawQuery(value);
}, []);
return [rawQuery, setter];
}