Skip to content

Commit

Permalink
Merge pull request #4341 from tloncorp/po/tlon-3467-save-home-nav-sta…
Browse files Browse the repository at this point in the history
…te-when-navigating-away

Desktop: save home tab nav state when navigating to another tab
  • Loading branch information
patosullivan authored Jan 16, 2025
2 parents d30856e + 5ead098 commit 4b3d11f
Showing 1 changed file with 45 additions and 15 deletions.
60 changes: 45 additions & 15 deletions packages/app/navigation/desktop/TopLevelDrawer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import {
DrawerContentComponentProps,
createDrawerNavigator,
} from '@react-navigation/drawer';
import { DrawerNavigationState } from '@react-navigation/native';
import * as store from '@tloncorp/shared/store';
import {
AvatarNavIcon,
Expand All @@ -11,6 +12,7 @@ import {
YStack,
useWebAppUpdate,
} from '@tloncorp/ui';
import { useCallback, useRef } from 'react';
import { getVariableValue, useTheme } from 'tamagui';

import { ActivityScreen } from '../../features/top/ActivityScreen';
Expand All @@ -26,12 +28,40 @@ const DrawerContent = (props: DrawerContentComponentProps) => {
const userId = useCurrentUserId();
const haveUnreadUnseenActivity = store.useHaveUnreadUnseenActivity();
const { webAppNeedsUpdate, triggerWebAppUpdate } = useWebAppUpdate();
const isRouteActive = (routeName: string) => {
return (
props.state.index ===
props.state.routes.findIndex((r) => r.name === routeName)
);
};
const lastHomeStateRef =
useRef<DrawerNavigationState<RootDrawerParamList> | null>(null);

const isRouteActive = useCallback(
(routeName: keyof RootDrawerParamList) => {
return (
props.state.index ===
props.state.routes.findIndex((r) => r.name === routeName)
);
},
[props.state]
);

const saveHomeState = useCallback(() => {
if (isRouteActive('Home')) {
lastHomeStateRef.current =
props.state as DrawerNavigationState<RootDrawerParamList>;
}
}, [props.state, isRouteActive]);

const restoreHomeState = useCallback(() => {
try {
if (lastHomeStateRef.current) {
props.navigation.reset(lastHomeStateRef.current);
} else {
// Default state if no saved state exists
props.navigation.reset({ index: 0, routes: [{ name: 'Home' }] });
}
} catch (error) {
console.error('Error restoring Home navigation state:', error);
// Fallback to default state if restoration fails
props.navigation.reset({ index: 0, routes: [{ name: 'Home' }] });
}
}, [props.navigation]);

return (
<YStack gap="$l">
Expand All @@ -42,25 +72,25 @@ const DrawerContent = (props: DrawerContentComponentProps) => {
// hasUnreads={(unreadCount?.channels ?? 0) > 0}
// intentionally leave undotted for now
hasUnreads={false}
onPress={() =>
props.navigation.reset({ index: 0, routes: [{ name: 'Home' }] })
}
onPress={restoreHomeState}
/>
<NavIcon
type="Notifications"
activeType="NotificationsFilled"
hasUnreads={haveUnreadUnseenActivity}
isActive={isRouteActive('Activity')}
onPress={() =>
props.navigation.reset({ index: 0, routes: [{ name: 'Activity' }] })
}
onPress={() => {
saveHomeState();
props.navigation.reset({ index: 0, routes: [{ name: 'Activity' }] });
}}
/>
<AvatarNavIcon
id={userId}
focused={isRouteActive('Contacts')}
onPress={() =>
props.navigation.reset({ index: 0, routes: [{ name: 'Contacts' }] })
}
onPress={() => {
saveHomeState();
props.navigation.reset({ index: 0, routes: [{ name: 'Contacts' }] });
}}
/>
{webAppNeedsUpdate && (
<NavIcon
Expand Down

0 comments on commit 4b3d11f

Please sign in to comment.