165 lines
4.6 KiB
TypeScript
165 lines
4.6 KiB
TypeScript
import React from 'react'
|
|
import {Pressable, View} from 'react-native'
|
|
import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome'
|
|
import {msg, Trans} from '@lingui/macro'
|
|
import {useLingui} from '@lingui/react'
|
|
|
|
import {useKawaiiMode} from '#/state/preferences/kawaii'
|
|
import {useWebMediaQueries} from 'lib/hooks/useWebMediaQueries'
|
|
import {Logo} from '#/view/icons/Logo'
|
|
import {Logotype} from '#/view/icons/Logotype'
|
|
import {ErrorBoundary} from 'view/com/util/ErrorBoundary'
|
|
import {atoms as a, useTheme} from '#/alf'
|
|
import {AppLanguageDropdown} from '#/components/AppLanguageDropdown'
|
|
import {Button, ButtonText} from '#/components/Button'
|
|
import {InlineLinkText} from '#/components/Link'
|
|
import {Text} from '#/components/Typography'
|
|
import {CenteredView} from '../util/Views'
|
|
|
|
export const SplashScreen = ({
|
|
onDismiss,
|
|
onPressSignin,
|
|
onPressCreateAccount,
|
|
}: {
|
|
onDismiss?: () => void
|
|
onPressSignin: () => void
|
|
onPressCreateAccount: () => void
|
|
}) => {
|
|
const {_} = useLingui()
|
|
const t = useTheme()
|
|
const {isTabletOrMobile: isMobileWeb} = useWebMediaQueries()
|
|
|
|
const kawaii = useKawaiiMode()
|
|
|
|
return (
|
|
<>
|
|
{onDismiss && (
|
|
<Pressable
|
|
accessibilityRole="button"
|
|
style={{
|
|
position: 'absolute',
|
|
top: 20,
|
|
right: 20,
|
|
padding: 20,
|
|
zIndex: 100,
|
|
}}
|
|
onPress={onDismiss}>
|
|
<FontAwesomeIcon
|
|
icon="x"
|
|
size={24}
|
|
style={{
|
|
color: String(t.atoms.text.color),
|
|
}}
|
|
/>
|
|
</Pressable>
|
|
)}
|
|
|
|
<CenteredView style={[a.h_full, a.flex_1]}>
|
|
<View
|
|
testID="noSessionView"
|
|
style={[
|
|
a.h_full,
|
|
a.justify_center,
|
|
// @ts-ignore web only
|
|
{paddingBottom: '20vh'},
|
|
isMobileWeb && a.pb_5xl,
|
|
t.atoms.border_contrast_medium,
|
|
a.align_center,
|
|
a.gap_5xl,
|
|
]}>
|
|
<ErrorBoundary>
|
|
<View style={[a.justify_center, a.align_center]}>
|
|
<Logo width={kawaii ? 300 : 92} fill="sky" />
|
|
|
|
{!kawaii && (
|
|
<View style={[a.pb_sm, a.pt_5xl]}>
|
|
<Logotype width={161} fill={t.atoms.text.color} />
|
|
</View>
|
|
)}
|
|
|
|
<Text
|
|
style={[
|
|
a.text_md,
|
|
a.font_semibold,
|
|
t.atoms.text_contrast_medium,
|
|
]}>
|
|
<Trans>What's up?</Trans>
|
|
</Text>
|
|
</View>
|
|
|
|
<View
|
|
testID="signinOrCreateAccount"
|
|
style={[a.w_full, {maxWidth: 320}]}>
|
|
<Button
|
|
testID="createAccountButton"
|
|
onPress={onPressCreateAccount}
|
|
accessibilityRole="button"
|
|
label={_(msg`Create new account`)}
|
|
accessibilityHint={_(
|
|
msg`Opens flow to create a new Bluesky account`,
|
|
)}
|
|
style={[a.mx_xl, a.mb_xl]}
|
|
size="large"
|
|
variant="solid"
|
|
color="primary">
|
|
<ButtonText>
|
|
<Trans>Create a new account</Trans>
|
|
</ButtonText>
|
|
</Button>
|
|
<Button
|
|
testID="signInButton"
|
|
onPress={onPressSignin}
|
|
label={_(msg`Sign in`)}
|
|
accessibilityHint={_(
|
|
msg`Opens flow to sign into your existing Bluesky account`,
|
|
)}
|
|
style={[a.mx_xl, a.mb_xl]}
|
|
size="large"
|
|
variant="solid"
|
|
color="secondary">
|
|
<ButtonText>
|
|
<Trans>Sign in</Trans>
|
|
</ButtonText>
|
|
</Button>
|
|
</View>
|
|
</ErrorBoundary>
|
|
</View>
|
|
<Footer />
|
|
</CenteredView>
|
|
</>
|
|
)
|
|
}
|
|
|
|
function Footer() {
|
|
const t = useTheme()
|
|
|
|
return (
|
|
<View
|
|
style={[
|
|
a.absolute,
|
|
a.inset_0,
|
|
{top: 'auto'},
|
|
a.p_xl,
|
|
a.border_t,
|
|
a.flex_row,
|
|
a.flex_wrap,
|
|
a.gap_xl,
|
|
a.flex_1,
|
|
t.atoms.border_contrast_medium,
|
|
]}>
|
|
<InlineLinkText to="https://bsky.social">
|
|
<Trans>Business</Trans>
|
|
</InlineLinkText>
|
|
<InlineLinkText to="https://bsky.social/about/blog">
|
|
<Trans>Blog</Trans>
|
|
</InlineLinkText>
|
|
<InlineLinkText to="https://bsky.social/about/join">
|
|
<Trans>Jobs</Trans>
|
|
</InlineLinkText>
|
|
|
|
<View style={a.flex_1} />
|
|
|
|
<AppLanguageDropdown />
|
|
</View>
|
|
)
|
|
}
|