Files
Momento/memento-mobile/app/(tabs)/profile.tsx
Antigravity 7c8695cacf
Some checks failed
CI / Lint, Unit Tests & Build (push) Failing after 1m5s
CI / Deploy production (on server) (push) Has been skipped
fix(mobile): migrate to Expo SDK 54, replace NativeWind with StyleSheet
- Update package.json to Expo ~54.0.35, expo-router ~6.0.24, RN 0.81.5
- Remove NativeWind/Tailwind dependencies
- Fix babel.config.js: presets babel-preset-expo only
- Rewrite all screens with StyleSheet.create (no className)
- Add lucide-react-native + react-native-svg
- Export design tokens C from _layout.tsx for shared usage
- Install node_modules (702 packages)

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
2026-05-29 16:18:44 +00:00

85 lines
3.7 KiB
TypeScript

import { View, Text, TouchableOpacity, ScrollView, Alert, StyleSheet } from 'react-native'
import { SafeAreaView } from 'react-native-safe-area-context'
import { LogOut, CreditCard, Globe } from 'lucide-react-native'
import { useAuthStore } from '@/lib/store'
import { C } from '../_layout'
const TIER_LABELS: Record<string, string> = {
FREE: 'Gratuit',
BASIC: 'Basic',
PRO: 'Pro',
BUSINESS: 'Business',
ENTERPRISE: 'Enterprise',
}
export default function ProfileScreen() {
const { user, logout } = useAuthStore()
const initial = (user?.name?.[0] ?? user?.email?.[0] ?? '?').toUpperCase()
const handleLogout = () => {
Alert.alert(
'Se déconnecter',
'Voulez-vous vraiment vous déconnecter ?',
[
{ text: 'Annuler', style: 'cancel' },
{ text: 'Déconnecter', style: 'destructive', onPress: logout },
]
)
}
return (
<SafeAreaView style={s.safe}>
<ScrollView style={{ flex: 1, paddingHorizontal: 20 }}>
<Text style={s.title}>Profil</Text>
<View style={s.card}>
<View style={s.avatar}>
<Text style={s.avatarText}>{initial}</Text>
</View>
<Text style={s.name}>{user?.name ?? 'Utilisateur'}</Text>
<Text style={s.email}>{user?.email}</Text>
{user?.tier && (
<View style={s.badge}>
<Text style={s.badgeText}>{TIER_LABELS[user.tier] ?? user.tier}</Text>
</View>
)}
</View>
<View style={s.actionsCard}>
<TouchableOpacity style={[s.actionRow, s.actionRowBorder]}>
<CreditCard size={18} color={C.concrete} />
<Text style={s.actionText}>Abonnement</Text>
</TouchableOpacity>
<TouchableOpacity style={s.actionRow}>
<Globe size={18} color={C.concrete} />
<Text style={s.actionText}>Ouvrir memento-note.com</Text>
</TouchableOpacity>
</View>
<TouchableOpacity onPress={handleLogout} style={s.logoutBtn}>
<LogOut size={18} color={C.rose} />
<Text style={s.logoutText}>Se déconnecter</Text>
</TouchableOpacity>
</ScrollView>
</SafeAreaView>
)
}
const s = StyleSheet.create({
safe: { flex: 1, backgroundColor: C.paper },
title: { fontSize: 22, fontStyle: 'italic', fontWeight: '700', color: C.ink, paddingTop: 16, paddingBottom: 24 },
card: { backgroundColor: C.white, borderWidth: 1, borderColor: C.border, borderRadius: 20, padding: 20, marginBottom: 16 },
avatar: { width: 56, height: 56, borderRadius: 28, backgroundColor: '#f3ece4', alignItems: 'center', justifyContent: 'center', marginBottom: 12 },
avatarText: { fontSize: 22, fontWeight: '700', color: C.brand },
name: { fontSize: 17, fontWeight: '600', color: C.ink },
email: { fontSize: 13, color: C.concrete, marginTop: 2 },
badge: { marginTop: 12, alignSelf: 'flex-start', backgroundColor: '#f3ece4', paddingHorizontal: 12, paddingVertical: 4, borderRadius: 20 },
badgeText: { fontSize: 11, fontWeight: '800', color: C.brand, letterSpacing: 1, textTransform: 'uppercase' },
actionsCard: { backgroundColor: C.white, borderWidth: 1, borderColor: C.border, borderRadius: 20, overflow: 'hidden', marginBottom: 16 },
actionRow: { flexDirection: 'row', alignItems: 'center', gap: 12, paddingHorizontal: 16, paddingVertical: 14 },
actionRowBorder: { borderBottomWidth: 1, borderBottomColor: C.border },
actionText: { fontSize: 15, color: C.ink, flex: 1 },
logoutBtn: { backgroundColor: C.white, borderWidth: 1, borderColor: C.roseBorder, borderRadius: 20, flexDirection: 'row', alignItems: 'center', gap: 12, paddingHorizontal: 16, paddingVertical: 14 },
logoutText: { fontSize: 15, color: C.rose, fontWeight: '500' },
})