* Base work for public view * Make default moderation settings more restrictive * Fix type * Handle showing sign-in on authed actions * Fix hoc logic * Simplify prefs logic * Remove duplicate method * Add todo * Clean up RepostButton.web * Fix x button color * Add todo * Retain existing label prefs for now, use separate logged out settings * Clean up useAuthedMethod, rename to useRequireAuth * Add todos * Move dismiss logic to withAuthRequired * Ooops add web * Block public view in prod * Add todo * Fix bad import
94 lines
2.7 KiB
TypeScript
94 lines
2.7 KiB
TypeScript
import React from 'react'
|
|
import {
|
|
ActivityIndicator,
|
|
Linking,
|
|
StyleSheet,
|
|
TouchableOpacity,
|
|
} from 'react-native'
|
|
import {CenteredView} from '../util/Views'
|
|
import {LoggedOut} from './LoggedOut'
|
|
import {Onboarding} from './Onboarding'
|
|
import {Text} from '../util/text/Text'
|
|
import {usePalette} from 'lib/hooks/usePalette'
|
|
import {STATUS_PAGE_URL} from 'lib/constants'
|
|
import {useOnboardingState} from '#/state/shell'
|
|
import {useSession} from '#/state/session'
|
|
import {
|
|
useLoggedOutView,
|
|
useLoggedOutViewControls,
|
|
} from '#/state/shell/logged-out'
|
|
import {IS_PROD} from '#/env'
|
|
|
|
export const withAuthRequired = <P extends object>(
|
|
Component: React.ComponentType<P>,
|
|
options: {
|
|
isPublic?: boolean // TODO(pwi) need to enable in TF somehow
|
|
} = {},
|
|
): React.FC<P> =>
|
|
function AuthRequired(props: P) {
|
|
const {isInitialLoad, hasSession} = useSession()
|
|
const onboardingState = useOnboardingState()
|
|
const {showLoggedOut} = useLoggedOutView()
|
|
const {setShowLoggedOut} = useLoggedOutViewControls()
|
|
|
|
if (isInitialLoad) {
|
|
return <Loading />
|
|
}
|
|
if (!hasSession) {
|
|
if (showLoggedOut) {
|
|
return <LoggedOut onDismiss={() => setShowLoggedOut(false)} />
|
|
} else if (!options?.isPublic || IS_PROD) {
|
|
return <LoggedOut />
|
|
}
|
|
}
|
|
if (onboardingState.isActive) {
|
|
return <Onboarding />
|
|
}
|
|
return <Component {...props} />
|
|
}
|
|
|
|
function Loading() {
|
|
const pal = usePalette('default')
|
|
|
|
const [isTakingTooLong, setIsTakingTooLong] = React.useState(false)
|
|
React.useEffect(() => {
|
|
const t = setTimeout(() => setIsTakingTooLong(true), 15e3) // 15 seconds
|
|
return () => clearTimeout(t)
|
|
}, [setIsTakingTooLong])
|
|
|
|
return (
|
|
<CenteredView style={[styles.loading, pal.view]}>
|
|
<ActivityIndicator size="large" />
|
|
<Text type="2xl" style={[styles.loadingText, pal.textLight]}>
|
|
{isTakingTooLong
|
|
? "This is taking too long. There may be a problem with your internet or with the service, but we're going to try a couple more times..."
|
|
: 'Connecting...'}
|
|
</Text>
|
|
{isTakingTooLong ? (
|
|
<TouchableOpacity
|
|
onPress={() => {
|
|
Linking.openURL(STATUS_PAGE_URL)
|
|
}}
|
|
accessibilityRole="button">
|
|
<Text type="2xl" style={[styles.loadingText, pal.link]}>
|
|
Check Bluesky status page
|
|
</Text>
|
|
</TouchableOpacity>
|
|
) : null}
|
|
</CenteredView>
|
|
)
|
|
}
|
|
|
|
const styles = StyleSheet.create({
|
|
loading: {
|
|
height: '100%',
|
|
alignContent: 'center',
|
|
justifyContent: 'center',
|
|
paddingBottom: 100,
|
|
},
|
|
loadingText: {
|
|
paddingVertical: 20,
|
|
paddingHorizontal: 20,
|
|
textAlign: 'center',
|
|
},
|
|
})
|