This commit is contained in:
2026-04-25 11:14:11 +02:00
parent 6f238b4d80
commit 72b45335dd
10 changed files with 271 additions and 29 deletions

View File

@@ -0,0 +1,18 @@
import { Stack, useRouter } from "expo-router";
import { useAuth } from "@/context/auth-context";
import { useEffect } from "react";
export default function AuthLayout() {
const { user } = useAuth();
const router = useRouter();
useEffect(() => {
if (user) {
router.replace("/(tabs)");
} else {
router.replace("/(auth)/login");
}
}, [user]);
return <Stack />;
}

145
apk/app/(auth)/login.tsx Normal file
View File

@@ -0,0 +1,145 @@
import React, { useState } from "react";
import { View, Text, TextInput, TouchableOpacity, StyleSheet } from "react-native";
import { useAuth } from "@/context/auth-context";
export default function AuthScreen() {
const [isLogin, setIsLogin] = useState(true);
return isLogin ? (
<LoginScreen onSwitch={() => setIsLogin(false)} />
) : (
<RegisterScreen onSwitch={() => setIsLogin(true)} />
);
}
function LoginScreen({ onSwitch }) {
const [email, setEmail] = useState("");
const [password, setPassword] = useState("");
const { login } = useAuth();
const handleLogin = () => {
console.log("Login ->", { email, password });
login(email, password);
};
return (
<View style={styles.container}>
<Text style={styles.title}>Welcome Back</Text>
<TextInput
style={styles.input}
placeholder="Email"
value={email}
onChangeText={setEmail}
keyboardType="email-address"
autoCapitalize="none"
/>
<TextInput
style={styles.input}
placeholder="Password"
value={password}
onChangeText={setPassword}
secureTextEntry
/>
<TouchableOpacity style={styles.button} onPress={handleLogin}>
<Text style={styles.buttonText}>Login</Text>
</TouchableOpacity>
<TouchableOpacity onPress={onSwitch}>
<Text style={styles.link}>Don't have an account? Register</Text>
</TouchableOpacity>
</View>
);
}
function RegisterScreen({ onSwitch }) {
const [name, setName] = useState("");
const [email, setEmail] = useState("");
const [password, setPassword] = useState("");
const handleRegister = () => {
console.log("Register ->", { name, email, password });
};
return (
<View style={styles.container}>
<Text style={styles.title}>Create Account</Text>
<TextInput
style={styles.input}
placeholder="Full Name"
value={name}
onChangeText={setName}
/>
<TextInput
style={styles.input}
placeholder="Email"
value={email}
onChangeText={setEmail}
keyboardType="email-address"
autoCapitalize="none"
/>
<TextInput
style={styles.input}
placeholder="Password"
value={password}
onChangeText={setPassword}
secureTextEntry
/>
<TouchableOpacity style={styles.button} onPress={handleRegister}>
<Text style={styles.buttonText}>Register</Text>
</TouchableOpacity>
<TouchableOpacity onPress={onSwitch}>
<Text style={styles.link}>Already have an account? Login</Text>
</TouchableOpacity>
</View>
);
}
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: "center",
padding: 20,
backgroundColor: "#f5f5f5",
},
title: {
fontSize: 28,
fontWeight: "bold",
marginBottom: 30,
textAlign: "center",
},
input: {
height: 50,
borderColor: "#ccc",
borderWidth: 1,
borderRadius: 10,
paddingHorizontal: 15,
marginBottom: 15,
backgroundColor: "#fff",
},
button: {
height: 50,
backgroundColor: "#4CAF50",
borderRadius: 10,
justifyContent: "center",
alignItems: "center",
marginTop: 10,
},
buttonText: {
color: "#fff",
fontSize: 16,
fontWeight: "bold",
},
link: {
marginTop: 15,
textAlign: "center",
color: "#007BFF",
},
});

View File

@@ -0,0 +1,13 @@
// app/(tabs)/_layout.tsx
import { Redirect, Tabs } from "expo-router";
import { useAuth } from "@/context/auth-context";
export default function TabsLayout() {
const { user } = useAuth();
if (!user) {
return <Redirect href="/(auth)/login" />;
}
return <Tabs />;
}

View File

@@ -1,31 +1,11 @@
import {
DarkTheme,
DefaultTheme,
ThemeProvider,
} from "@react-navigation/native";
import { Stack } from "expo-router";
import { StatusBar } from "expo-status-bar";
import "react-native-reanimated";
import RootNavigation from "@/components/views/root-navigation";
import { AuthProvider } from "@/context/auth-context";
import { BirthdaysProvider } from "@/context/birthdays-context";
import { useColorScheme } from "@/hooks/use-color-scheme";
export const unstable_settings = {
anchor: "(tabs)",
};
export default function RootLayout() {
const colorScheme = useColorScheme();
return (
<BirthdaysProvider>
<ThemeProvider value={colorScheme === "dark" ? DarkTheme : DefaultTheme}>
<Stack>
<Stack.Screen name="index" options={{ headerShown: false }} />
<Stack.Screen name="add" options={{ headerShown: false }} />
</Stack>
<StatusBar style="auto" />
</ThemeProvider>
</BirthdaysProvider>
<AuthProvider>
<RootNavigation />
</AuthProvider>
);
}
}