* Get home screen's swipable pager working with the drawer * Add tab bar to pager * Implement popular & following views on home screen * Visual tune-up * Move the feed selector to the footer * Fix to 'new posts' poll * Add the view header as a feed item * Use the native driver on the tabbar indicator to improve perf * Reduce home polling to the currently active page; also reuse some code * Add soft reset on tap selected in tab bar * Remove explicit 'onboarding' flow * Choose good stuff based on service * Add foaf-based follow discovery * Fall back to who to follow * Fix backgrounds * Switch to the off-spec goodstuff route * 1.8 * Fix for dev & staging * Swap the tab bar items and rename suggested to what's hot * Go to whats-hot by default if you have no follows * Implement pager and tabbar for desktop web * Pin deps to make expo happy * Add language filtering to goodstuff
128 lines
4 KiB
TypeScript
128 lines
4 KiB
TypeScript
import React from 'react'
|
|
import {observer} from 'mobx-react-lite'
|
|
import {StatusBar, StyleSheet, useWindowDimensions, View} from 'react-native'
|
|
import {useSafeAreaInsets} from 'react-native-safe-area-context'
|
|
import {Drawer} from 'react-native-drawer-layout'
|
|
import {useNavigationState} from '@react-navigation/native'
|
|
import {useStores} from 'state/index'
|
|
import {ModalsContainer} from 'view/com/modals/Modal'
|
|
import {Lightbox} from 'view/com/lightbox/Lightbox'
|
|
import {Text} from 'view/com/util/text/Text'
|
|
import {ErrorBoundary} from 'view/com/util/ErrorBoundary'
|
|
import {DrawerContent} from './Drawer'
|
|
import {Composer} from './Composer'
|
|
import {s} from 'lib/styles'
|
|
import {useTheme} from 'lib/ThemeContext'
|
|
import {usePalette} from 'lib/hooks/usePalette'
|
|
import {RoutesContainer, TabsNavigator} from '../../Navigation'
|
|
import {isStateAtTabRoot} from 'lib/routes/helpers'
|
|
|
|
const ShellInner = observer(() => {
|
|
const store = useStores()
|
|
const winDim = useWindowDimensions()
|
|
const safeAreaInsets = useSafeAreaInsets()
|
|
const containerPadding = React.useMemo(
|
|
() => ({height: '100%', paddingTop: safeAreaInsets.top}),
|
|
[safeAreaInsets],
|
|
)
|
|
const renderDrawerContent = React.useCallback(() => <DrawerContent />, [])
|
|
const onOpenDrawer = React.useCallback(
|
|
() => store.shell.openDrawer(),
|
|
[store],
|
|
)
|
|
const onCloseDrawer = React.useCallback(
|
|
() => store.shell.closeDrawer(),
|
|
[store],
|
|
)
|
|
const canGoBack = useNavigationState(state => !isStateAtTabRoot(state))
|
|
|
|
return (
|
|
<>
|
|
<View style={containerPadding}>
|
|
<ErrorBoundary>
|
|
<Drawer
|
|
renderDrawerContent={renderDrawerContent}
|
|
open={store.shell.isDrawerOpen}
|
|
onOpen={onOpenDrawer}
|
|
onClose={onCloseDrawer}
|
|
swipeEdgeWidth={winDim.width}
|
|
swipeEnabled={
|
|
!canGoBack &&
|
|
store.session.hasSession &&
|
|
!store.shell.isDrawerSwipeDisabled
|
|
}>
|
|
<TabsNavigator />
|
|
</Drawer>
|
|
</ErrorBoundary>
|
|
</View>
|
|
<ModalsContainer />
|
|
<Lightbox />
|
|
<Composer
|
|
active={store.shell.isComposerActive}
|
|
onClose={() => store.shell.closeComposer()}
|
|
winHeight={winDim.height}
|
|
replyTo={store.shell.composerOpts?.replyTo}
|
|
onPost={store.shell.composerOpts?.onPost}
|
|
quote={store.shell.composerOpts?.quote}
|
|
/>
|
|
</>
|
|
)
|
|
})
|
|
|
|
export const Shell: React.FC = observer(() => {
|
|
const theme = useTheme()
|
|
const pal = usePalette('default')
|
|
const store = useStores()
|
|
|
|
if (store.hackUpgradeNeeded) {
|
|
return (
|
|
<View style={styles.outerContainer}>
|
|
<View style={[s.flexCol, s.p20, s.h100pct]}>
|
|
<View style={s.flex1} />
|
|
<View>
|
|
<Text type="title-2xl" style={s.pb10}>
|
|
Update required
|
|
</Text>
|
|
<Text style={[s.pb20, s.bold]}>
|
|
Please update your app to the latest version. If no update is
|
|
available yet, please check the App Store in a day or so.
|
|
</Text>
|
|
<Text type="title" style={s.pb10}>
|
|
What's happening?
|
|
</Text>
|
|
<Text style={s.pb10}>
|
|
We're in the final stages of the AT Protocol's v1 development. To
|
|
make sure everything works as well as possible, we're making final
|
|
breaking changes to the APIs.
|
|
</Text>
|
|
<Text>
|
|
If we didn't botch this process, a new version of the app should
|
|
be available now.
|
|
</Text>
|
|
</View>
|
|
<View style={s.flex1} />
|
|
<View style={s.footerSpacer} />
|
|
</View>
|
|
</View>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<View testID="mobileShellView" style={[styles.outerContainer, pal.view]}>
|
|
<StatusBar
|
|
barStyle={
|
|
theme.colorScheme === 'dark' ? 'light-content' : 'dark-content'
|
|
}
|
|
/>
|
|
<RoutesContainer>
|
|
<ShellInner />
|
|
</RoutesContainer>
|
|
</View>
|
|
)
|
|
})
|
|
|
|
const styles = StyleSheet.create({
|
|
outerContainer: {
|
|
height: '100%',
|
|
},
|
|
})
|