grafana/public/app/features/explore/TraceView/useDetailState.ts
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

121 lines
4.0 KiB
TypeScript

import { TraceLog, TraceSpanReference } from '@jaegertracing/jaeger-ui-components/src/types/trace';
import { useCallback, useState, useEffect } from 'react';
import { DataFrame } from '@grafana/data';
import { DetailState } from '@jaegertracing/jaeger-ui-components';
/**
* Keeps state of the span detail. This means whether span details are open but also state of each detail subitem
* like logs or tags.
*/
export function useDetailState(frame: DataFrame) {
const [detailStates, setDetailStates] = useState(new Map<string, DetailState>());
// Clear detail state when new trace arrives
useEffect(() => {
setDetailStates(new Map<string, DetailState>());
}, [frame, setDetailStates]);
const toggleDetail = useCallback(
function toggleDetail(spanID: string) {
const newDetailStates = new Map(detailStates);
if (newDetailStates.has(spanID)) {
newDetailStates.delete(spanID);
} else {
newDetailStates.set(spanID, new DetailState());
}
setDetailStates(newDetailStates);
},
[detailStates]
);
const detailLogItemToggle = useCallback(
function detailLogItemToggle(spanID: string, log: TraceLog) {
const old = detailStates.get(spanID);
if (!old) {
return;
}
const detailState = old.toggleLogItem(log);
const newDetailStates = new Map(detailStates);
newDetailStates.set(spanID, detailState);
return setDetailStates(newDetailStates);
},
[detailStates]
);
const detailReferenceItemToggle = useCallback(
function detailReferenceItemToggle(spanID: string, reference: TraceSpanReference) {
const old = detailStates.get(spanID);
if (!old) {
return;
}
const detailState = old.toggleReferenceItem(reference);
const newDetailStates = new Map(detailStates);
newDetailStates.set(spanID, detailState);
return setDetailStates(newDetailStates);
},
[detailStates]
);
return {
detailStates,
toggleDetail,
detailLogItemToggle,
detailLogsToggle: useCallback(
(spanID: string) => makeDetailSubsectionToggle('logs', detailStates, setDetailStates)(spanID),
[detailStates]
),
detailWarningsToggle: useCallback(
(spanID: string) => makeDetailSubsectionToggle('warnings', detailStates, setDetailStates)(spanID),
[detailStates]
),
detailStackTracesToggle: useCallback(
(spanID: string) => makeDetailSubsectionToggle('stackTraces', detailStates, setDetailStates)(spanID),
[detailStates]
),
detailReferenceItemToggle,
detailReferencesToggle: useCallback(
(spanID: string) => makeDetailSubsectionToggle('references', detailStates, setDetailStates)(spanID),
[detailStates]
),
detailProcessToggle: useCallback(
(spanID: string) => makeDetailSubsectionToggle('process', detailStates, setDetailStates)(spanID),
[detailStates]
),
detailTagsToggle: useCallback(
(spanID: string) => makeDetailSubsectionToggle('tags', detailStates, setDetailStates)(spanID),
[detailStates]
),
};
}
function makeDetailSubsectionToggle(
subSection: 'tags' | 'process' | 'logs' | 'warnings' | 'references' | 'stackTraces',
detailStates: Map<string, DetailState>,
setDetailStates: (detailStates: Map<string, DetailState>) => void
) {
return (spanID: string) => {
const old = detailStates.get(spanID);
if (!old) {
return;
}
let detailState;
if (subSection === 'tags') {
detailState = old.toggleTags();
} else if (subSection === 'process') {
detailState = old.toggleProcess();
} else if (subSection === 'warnings') {
detailState = old.toggleWarnings();
} else if (subSection === 'references') {
detailState = old.toggleReferences();
} else if (subSection === 'stackTraces') {
detailState = old.toggleStackTraces();
} else {
detailState = old.toggleLogs();
}
const newDetailStates = new Map(detailStates);
newDetailStates.set(spanID, detailState);
setDetailStates(newDetailStates);
};
}