animate transitions on web only

zio/stable
Samuel Newman 2024-03-15 14:21:15 +00:00
parent e31fcb1a6d
commit 0f67be3627
3 changed files with 13 additions and 7 deletions

View File

@ -0,0 +1,10 @@
import React from 'react'
import Animated, {FadeInRight, FadeOutLeft} from 'react-native-reanimated'
export function ScreenTransition({children}: {children: React.ReactNode}) {
return (
<Animated.View entering={FadeInRight} exiting={FadeOutLeft}>
{children}
</Animated.View>
)
}

View File

@ -0,0 +1 @@
export {Fragment as ScreenTransition} from 'react'

View File

@ -2,7 +2,6 @@ import React from 'react'
import {KeyboardAvoidingView} from 'react-native' import {KeyboardAvoidingView} from 'react-native'
import {useAnalytics} from '#/lib/analytics/analytics' import {useAnalytics} from '#/lib/analytics/analytics'
import {useLingui} from '@lingui/react' import {useLingui} from '@lingui/react'
import Animated, {FadeInRight, FadeOutLeft} from 'react-native-reanimated'
import {LoggedOutLayout} from '#/view/com/util/layouts/LoggedOutLayout' import {LoggedOutLayout} from '#/view/com/util/layouts/LoggedOutLayout'
import {SessionAccount, useSession} from '#/state/session' import {SessionAccount, useSession} from '#/state/session'
@ -17,6 +16,7 @@ import {ForgotPasswordForm} from '#/screens/Login/ForgotPasswordForm'
import {SetNewPasswordForm} from '#/screens/Login/SetNewPasswordForm' import {SetNewPasswordForm} from '#/screens/Login/SetNewPasswordForm'
import {PasswordUpdatedForm} from '#/screens/Login/PasswordUpdatedForm' import {PasswordUpdatedForm} from '#/screens/Login/PasswordUpdatedForm'
import {LoginForm} from '#/screens/Login/LoginForm' import {LoginForm} from '#/screens/Login/LoginForm'
import {ScreenTransition} from './ScreenTransition'
enum Forms { enum Forms {
Login, Login,
@ -161,12 +161,7 @@ export const Login = ({onPressBack}: {onPressBack: () => void}) => {
return ( return (
<KeyboardAvoidingView testID="signIn" behavior="padding" style={a.flex_1}> <KeyboardAvoidingView testID="signIn" behavior="padding" style={a.flex_1}>
<LoggedOutLayout leadin="" title={title} description={description}> <LoggedOutLayout leadin="" title={title} description={description}>
<Animated.View <ScreenTransition key={currentForm}>{content}</ScreenTransition>
entering={FadeInRight}
exiting={FadeOutLeft}
key={currentForm}>
{content}
</Animated.View>
</LoggedOutLayout> </LoggedOutLayout>
</KeyboardAvoidingView> </KeyboardAvoidingView>
) )