2025-05-11 17:47:30 +05:30
|
|
|
import './QueryBuilderV2.styles.scss';
|
|
|
|
|
|
2025-05-25 18:43:36 +05:30
|
|
|
import { OPERATORS } from 'constants/queryBuilder';
|
|
|
|
|
import { QueryBuilderProps } from 'container/QueryBuilder/QueryBuilder.interfaces';
|
|
|
|
|
import { useMemo } from 'react';
|
2025-05-16 02:48:03 +05:30
|
|
|
import { IBuilderQuery } from 'types/api/queryBuilder/queryBuilderData';
|
|
|
|
|
import { DataSource } from 'types/common/queryBuilder';
|
2025-05-11 17:47:30 +05:30
|
|
|
|
2025-05-25 18:43:36 +05:30
|
|
|
import { LogsQB } from './Logs/LogsQB';
|
2025-05-16 15:07:00 +05:30
|
|
|
import MetricsQB from './Metrics/MetricsQB';
|
2025-05-14 16:43:28 +05:30
|
|
|
import { QueryBuilderV2Provider } from './QueryBuilderV2Context';
|
2025-05-16 15:07:00 +05:30
|
|
|
import TracesQB from './Traces/TracesQB';
|
2025-04-26 23:53:30 +05:30
|
|
|
|
2025-05-16 02:48:03 +05:30
|
|
|
type QueryBuilderV2Props = {
|
|
|
|
|
source: DataSource;
|
|
|
|
|
query: IBuilderQuery;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
function QueryBuilderV2Main({
|
|
|
|
|
source,
|
|
|
|
|
query,
|
|
|
|
|
}: QueryBuilderV2Props): JSX.Element {
|
2025-05-16 15:07:00 +05:30
|
|
|
const isMetricsDataSource = source === DataSource.METRICS;
|
|
|
|
|
const isLogsDataSource = source === DataSource.LOGS;
|
|
|
|
|
const isTracesDataSource = source === DataSource.TRACES;
|
2025-05-11 17:47:30 +05:30
|
|
|
|
2025-05-25 18:43:36 +05:30
|
|
|
const listViewLogFilterConfigs: QueryBuilderProps['filterConfigs'] = useMemo(() => {
|
|
|
|
|
const config: QueryBuilderProps['filterConfigs'] = {
|
|
|
|
|
stepInterval: { isHidden: true, isDisabled: true },
|
|
|
|
|
having: { isHidden: true, isDisabled: true },
|
|
|
|
|
filters: {
|
|
|
|
|
customKey: 'body',
|
|
|
|
|
customOp: OPERATORS.CONTAINS,
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return config;
|
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
|
|
const listViewTracesFilterConfigs: QueryBuilderProps['filterConfigs'] = useMemo(() => {
|
|
|
|
|
const config: QueryBuilderProps['filterConfigs'] = {
|
|
|
|
|
stepInterval: { isHidden: true, isDisabled: true },
|
|
|
|
|
having: { isHidden: true, isDisabled: true },
|
|
|
|
|
limit: { isHidden: true, isDisabled: true },
|
|
|
|
|
filters: {
|
|
|
|
|
customKey: 'body',
|
|
|
|
|
customOp: OPERATORS.CONTAINS,
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return config;
|
|
|
|
|
}, []);
|
|
|
|
|
|
2025-04-26 23:53:30 +05:30
|
|
|
return (
|
|
|
|
|
<div className="query-builder-v2">
|
2025-05-16 15:07:00 +05:30
|
|
|
{isMetricsDataSource ? <MetricsQB query={query} /> : null}
|
2025-05-25 18:43:36 +05:30
|
|
|
{isLogsDataSource ? (
|
|
|
|
|
<LogsQB
|
|
|
|
|
query={query}
|
|
|
|
|
filterConfigs={
|
|
|
|
|
query.dataSource === DataSource.TRACES
|
|
|
|
|
? listViewTracesFilterConfigs
|
|
|
|
|
: listViewLogFilterConfigs
|
|
|
|
|
}
|
|
|
|
|
/>
|
|
|
|
|
) : null}
|
2025-05-16 15:07:00 +05:30
|
|
|
{isTracesDataSource ? <TracesQB query={query} /> : null}
|
2025-04-26 23:53:30 +05:30
|
|
|
</div>
|
|
|
|
|
);
|
2025-04-26 20:44:43 +05:30
|
|
|
}
|
|
|
|
|
|
2025-05-16 02:48:03 +05:30
|
|
|
function QueryBuilderV2(props: QueryBuilderV2Props): JSX.Element {
|
|
|
|
|
const { source, query } = props;
|
|
|
|
|
|
2025-05-14 16:43:28 +05:30
|
|
|
return (
|
|
|
|
|
<QueryBuilderV2Provider>
|
2025-05-16 02:48:03 +05:30
|
|
|
<QueryBuilderV2Main source={source} query={query} />
|
2025-05-14 16:43:28 +05:30
|
|
|
</QueryBuilderV2Provider>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2025-04-26 20:44:43 +05:30
|
|
|
export default QueryBuilderV2;
|