import React, {useState, useRef} from 'react'; import {RouteProp} from '@react-navigation/native'; import {StackNavigationProp} from '@react-navigation/stack'; import { View, Text, StyleSheet, StatusBar, Alert, Platform, TouchableOpacity, KeyboardAvoidingView, } from 'react-native'; import {OnboardingStackParams} from '../../routes'; import { ArrowButton, RegistrationWizard, TaggInput, Background, LoadingIndicator, } from '../../components'; import {trackPromise} from 'react-promise-tracker'; import {SEND_OTP_ENDPOINT} from '../../constants'; import {phoneRegex} from '../../constants'; type RegistrationScreenOneRouteProp = RouteProp< OnboardingStackParams, 'RegistrationOne' >; type RegistrationScreenOneNavigationProp = StackNavigationProp< OnboardingStackParams, 'RegistrationOne' >; interface RegistrationOneProps { route: RegistrationScreenOneRouteProp; navigation: RegistrationScreenOneNavigationProp; } /** * Registration screen 1 for Email * @param navigation react-navigation navigation object */ const RegistrationOne: React.FC = ({navigation}) => { // // refs for changing focus const phoneRef = useRef(); // registration form state const [form, setForm] = useState({ phone_number: '', isValidPhone: false, attemptedSubmit: false, }); /* * Handles changes to the email field value and verifies the input by updating state and running a validation function. */ const handlePhoneUpdate = (phone_number: string) => { let isValidPhone: boolean = phoneRegex.test(phone_number); setForm({ ...form, phone_number, isValidPhone, }); }; /** * Handles a click on the "next" arrow button by navigating to Verification if email is filled correctly */ const goToVerification = async () => { if (!form.attemptedSubmit) { setForm({ ...form, attemptedSubmit: true, }); } try { if (form.isValidPhone) { let sendOtpResponse = await trackPromise( fetch(SEND_OTP_ENDPOINT, { method: 'POST', body: JSON.stringify({ phone_number: form.phone_number, }), }), ); let otpStatusCode = sendOtpResponse.status; if (otpStatusCode === 200) { navigation.navigate('Verification', { phone: form.phone_number, }); } else if (otpStatusCode === 409) { Alert.alert( 'This phone number is already registered with us, please use another email.', ); } else { Alert.alert( "Looks like Our phone servers might be down 😓'", "Try again in a couple minutes. We're sorry for the inconvenience.", ); } } else { setForm({...form, attemptedSubmit: false}); setTimeout(() => setForm({...form, attemptedSubmit: true})); } } catch (error) { Alert.alert( 'Looks like our servers are down. 😓', "Try again in a couple minutes. We're sorry for the inconvenience.", ); return { name: 'Send OTP error', description: error, }; } }; const Footer = () => ( navigation.navigate('Login')} /> ); return ( ENTER PHONE NUMBER