import { useState } from 'react'; import { View, Text, StyleSheet, TouchableWithoutFeedback, Keyboard, Pressable } from 'react-native'; import { KeyboardAwareScrollView } from 'react-native-keyboard-aware-scroll-view'; import PaginationIndicator from '../../global/PaginationIndicator'; import { router } from 'expo-router'; import BindingPhoneNumberPage from './formPages/bindingPhoneNumberPage'; import BindingPhoneNumberPageStepTwo from './formPages/bindingPhoneNumberPageStepTwo'; import BindingFinishPage from './formPages/bindingFinishPage'; import { useTranslation } from '../../../util/hooks/useTranslation'; const BindingPhoneNumberForm = ({ bindingFormData, setBindingFormData }: any) => { const { t } = useTranslation(); // 使用翻译钩子 const [screen, setScreen] = useState(0); const FormTitle = [ t('binding.old_user_phone_binding_step1'), t('binding.old_user_phone_binding_step2') ]; const goToPreviousPage = () => { if (screen == 1) { setScreen((prevState) => prevState - 1); } else { router.replace('/(public)/login'); } }; const ScreenDisplay = () => { switch (screen) { case 0: return ( ); case 1: return ( ); case 2: return ; default: return <>; } }; return ( <> {screen !== 2 && ( {FormTitle[screen]} {t('common.previous')} )} {ScreenDisplay()} ); }; const styles = StyleSheet.create({ topContainer: { flex: 1, alignItems: 'center', justifyContent: 'center', paddingBottom: '25%', paddingTop: '15%' }, previouspageAndPaginationWrapper: { display: 'flex', width: '100%', flexDirection: 'row', justifyContent: 'space-between', alignItems: 'center', paddingHorizontal: 25 }, bottomContainer: { flex: 1 }, breakline: { width: 24, height: 1, backgroundColor: '#000000', marginVertical: 17 }, text: { fontSize: 24, fontWeight: '300' } }); export default BindingPhoneNumberForm;