From 128468767afd048cbb5c7b5a1ef4b547febb7828 Mon Sep 17 00:00:00 2001 From: Walter Rafelsberger Date: Tue, 17 Aug 2021 14:52:54 +0200 Subject: [PATCH] [ML] Refactor fetchers to reduce state handlers. --- .../use_transaction_distribution_fetcher.ts | 116 +++++++++------- ...ransaction_latency_correlations_fetcher.ts | 129 ++++++++++-------- 2 files changed, 142 insertions(+), 103 deletions(-) diff --git a/x-pack/plugins/apm/public/hooks/use_transaction_distribution_fetcher.ts b/x-pack/plugins/apm/public/hooks/use_transaction_distribution_fetcher.ts index 006aea8600a35..9f39e6a01d065 100644 --- a/x-pack/plugins/apm/public/hooks/use_transaction_distribution_fetcher.ts +++ b/x-pack/plugins/apm/public/hooks/use_transaction_distribution_fetcher.ts @@ -30,6 +30,19 @@ interface RawResponse { ccsWarning: boolean; } +interface TransactionDistributionFetcherState { + error?: Error; + isComplete: boolean; + isRunning: boolean; + loaded: number; + ccsWarning: RawResponse['ccsWarning']; + log: RawResponse['log']; + transactionDistribution?: RawResponse['overallHistogram']; + percentileThresholdValue?: RawResponse['percentileThresholdValue']; + timeTook?: number; + total: number; +} + export function useTransactionDistributionFetcher( params: Omit ) { @@ -37,46 +50,50 @@ export function useTransactionDistributionFetcher( services: { data }, } = useKibana(); - const [error, setError] = useState(); - const [isComplete, setIsComplete] = useState(false); - const [isRunning, setIsRunning] = useState(false); - const [loaded, setLoaded] = useState(0); - - const [transactionDistribution, setTansactionDistribution] = useState< - RawResponse['overallHistogram'] - >(); - const [percentileThresholdValue, setPercentileThresholdValue] = useState< - RawResponse['percentileThresholdValue'] - >(); + const [ + fetchState, + setFetchState, + ] = useState({ + isComplete: false, + isRunning: false, + loaded: 0, + ccsWarning: false, + log: [], + total: 100, + }); - const [timeTook, setTimeTook] = useState(); - const [total, setTotal] = useState(100); const abortCtrl = useRef(new AbortController()); const searchSubscription$ = useRef(); function setResponse(response: IKibanaSearchResponse) { - setIsRunning(response.isRunning || false); - - // only set percentileThresholdValue and overallHistogram once it's repopulated on a refresh, - // otherwise the consuming chart would flicker with an empty state on reload. - if ( - response.rawResponse?.percentileThresholdValue !== undefined && + setFetchState((prevState) => ({ + ...prevState, + isRunning: response.isRunning || false, + ccsWarning: response.rawResponse?.ccsWarning ?? false, + histograms: response.rawResponse?.values ?? [], + log: response.rawResponse?.log ?? [], + loaded: response.loaded!, + total: response.total!, + timeTook: response.rawResponse.took, + // only set percentileThresholdValue and overallHistogram once it's repopulated on a refresh, + // otherwise the consuming chart would flicker with an empty state on reload. + ...(response.rawResponse?.percentileThresholdValue !== undefined && response.rawResponse?.overallHistogram !== undefined - ) { - setTansactionDistribution(response.rawResponse?.overallHistogram); - setPercentileThresholdValue( - response.rawResponse?.percentileThresholdValue - ); - } - - setLoaded(response.loaded!); - setTotal(response.total!); - setTimeTook(response.rawResponse.took); + ? { + transactionDistribution: response.rawResponse?.overallHistogram, + percentileThresholdValue: + response.rawResponse?.percentileThresholdValue, + } + : {}), + })); } const startFetch = () => { - setError(undefined); - setIsComplete(false); + setFetchState((prevState) => ({ + ...prevState, + error: undefined, + isComplete: false, + })); searchSubscription$.current?.unsubscribe(); abortCtrl.current.abort(); abortCtrl.current = new AbortController(); @@ -98,17 +115,26 @@ export function useTransactionDistributionFetcher( setResponse(res); if (isCompleteResponse(res)) { searchSubscription$.current?.unsubscribe(); - setIsRunning(false); - setIsComplete(true); + setFetchState((prevState) => ({ + ...prevState, + isRunnning: false, + isComplete: true, + })); } else if (isErrorResponse(res)) { searchSubscription$.current?.unsubscribe(); - setError((res as unknown) as Error); - setIsRunning(false); + setFetchState((prevState) => ({ + ...prevState, + error: (res as unknown) as Error, + setIsRunning: false, + })); } }, - error: (e: Error) => { - setError(e); - setIsRunning(false); + error: (error: Error) => { + setFetchState((prevState) => ({ + ...prevState, + error, + setIsRunning: false, + })); }, }); }; @@ -117,17 +143,15 @@ export function useTransactionDistributionFetcher( searchSubscription$.current?.unsubscribe(); searchSubscription$.current = undefined; abortCtrl.current.abort(); - setIsRunning(false); + setFetchState((prevState) => ({ + ...prevState, + setIsRunning: false, + })); }; return { - error, - percentileThresholdValue, - isComplete, - isRunning, - progress: loaded / total, - timeTook, - transactionDistribution, + ...fetchState, + progress: fetchState.loaded / fetchState.total, startFetch, cancelFetch, }; diff --git a/x-pack/plugins/apm/public/hooks/use_transaction_latency_correlations_fetcher.ts b/x-pack/plugins/apm/public/hooks/use_transaction_latency_correlations_fetcher.ts index 837b94fbabcab..538792bbf23a8 100644 --- a/x-pack/plugins/apm/public/hooks/use_transaction_latency_correlations_fetcher.ts +++ b/x-pack/plugins/apm/public/hooks/use_transaction_latency_correlations_fetcher.ts @@ -30,6 +30,20 @@ interface RawResponse { ccsWarning: boolean; } +interface TransactionLatencyCorrelationsFetcherState { + error?: Error; + isComplete: boolean; + isRunning: boolean; + loaded: number; + ccsWarning: RawResponse['ccsWarning']; + histograms: RawResponse['values']; + log: RawResponse['log']; + overallHistogram?: RawResponse['overallHistogram']; + percentileThresholdValue?: RawResponse['percentileThresholdValue']; + timeTook?: number; + total: number; +} + export const useTransactionLatencyCorrelationsFetcher = ( params: Omit ) => { @@ -37,54 +51,51 @@ export const useTransactionLatencyCorrelationsFetcher = ( services: { data }, } = useKibana(); - const [error, setError] = useState(); - const [isComplete, setIsComplete] = useState(false); - const [isRunning, setIsRunning] = useState(false); - const [loaded, setLoaded] = useState(0); - - const [ccsWarning, setCcsWarning] = useState( - false - ); - const [histograms, setHistograms] = useState([]); - const [log, setLog] = useState([]); - const [overallHistogram, setOverallHistogram] = useState< - RawResponse['overallHistogram'] - >(); - const [percentileThresholdValue, setPercentileThresholdValue] = useState< - RawResponse['percentileThresholdValue'] - >(); + const [ + fetchState, + setFetchState, + ] = useState({ + isComplete: false, + isRunning: false, + loaded: 0, + ccsWarning: false, + histograms: [], + log: [], + total: 100, + }); - const [timeTook, setTimeTook] = useState(); - const [total, setTotal] = useState(100); const abortCtrl = useRef(new AbortController()); const searchSubscription$ = useRef(); function setResponse(response: IKibanaSearchResponse) { - setIsRunning(response.isRunning || false); - setCcsWarning(response.rawResponse?.ccsWarning ?? false); - setHistograms(response.rawResponse?.values ?? []); - setLog(response.rawResponse?.log ?? []); - - // only set percentileThresholdValue and overallHistogram once it's repopulated on a refresh, - // otherwise the consuming chart would flicker with an empty state on reload. - if ( - response.rawResponse?.percentileThresholdValue !== undefined && + setFetchState((prevState) => ({ + ...prevState, + isRunning: response.isRunning || false, + ccsWarning: response.rawResponse?.ccsWarning ?? false, + histograms: response.rawResponse?.values ?? [], + log: response.rawResponse?.log ?? [], + loaded: response.loaded!, + total: response.total!, + timeTook: response.rawResponse.took, + // only set percentileThresholdValue and overallHistogram once it's repopulated on a refresh, + // otherwise the consuming chart would flicker with an empty state on reload. + ...(response.rawResponse?.percentileThresholdValue !== undefined && response.rawResponse?.overallHistogram !== undefined - ) { - setOverallHistogram(response.rawResponse?.overallHistogram); - setPercentileThresholdValue( - response.rawResponse?.percentileThresholdValue - ); - } - - setLoaded(response.loaded!); - setTotal(response.total!); - setTimeTook(response.rawResponse.took); + ? { + overallHistogram: response.rawResponse?.overallHistogram, + percentileThresholdValue: + response.rawResponse?.percentileThresholdValue, + } + : {}), + })); } const startFetch = () => { - setError(undefined); - setIsComplete(false); + setFetchState((prevState) => ({ + ...prevState, + error: undefined, + isComplete: false, + })); searchSubscription$.current?.unsubscribe(); abortCtrl.current.abort(); abortCtrl.current = new AbortController(); @@ -106,17 +117,26 @@ export const useTransactionLatencyCorrelationsFetcher = ( setResponse(res); if (isCompleteResponse(res)) { searchSubscription$.current?.unsubscribe(); - setIsRunning(false); - setIsComplete(true); + setFetchState((prevState) => ({ + ...prevState, + isRunnning: false, + isComplete: true, + })); } else if (isErrorResponse(res)) { searchSubscription$.current?.unsubscribe(); - setError((res as unknown) as Error); - setIsRunning(false); + setFetchState((prevState) => ({ + ...prevState, + error: (res as unknown) as Error, + setIsRunning: false, + })); } }, - error: (e: Error) => { - setError(e); - setIsRunning(false); + error: (error: Error) => { + setFetchState((prevState) => ({ + ...prevState, + error, + setIsRunning: false, + })); }, }); }; @@ -125,20 +145,15 @@ export const useTransactionLatencyCorrelationsFetcher = ( searchSubscription$.current?.unsubscribe(); searchSubscription$.current = undefined; abortCtrl.current.abort(); - setIsRunning(false); + setFetchState((prevState) => ({ + ...prevState, + setIsRunning: false, + })); }; return { - ccsWarning, - log, - error, - histograms, - percentileThresholdValue, - overallHistogram, - isComplete, - isRunning, - progress: loaded / total, - timeTook, + ...fetchState, + progress: fetchState.loaded / fetchState.total, startFetch, cancelFetch, };