Skip to content

Commit

Permalink
Fix the render side-effect by using the useEffect feature
Browse files Browse the repository at this point in the history
  • Loading branch information
JulesVautier-io committed Jun 20, 2024
1 parent 91e2256 commit bccdf7b
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.

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';
Expand Down Expand Up @@ -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) => {
Expand Down Expand Up @@ -151,6 +161,7 @@ export function AggregationKind(props: SearchComponentProps) {
const newAggregations = [...agg];
newAggregations[pos] = {histogram: {interval:value}};
updateAggregationProp(newAggregations);
props.runSearch(props.searchRequest)
return newAggregations;
});
}
Expand Down Expand Up @@ -229,14 +240,6 @@ export function AggregationKind(props: SearchComponentProps) {
return options;
}

// 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);
}

const drawAdditional = (pos: number, aggs: ({term: TermAgg} | {histogram: HistogramAgg})[]) => {
const agg = aggs[pos]
if (isHistogram(agg)) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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 (<ResultTable searchResponse={props.searchResponse} index={props.index} />);
} else {
console.log("aggregation result");
return (<AggregationResult searchResponse={props.searchResponse} />);
}
},
Expand Down

0 comments on commit bccdf7b

Please sign in to comment.