From ed14848de40a385d9d0d32d90a3283b2a77ea2e3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20Oberm=C3=BCller?= Date: Fri, 20 Dec 2024 13:17:03 +0100 Subject: [PATCH] fix(funnels): memoize getPathUrl in FunnelStepMore (#27053) --- .../src/scenes/funnels/FunnelStepMore.tsx | 52 ++++++++++--------- 1 file changed, 27 insertions(+), 25 deletions(-) diff --git a/frontend/src/scenes/funnels/FunnelStepMore.tsx b/frontend/src/scenes/funnels/FunnelStepMore.tsx index 609efa4b9b2ef..4ee1c82e5a672 100644 --- a/frontend/src/scenes/funnels/FunnelStepMore.tsx +++ b/frontend/src/scenes/funnels/FunnelStepMore.tsx @@ -1,6 +1,7 @@ import { useValues } from 'kea' import { LemonButton } from 'lib/lemon-ui/LemonButton' import { More } from 'lib/lemon-ui/LemonButton/More' +import { useCallback } from 'react' import { insightLogic } from 'scenes/insights/insightLogic' import { urls } from 'scenes/urls' @@ -17,34 +18,35 @@ export function FunnelStepMore({ stepIndex }: FunnelStepMoreProps): JSX.Element const { insightProps } = useValues(insightLogic) const { querySource } = useValues(funnelDataLogic(insightProps)) - const aggregationGroupTypeIndex = querySource?.aggregation_group_type_index - - // Don't show paths modal if aggregating by groups - paths is user-based! - if (aggregationGroupTypeIndex != undefined) { - return null - } - const stepNumber = stepIndex + 1 - const getPathUrl = (funnelPathType: FunnelPathType, dropOff = false): string => { - const query: InsightVizNode = { - kind: NodeKind.InsightVizNode, - source: { - kind: NodeKind.PathsQuery, - funnelPathsFilter: { - funnelStep: dropOff ? stepNumber * -1 : stepNumber, - funnelSource: querySource!, - funnelPathType, - }, - pathsFilter: { - includeEventTypes: [PathType.PageView, PathType.CustomEvent], + const getPathUrl = useCallback( + (funnelPathType: FunnelPathType, dropOff = false): string => { + const query: InsightVizNode = { + kind: NodeKind.InsightVizNode, + source: { + kind: NodeKind.PathsQuery, + funnelPathsFilter: { + funnelStep: dropOff ? stepNumber * -1 : stepNumber, + funnelSource: querySource!, + funnelPathType, + }, + pathsFilter: { + includeEventTypes: [PathType.PageView, PathType.CustomEvent], + }, + dateRange: { + date_from: querySource?.dateRange?.date_from, + }, }, - dateRange: { - date_from: querySource?.dateRange?.date_from, - }, - }, - } + } + + return urls.insightNew(undefined, undefined, query) + }, + [querySource, stepNumber] + ) - return urls.insightNew(undefined, undefined, query) + // Don't show paths modal if aggregating by groups - paths is user-based! + if (querySource?.aggregation_group_type_index != undefined) { + return null } return (