Skip to content

Commit

Permalink
Merge pull request Expensify#34422 from callstack-internal/hur/perf/s…
Browse files Browse the repository at this point in the history
…mooth-search-transition

perf: smooth search transition
  • Loading branch information
mountiny authored Feb 13, 2024
2 parents 774f91b + a3393f8 commit 3a702ce
Show file tree
Hide file tree
Showing 6 changed files with 22 additions and 17 deletions.
4 changes: 2 additions & 2 deletions src/components/LHNOptionsList/LHNOptionsList.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import {FlashList} from '@shopify/flash-list';
import type {ReactElement} from 'react';
import React, {useCallback} from 'react';
import React, {memo, useCallback} from 'react';
import {StyleSheet, View} from 'react-native';
import {withOnyx} from 'react-native-onyx';
import withCurrentReportID from '@components/withCurrentReportID';
Expand Down Expand Up @@ -158,7 +158,7 @@ export default withCurrentReportID(
transactionViolations: {
key: ONYXKEYS.COLLECTION.TRANSACTION_VIOLATIONS,
},
})(LHNOptionsList),
})(memo(LHNOptionsList)),
);

export type {LHNOptionsListProps};
8 changes: 5 additions & 3 deletions src/components/OptionsList/BaseOptionsList.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import isEqual from 'lodash/isEqual';
import type {ForwardedRef} from 'react';
import React, {forwardRef, memo, useEffect, useRef} from 'react';
import React, {forwardRef, memo, useEffect, useMemo, useRef} from 'react';
import type {SectionListRenderItem} from 'react-native';
import {View} from 'react-native';
import OptionRow from '@components/OptionRow';
Expand Down Expand Up @@ -31,7 +31,7 @@ function BaseOptionsList(
shouldHaveOptionSeparator = false,
showTitleTooltip = false,
optionHoveredStyle,
contentContainerStyles,
contentContainerStyles: contentContainerStylesProp,
sectionHeaderStyle,
showScrollIndicator = true,
listContainerStyles: listContainerStylesProp,
Expand All @@ -51,6 +51,7 @@ function BaseOptionsList(
nestedScrollEnabled = true,
bounces = true,
renderFooterContent,
safeAreaPaddingBottomStyle,
}: BaseOptionListProps,
ref: ForwardedRef<OptionsList>,
) {
Expand All @@ -64,7 +65,8 @@ function BaseOptionsList(
const previousSections = usePrevious<OptionsListData[]>(sections);
const didLayout = useRef(false);

const listContainerStyles = listContainerStylesProp ?? [styles.flex1];
const listContainerStyles = useMemo(() => listContainerStylesProp ?? [styles.flex1], [listContainerStylesProp, styles.flex1]);
const contentContainerStyles = useMemo(() => [safeAreaPaddingBottomStyle, contentContainerStylesProp], [contentContainerStylesProp, safeAreaPaddingBottomStyle]);

/**
* This helper function is used to memoize the computation needed for getItemLayout. It is run whenever section data changes.
Expand Down
2 changes: 1 addition & 1 deletion src/components/OptionsList/index.native.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ function OptionsList(props: OptionsListProps, ref: ForwardedRef<OptionsListType>
// eslint-disable-next-line react/jsx-props-no-spreading
{...props}
ref={ref}
onScrollBeginDrag={() => Keyboard.dismiss()}
onScrollBeginDrag={Keyboard.dismiss}
/>
);
}
Expand Down
4 changes: 2 additions & 2 deletions src/pages/home/report/ReportActionsList.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import {useRoute} from '@react-navigation/native';
import lodashGet from 'lodash/get';
import PropTypes from 'prop-types';
import React, {useCallback, useEffect, useMemo, useRef, useState} from 'react';
import React, {memo, useCallback, useEffect, useMemo, useRef, useState} from 'react';
import {DeviceEventEmitter, InteractionManager} from 'react-native';
import Animated, {useAnimatedStyle, useSharedValue, withTiming} from 'react-native-reanimated';
import _ from 'underscore';
Expand Down Expand Up @@ -515,4 +515,4 @@ ReportActionsList.propTypes = propTypes;
ReportActionsList.defaultProps = defaultProps;
ReportActionsList.displayName = 'ReportActionsList';

export default compose(withWindowDimensions, withCurrentUserPersonalDetails)(ReportActionsList);
export default compose(withWindowDimensions, withCurrentUserPersonalDetails)(memo(ReportActionsList));
14 changes: 7 additions & 7 deletions src/pages/home/report/ReportActionsView.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import {useIsFocused} from '@react-navigation/native';
import lodashGet from 'lodash/get';
import PropTypes from 'prop-types';
import React, {useContext, useEffect, useMemo, useRef} from 'react';
import React, {useCallback, useContext, useEffect, useMemo, useRef} from 'react';
import {withOnyx} from 'react-native-onyx';
import _ from 'underscore';
import networkPropTypes from '@components/networkPropTypes';
Expand Down Expand Up @@ -173,25 +173,25 @@ function ReportActionsView(props) {
}
}, [props.report.pendingFields, didSubscribeToReportTypingEvents, reportID]);

const oldestReportAction = useMemo(() => _.last(props.reportActions), [props.reportActions]);

/**
* Retrieves the next set of report actions for the chat once we are nearing the end of what we are currently
* displaying.
*/
const loadOlderChats = () => {
const loadOlderChats = useCallback(() => {
// Only fetch more if we are neither already fetching (so that we don't initiate duplicate requests) nor offline.
if (props.network.isOffline || props.isLoadingOlderReportActions) {
return;
}

const oldestReportAction = _.last(props.reportActions);

// Don't load more chats if we're already at the beginning of the chat history
if (!oldestReportAction || oldestReportAction.actionName === CONST.REPORT.ACTIONS.TYPE.CREATED) {
return;
}
// Retrieve the next REPORT.ACTIONS.LIMIT sized page of comments
Report.getOlderActions(reportID, oldestReportAction.reportActionID);
};
}, [props.isLoadingOlderReportActions, props.network.isOffline, oldestReportAction, reportID]);

/**
* Retrieves the next set of report actions for the chat once we are nearing the end of what we are currently
Expand Down Expand Up @@ -228,7 +228,7 @@ function ReportActionsView(props) {
/**
* Runs when the FlatList finishes laying out
*/
const recordTimeToMeasureItemLayout = () => {
const recordTimeToMeasureItemLayout = useCallback(() => {
if (didLayout.current) {
return;
}
Expand All @@ -243,7 +243,7 @@ function ReportActionsView(props) {
} else {
Performance.markEnd(CONST.TIMING.SWITCH_REPORT);
}
};
}, [hasCachedActions]);

// Comments have not loaded at all yet do nothing
if (!_.size(props.reportActions)) {
Expand Down
7 changes: 5 additions & 2 deletions src/pages/home/sidebar/SidebarLinks.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/* eslint-disable rulesdir/onyx-props-must-have-default */
import lodashGet from 'lodash/get';
import PropTypes from 'prop-types';
import React, {useCallback, useEffect, useRef} from 'react';
import React, {useCallback, useEffect, useMemo, useRef} from 'react';
import {InteractionManager, StyleSheet, View} from 'react-native';
import {withOnyx} from 'react-native-onyx';
import _ from 'underscore';
Expand Down Expand Up @@ -131,6 +131,9 @@ function SidebarLinks({onLinkClick, insets, optionListItems, isLoading, priority

const viewMode = priorityMode === CONST.PRIORITY_MODE.GSD ? CONST.OPTION_MODE.COMPACT : CONST.OPTION_MODE.DEFAULT;

// eslint-disable-next-line react-hooks/exhaustive-deps
const contentContainerStyles = useMemo(() => StyleSheet.flatten([styles.sidebarListContainer, {paddingBottom: StyleUtils.getSafeAreaMargins(insets).marginBottom}]), [insets]);

return (
<View style={[styles.flex1, styles.h100]}>
<Breadcrumbs
Expand All @@ -152,7 +155,7 @@ function SidebarLinks({onLinkClick, insets, optionListItems, isLoading, priority
<View style={[styles.pRelative, styles.flex1]}>
<LHNOptionsList
style={styles.flex1}
contentContainerStyles={StyleSheet.flatten([styles.sidebarListContainer, {paddingBottom: StyleUtils.getSafeAreaMargins(insets).marginBottom}])}
contentContainerStyles={contentContainerStyles}
data={optionListItems}
onSelectRow={showReportPage}
shouldDisableFocusOptions={isSmallScreenWidth}
Expand Down

0 comments on commit 3a702ce

Please sign in to comment.