From 756968a491095f82521cef9e41d61391ac462b20 Mon Sep 17 00:00:00 2001 From: JulesVautier-io Date: Tue, 18 Jun 2024 16:26:37 +0200 Subject: [PATCH] Fix the render side-effect by using the useEffect feature --- .../components/QueryEditor/AggregationEditor.tsx | 14 ++++++++++++-- .../src/components/SearchResult/SearchResult.tsx | 2 -- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/quickwit/quickwit-ui/src/components/QueryEditor/AggregationEditor.tsx b/quickwit/quickwit-ui/src/components/QueryEditor/AggregationEditor.tsx index a04bf5f9458..a4d4ed2bd4c 100644 --- a/quickwit/quickwit-ui/src/components/QueryEditor/AggregationEditor.tsx +++ b/quickwit/quickwit-ui/src/components/QueryEditor/AggregationEditor.tsx @@ -17,7 +17,7 @@ // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . -import { useRef, useState } from 'react'; +import { useRef, useEffect, useState } from 'react'; import { SearchComponentProps } from '../../utils/SearchComponentProps'; import { TermAgg, HistogramAgg } from '../../utils/models'; import { Box } from '@mui/material'; @@ -107,13 +107,23 @@ export function AggregationKind(props: SearchComponentProps) { const [aggregations, setAggregations] = useState<({term: TermAgg} | {histogram: HistogramAgg})[]>( [defaultAgg]); + useEffect(() => { + // do the initial filling of parameters + const aggregationConfig = props.searchRequest.aggregationConfig; + if (aggregationConfig.histogram === null && aggregationConfig.term === null) { + const initialAggregation = Object.assign({}, ...aggregations); + const initialSearchRequest = {...props.searchRequest, aggregationConfig: initialAggregation}; + props.onSearchRequestUpdate(initialSearchRequest); + } + }, []); // Empty dependency array means this runs once after mount + const updateAggregationProp = (newAggregations: ({term: TermAgg} | {histogram: HistogramAgg})[]) => { const metric = props.searchRequest.aggregationConfig.metric; const updatedAggregation = Object.assign({}, {metric: metric}, ...newAggregations); const updatedSearchRequest = {...props.searchRequest, aggregationConfig: updatedAggregation}; props.onSearchRequestUpdate(updatedSearchRequest); }; - + const handleAggregationChange = (pos: number, event: SelectChangeEvent) => { const value = event.target.value; setAggregations((agg) => { diff --git a/quickwit/quickwit-ui/src/components/SearchResult/SearchResult.tsx b/quickwit/quickwit-ui/src/components/SearchResult/SearchResult.tsx index 19ea6469feb..74eb10d812e 100644 --- a/quickwit/quickwit-ui/src/components/SearchResult/SearchResult.tsx +++ b/quickwit/quickwit-ui/src/components/SearchResult/SearchResult.tsx @@ -72,10 +72,8 @@ export default function SearchResult(props: SearchResultProps) { if (props.searchResponse == null || props.index == null) { return null; } else if (props.searchResponse.aggregations === undefined) { - console.log("result table"); return (); } else { - console.log("aggregation result"); return (); } },