import { Link } from "expo-router"; import { useState } from "react"; import { KeyboardAvoidingView, Platform, ScrollView, StyleSheet, Text, View, } from "react-native"; import { FullScreen } from "@/components/Screen"; import { AuthBackground } from "@/components/AppBackground"; import { AuthServerPicker } from "@/components/AuthServerPicker"; import { HeadingText, Logo } from "@/components/Logo"; import { Button } from "@/components/ui/Button"; import { Card } from "@/components/ui/Card"; import { Input } from "@/components/ui/Input"; import { fonts, spacing } from "@/constants/theme"; import { useAccounts } from "@/contexts/AccountsContext"; import { useAuthClient } from "@/contexts/AuthContext"; import { useAppTheme } from "@/contexts/ThemeContext"; import { registerAccount } from "@/lib/auth-api"; import { completeSignInAfterAuth } from "@/lib/complete-sign-in"; import { isRequiredString, isValidEmail, isValidPassword, useFieldVisibility } from "@/lib/form-validation"; export default function RegisterScreen() { const authClient = useAuthClient(); const { apiUrl, activeAccountId, registerAccount: saveAccount } = useAccounts(); const { colors } = useAppTheme(); const [firstName, setFirstName] = useState(""); const [lastName, setLastName] = useState(""); const [email, setEmail] = useState(""); const [password, setPassword] = useState(""); const [error, setError] = useState(null); const [loading, setLoading] = useState(false); const [serverReady, setServerReady] = useState(true); const { touch, visible, markSubmitted } = useFieldVisibility(); const firstNameError = isRequiredString(firstName) ? undefined : "First name is required"; const lastNameError = isRequiredString(lastName) ? undefined : "Last name is required"; const emailValidationError = isValidEmail(email) ? undefined : email.trim() ? "Enter a valid email" : "Email is required"; const passwordValidationError = isValidPassword(password) ? undefined : password ? "Password must be at least 8 characters" : "Password is required"; const canRegister = isRequiredString(firstName) && isRequiredString(lastName) && isValidEmail(email) && isValidPassword(password) && serverReady; async function handleRegister() { markSubmitted(); if (!canRegister) return; setError(null); setLoading(true); try { await registerAccount({ firstName: firstName.trim(), lastName: lastName.trim(), email: email.trim(), password, }); const { error: signInError } = await authClient.signIn.email({ email: email.trim(), password, }); if (signInError) { setError(signInError.message || "Account created but sign-in failed. Try signing in."); return; } const session = await authClient.getSession(); const user = session.data?.user; if (user) { await completeSignInAfterAuth(authClient, { apiUrl, activeAccountId, registerAccount: saveAccount, }); } } catch (err) { setError(err instanceof Error ? err.message : "Registration failed"); } finally { setLoading(false); } } return ( Create your account Get started today touch("firstName")} autoComplete="given-name" placeholder="Jane" required error={visible("firstName") ? firstNameError : undefined} /> touch("lastName")} autoComplete="family-name" placeholder="Doe" required error={visible("lastName") ? lastNameError : undefined} /> touch("email")} placeholder="you@example.com" required error={visible("email") ? emailValidationError : undefined} /> touch("password")} placeholder="At least 8 characters" required error={visible("password") ? passwordValidationError : undefined} /> {error ? ( {error} ) : null}