1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- import {useCallback, useMemo} from 'react';
- import {unescapeMetricsFormula} from 'sentry/utils/metrics';
- import {
- isMetricsEquationWidget,
- isMetricsQueryWidget,
- type MetricsQueryWidget,
- } from 'sentry/utils/metrics/types';
- import {useMetricsContext} from 'sentry/views/metrics/context';
- import {parseFormula} from 'sentry/views/metrics/formulaParser/parser';
- import {type TokenList, TokenType} from 'sentry/views/metrics/formulaParser/types';
- import {getQuerySymbol} from 'sentry/views/metrics/querySymbol';
- interface FormulaDependencies {
- dependencies: MetricsQueryWidget[];
- isError: boolean;
- }
- export function useFormulaDependencies() {
- const {widgets} = useMetricsContext();
- const queriesLookup = useMemo(() => {
- const lookup = new Map<string, MetricsQueryWidget>();
- widgets.forEach(widget => {
- if (isMetricsQueryWidget(widget)) {
- lookup.set(getQuerySymbol(widget.id), widget);
- }
- });
- return lookup;
- }, [widgets]);
- const getFormulaQueryDependencies = useCallback(
- (formula: string): FormulaDependencies => {
- let tokens: TokenList = [];
- try {
- tokens = parseFormula(unescapeMetricsFormula(formula));
- } catch {
- // We should not end up here, but if we do, we should not crash the UI
- return {dependencies: [], isError: true};
- }
- const dependencies: MetricsQueryWidget[] = [];
- let isError = false;
- tokens.forEach(token => {
- if (token.type === TokenType.VARIABLE) {
- const widget = queriesLookup.get(token.content);
- if (widget) {
- dependencies.push(widget);
- } else {
- isError = true;
- }
- }
- });
- return {dependencies, isError};
- },
- [queriesLookup]
- );
- const formulaDependencies = useMemo(() => {
- return widgets.reduce((acc: Record<number, FormulaDependencies>, widget) => {
- if (isMetricsEquationWidget(widget)) {
- acc[widget.id] = getFormulaQueryDependencies(widget.formula);
- }
- return acc;
- }, {});
- }, [getFormulaQueryDependencies, widgets]);
- return formulaDependencies;
- }
|