import 'package:flutter/material.dart'; import 'package:flutter_dotenv/flutter_dotenv.dart'; import 'package:http/http.dart' as http; import '/models/conversations.dart'; import '/models/friends.dart'; import '/models/my_profile.dart'; import '/utils/storage/conversations.dart'; import '/utils/storage/friends.dart'; import '/utils/storage/messages.dart'; import '/utils/storage/session_cookie.dart'; import '/views/main/conversation/list.dart'; import '/views/main/friend/list.dart'; import '/views/main/profile/profile.dart'; class Home extends StatefulWidget { const Home({Key? key}) : super(key: key); @override State createState() => _HomeState(); } class _HomeState extends State { List conversations = []; List friends = []; List friendRequests = []; MyProfile profile = MyProfile( id: '', username: '', ); bool isLoading = true; int _selectedIndex = 0; List _widgetOptions = [ const ConversationList(conversations: [], friends: []), const FriendList(), Profile( profile: MyProfile( id: '', username: '', ) ), ]; @override Widget build(BuildContext context) { return WillPopScope( onWillPop: () async => false, child: isLoading ? loading() : Scaffold( body: _widgetOptions.elementAt(_selectedIndex), bottomNavigationBar: isLoading ? const SizedBox.shrink() : BottomNavigationBar( currentIndex: _selectedIndex, onTap: _onItemTapped, selectedItemColor: Theme.of(context).primaryColor, unselectedItemColor: Theme.of(context).hintColor, selectedLabelStyle: const TextStyle(fontWeight: FontWeight.w600), unselectedLabelStyle: const TextStyle(fontWeight: FontWeight.w600), type: BottomNavigationBarType.fixed, items: const [ BottomNavigationBarItem( icon: Icon(Icons.message), label: "Chats", ), BottomNavigationBarItem( icon: Icon(Icons.group_work), label: "Friends", ), BottomNavigationBarItem( icon: Icon(Icons.account_box), label: "Profile", ), ], ), ), ); } Future checkLogin() async { bool isLoggedIn = false; try { isLoggedIn = await MyProfile.isLoggedIn(); } catch (Exception) { Navigator.pushNamedAndRemoveUntil(context, '/landing', ModalRoute.withName('/landing')); return false; } if (!isLoggedIn) { await MyProfile.logout(); Navigator.pushNamedAndRemoveUntil(context, '/landing', ModalRoute.withName('/landing')); return false; } int statusCode = 200; try { var resp = await http.get( Uri.parse('${dotenv.env["SERVER_URL"]}api/v1/auth/check'), headers: { 'cookie': await getSessionCookie(), } ); statusCode = resp.statusCode; } catch(SocketException) { if (await MyProfile.isLoggedIn()) { return true; } } if (isLoggedIn && statusCode == 200) { return true; } MyProfile.logout(); Navigator.pushNamedAndRemoveUntil(context, '/landing', ModalRoute.withName('/landing')); return false; } @override void initState() { updateData(); super.initState(); } Widget loading() { return Stack( children: [ const Opacity( opacity: 0.1, child: ModalBarrier(dismissible: false, color: Colors.black), ), Center( child: Column( mainAxisSize: MainAxisSize.max, mainAxisAlignment: MainAxisAlignment.center, children: const [ CircularProgressIndicator(), SizedBox(height: 25), Text('Loading...'), ], ) ), ] ); } void updateData() async { if (!await checkLogin()) { return; } await updateFriends(); await updateConversations(); await updateMessageThreads(); conversations = await getConversations(); friends = await getFriends(accepted: true); profile = await MyProfile.getProfile(); setState(() { _widgetOptions = [ ConversationList( conversations: conversations, friends: friends, ), const FriendList(), Profile(profile: profile), ]; isLoading = false; }); } void _onItemTapped(int index) { setState(() { _selectedIndex = index; }); } }