Sync top/bottom bar disappearance to the scroll (#1855)
* Disable existing code that toggles shell * Make shell mode a float * Translate based on the gesture * Track header and footer heights * Add web support * Fix types and cleanup * Add back isScrolled logic * Add comments
This commit is contained in:
		
							parent
							
								
									1dcf882619
								
							
						
					
					
						commit
						7a55ca6133
					
				
					 10 changed files with 183 additions and 107 deletions
				
			
		|  | @ -10,6 +10,7 @@ import {usePalette} from 'lib/hooks/usePalette' | |||
| import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries' | ||||
| import {FeedsTabBar as FeedsTabBarMobile} from './FeedsTabBarMobile' | ||||
| import {useMinimalShellMode} from 'lib/hooks/useMinimalShellMode' | ||||
| import {useShellLayout} from '#/state/shell/shell-layout' | ||||
| 
 | ||||
| export const FeedsTabBar = observer(function FeedsTabBarImpl( | ||||
|   props: RenderTabBarFnProps & {testID?: string; onPressSelected: () => void}, | ||||
|  | @ -31,11 +32,15 @@ const FeedsTabBarTablet = observer(function FeedsTabBarTabletImpl( | |||
|   const items = useHomeTabs(store.preferences.pinnedFeeds) | ||||
|   const pal = usePalette('default') | ||||
|   const {headerMinimalShellTransform} = useMinimalShellMode() | ||||
|   const {headerHeight} = useShellLayout() | ||||
| 
 | ||||
|   return ( | ||||
|     // @ts-ignore the type signature for transform wrong here, translateX and translateY need to be in separate objects -prf
 | ||||
|     <Animated.View | ||||
|       style={[pal.view, styles.tabBar, headerMinimalShellTransform]}> | ||||
|       style={[pal.view, styles.tabBar, headerMinimalShellTransform]} | ||||
|       onLayout={e => { | ||||
|         headerHeight.value = e.nativeEvent.layout.height | ||||
|       }}> | ||||
|       <TabBar | ||||
|         key={items.join(',')} | ||||
|         {...props} | ||||
|  |  | |||
|  | @ -18,6 +18,7 @@ import {msg} from '@lingui/macro' | |||
| import {useLingui} from '@lingui/react' | ||||
| import {useMinimalShellMode} from 'lib/hooks/useMinimalShellMode' | ||||
| import {useSetDrawerOpen} from '#/state/shell/drawer-open' | ||||
| import {useShellLayout} from '#/state/shell/shell-layout' | ||||
| 
 | ||||
| export const FeedsTabBar = observer(function FeedsTabBarImpl( | ||||
|   props: RenderTabBarFnProps & {testID?: string; onPressSelected: () => void}, | ||||
|  | @ -28,6 +29,7 @@ export const FeedsTabBar = observer(function FeedsTabBarImpl( | |||
|   const setDrawerOpen = useSetDrawerOpen() | ||||
|   const items = useHomeTabs(store.preferences.pinnedFeeds) | ||||
|   const brandBlue = useColorSchemeStyle(s.brandBlue, s.blue3) | ||||
|   const {headerHeight} = useShellLayout() | ||||
|   const {headerMinimalShellTransform} = useMinimalShellMode() | ||||
| 
 | ||||
|   const onPressAvi = React.useCallback(() => { | ||||
|  | @ -36,12 +38,10 @@ export const FeedsTabBar = observer(function FeedsTabBarImpl( | |||
| 
 | ||||
|   return ( | ||||
|     <Animated.View | ||||
|       style={[ | ||||
|         pal.view, | ||||
|         pal.border, | ||||
|         styles.tabBar, | ||||
|         headerMinimalShellTransform, | ||||
|       ]}> | ||||
|       style={[pal.view, pal.border, styles.tabBar, headerMinimalShellTransform]} | ||||
|       onLayout={e => { | ||||
|         headerHeight.value = e.nativeEvent.layout.height | ||||
|       }}> | ||||
|       <View style={[pal.view, styles.topBar]}> | ||||
|         <View style={[pal.view]}> | ||||
|           <TouchableOpacity | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue