import 'package:flutter/material.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart'; import '../../core/navigation_provider.dart'; import '../../providers/auth_provider.dart'; class ProfilePage extends ConsumerWidget { const ProfilePage({super.key}); @override Widget build(BuildContext context, WidgetRef ref) { final auth = ref.watch(authProvider); final user = auth.user; return Scaffold( backgroundColor: const Color(0xFFF8F7FF), body: SafeArea(child: SingleChildScrollView(padding: const EdgeInsets.only(bottom: 20), child: Column(children: [ Container(width: double.infinity, padding: const EdgeInsets.all(24), decoration: const BoxDecoration(color: Colors.white, borderRadius: BorderRadius.only(bottomLeft: Radius.circular(24), bottomRight: Radius.circular(24))), child: Column(children: [ Row(mainAxisAlignment: MainAxisAlignment.spaceBetween, children: [Text('9:41', style: TextStyle(fontSize: 16, fontWeight: FontWeight.w600, color: Colors.grey[800])), Row(children: [Icon(Icons.wifi, size: 18, color: Colors.grey[700]), const SizedBox(width: 4), Icon(Icons.battery_full, size: 18, color: Colors.grey[700])]),]), const SizedBox(height: 20), Row(children: [ GestureDetector( onTap: () => pushRoute(ref, 'editProfile'), child: Stack(children: [ CircleAvatar(radius: 32, backgroundColor: const Color(0xFFEDEBFF), backgroundImage: user?.avatarUrl != null ? NetworkImage(user!.avatarUrl!) : null, child: user?.avatarUrl == null ? const Icon(Icons.person, size: 40, color: Color(0xFF635BFF)) : null), Positioned(right: 0, bottom: 0, child: Container(width: 22, height: 22, decoration: BoxDecoration(color: const Color(0xFF635BFF), borderRadius: BorderRadius.circular(11), border: Border.all(color: Colors.white, width: 2)), child: const Icon(Icons.edit, size: 12, color: Colors.white))), ]), ), const SizedBox(width: 16), Expanded(child: Column(crossAxisAlignment: CrossAxisAlignment.start, children: [ Text(user?.name ?? '张三', style: const TextStyle(fontSize: 22, fontWeight: FontWeight.bold, color: Color(0xFF1A1A1A))), const SizedBox(height: 4), Text('42岁', style: TextStyle(fontSize: 14, color: Colors.grey[500])), ])), Icon(Icons.chevron_right, size: 24, color: Colors.grey[400]), ]), ])), const SizedBox(height: 12), _MenuItem(icon: Icons.folder_shared, title: '健康档案', onTap: () => pushRoute(ref, 'healthArchive')), _MenuItem(icon: Icons.devices, title: '设备管理', onTap: () => pushRoute(ref, 'devices')), _MenuItem(icon: Icons.favorite_border, title: '就诊收藏', trailing: '3'), _MenuItem(icon: Icons.people_outline, title: '家人关怀'), _MenuItem(icon: Icons.local_hospital_outlined, title: '医生绑定记录'), _MenuItem(icon: Icons.chat_bubble_outline, title: '意见反馈'), _MenuItem(icon: Icons.info_outline, title: '关于我们'), const SizedBox(height: 40), GestureDetector( onTap: () async { final ok = await showDialog( context: context, builder: (ctx) => AlertDialog( title: const Text('退出登录'), content: const Text('确定退出?'), actions: [ TextButton(onPressed: () => Navigator.pop(ctx, false), child: const Text('取消')), TextButton(onPressed: () => Navigator.pop(ctx, true), child: const Text('确定')), ], ), ); if (ok == true) { await ref.read(authProvider.notifier).logout(); goRoute(ref, 'login'); } }, child: Container( margin: const EdgeInsets.symmetric(horizontal: 24), height: 50, alignment: Alignment.center, decoration: BoxDecoration(border: Border.all(color: const Color(0xFFE53935)), borderRadius: BorderRadius.circular(25)), child: const Text('退出登录', style: TextStyle(fontSize: 16, color: Color(0xFFE53935), fontWeight: FontWeight.w500)), ), ), ]))), ); } } class _MenuItem extends StatelessWidget { final IconData icon; final String title; final String? trailing; final VoidCallback? onTap; const _MenuItem({required this.icon, required this.title, this.trailing, this.onTap}); @override Widget build(BuildContext context) { return GestureDetector( onTap: onTap, behavior: HitTestBehavior.opaque, child: Container( margin: const EdgeInsets.symmetric(horizontal: 24, vertical: 2), padding: const EdgeInsets.symmetric(horizontal: 4, vertical: 14), decoration: BoxDecoration(color: Colors.white), child: Row(children: [ Container(width: 36, height: 36, decoration: BoxDecoration(color: const Color(0xFFF5F3FF), borderRadius: BorderRadius.circular(10)), child: Icon(icon, size: 18, color: const Color(0xFF635BFF))), const SizedBox(width: 12), Text(title, style: const TextStyle(fontSize: 16, color: Color(0xFF1A1A1A))), if (trailing != null && trailing!.isNotEmpty) ...[const Spacer(), Text(trailing!, style: TextStyle(fontSize: 14, color: Colors.grey[400]))], if (trailing == null || trailing!.isEmpty) const Spacer(), Icon(Icons.chevron_right, size: 20, color: Colors.grey[300]), ]), ), ); } }