1
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.
 
 
 
 
 
 

18 lines
756 B

import { useMemo } from 'react';
import { useQuery } from '../components/QueryEditor/ElasticsearchQueryContext';
import { BucketAggregation } from '../components/QueryEditor/BucketAggregationsEditor/aggregations';
import { MetricAggregation } from '../components/QueryEditor/MetricAggregationsEditor/aggregations';
const toId = <T extends { id: unknown }>(e: T): T['id'] => e.id;
const toInt = (idString: string) => parseInt(idString, 10);
export const useNextId = (): MetricAggregation['id'] | BucketAggregation['id'] => {
const { metrics, bucketAggs } = useQuery();
return useMemo(
() =>
(Math.max(...[...(metrics?.map(toId) || ['0']), ...(bucketAggs?.map(toId) || ['0'])].map(toInt)) + 1).toString(),
[metrics, bucketAggs]
);
};