2023-05-11 22:24:25 +00:00
|
|
|
// import 'package:drifter/pages/home_screen/home_screen_widget.dart';
|
2023-05-12 17:28:36 +00:00
|
|
|
import 'package:drifter/pages/home_screen/home_screen_widget.dart';
|
2023-05-17 23:16:20 +00:00
|
|
|
import 'package:drifter/pages/login_screen/login_screen.dart';
|
2023-05-11 22:24:25 +00:00
|
|
|
import 'package:drifter/pages/message_screen/message_screen_widget.dart';
|
2023-05-30 21:56:26 +00:00
|
|
|
import 'package:drifter/pages/notifications_screen/notifications_screen.dart';
|
2023-05-11 22:24:25 +00:00
|
|
|
import 'package:drifter/pages/profile_screen/profile_screen.dart';
|
2023-05-30 21:56:26 +00:00
|
|
|
import 'package:drifter/pages/search_screen/search_screen.dart';
|
2023-05-11 22:24:25 +00:00
|
|
|
import 'package:drifter/theme/app_colors.dart';
|
2023-05-22 20:04:20 +00:00
|
|
|
import 'package:drifter/main.dart';
|
2023-05-11 22:24:25 +00:00
|
|
|
import 'package:drifter/utilities/assets.dart';
|
2023-05-11 13:48:05 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2023-05-11 16:04:30 +00:00
|
|
|
import 'package:flutter_svg/svg.dart';
|
2023-05-11 13:48:05 +00:00
|
|
|
|
|
|
|
class MainScreenWidget extends StatefulWidget {
|
|
|
|
const MainScreenWidget({super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
State<MainScreenWidget> createState() => _MainScreenWidgetState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _MainScreenWidgetState extends State<MainScreenWidget> {
|
2023-05-30 21:56:26 +00:00
|
|
|
int _selectedTap = 2;
|
|
|
|
late String _title;
|
2023-05-11 13:48:05 +00:00
|
|
|
|
|
|
|
void onSelectedtap(int index) {
|
|
|
|
if (_selectedTap == index) return;
|
|
|
|
setState(() {
|
|
|
|
_selectedTap = index;
|
2023-05-30 21:56:26 +00:00
|
|
|
switch (index) {
|
|
|
|
case 0:
|
|
|
|
{
|
|
|
|
_title = 'Message';
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
{
|
|
|
|
_title = 'Search';
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
{
|
|
|
|
_title = 'Feed';
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
{
|
|
|
|
_title = 'Notifications';
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
{
|
|
|
|
_title = 'Profile';
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2023-05-11 13:48:05 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2023-05-30 21:56:26 +00:00
|
|
|
@override
|
|
|
|
initState() {
|
|
|
|
_title = 'Feed';
|
|
|
|
}
|
|
|
|
|
2023-05-11 13:48:05 +00:00
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Scaffold(
|
2023-05-12 17:28:36 +00:00
|
|
|
backgroundColor: AppColors.mainBackground,
|
2023-05-11 13:48:05 +00:00
|
|
|
appBar: AppBar(
|
2023-05-30 01:09:23 +00:00
|
|
|
leading: IconButton(
|
|
|
|
icon: Icon(Icons.settings),
|
|
|
|
color: AppColors.topNavIconPtimary,
|
2023-05-30 21:56:26 +00:00
|
|
|
onPressed: () {
|
|
|
|
Navigator.pushNamed(context, '/Settings');
|
|
|
|
},
|
2023-05-30 01:09:23 +00:00
|
|
|
),
|
|
|
|
actions: <Widget>[
|
|
|
|
IconButton(
|
|
|
|
icon: Icon(Icons.rss_feed),
|
|
|
|
color: AppColors.topNavIconPtimary,
|
|
|
|
onPressed: () {},
|
|
|
|
),
|
|
|
|
],
|
2023-05-30 21:56:26 +00:00
|
|
|
title: Text(
|
|
|
|
_title,
|
2023-05-30 01:09:23 +00:00
|
|
|
style: TextStyle(
|
|
|
|
color: AppColors.topNavText,
|
|
|
|
),
|
|
|
|
// textAlign: TextAlign.center,
|
2023-05-11 16:04:30 +00:00
|
|
|
),
|
2023-05-11 13:48:05 +00:00
|
|
|
centerTitle: true,
|
2023-05-30 01:09:23 +00:00
|
|
|
backgroundColor: AppColors.mainBackground,
|
|
|
|
elevation: 0,
|
2023-05-11 13:48:05 +00:00
|
|
|
),
|
|
|
|
body: IndexedStack(
|
|
|
|
index: _selectedTap,
|
2023-05-11 22:24:25 +00:00
|
|
|
children: const [
|
2023-05-11 13:48:05 +00:00
|
|
|
MessageScreen(),
|
2023-05-30 21:56:26 +00:00
|
|
|
SearchScreen(),
|
|
|
|
HomeScreen(),
|
|
|
|
NotificationsScreen(),
|
2023-05-11 13:48:05 +00:00
|
|
|
ProfileScreen(),
|
2023-05-22 20:04:20 +00:00
|
|
|
// LoginScreen(),
|
2023-05-11 13:48:05 +00:00
|
|
|
],
|
|
|
|
),
|
|
|
|
bottomNavigationBar: BottomNavigationBar(
|
2023-05-30 01:09:23 +00:00
|
|
|
backgroundColor: AppColors.bottomNavBackground,
|
|
|
|
selectedItemColor: AppColors.bottomNavIconActive,
|
|
|
|
unselectedItemColor: AppColors.bottomNavIconDefault,
|
2023-05-30 21:56:26 +00:00
|
|
|
selectedFontSize: 0,
|
2023-05-11 13:48:05 +00:00
|
|
|
currentIndex: _selectedTap,
|
2023-05-30 21:56:26 +00:00
|
|
|
type: BottomNavigationBarType.fixed,
|
2023-05-11 22:24:25 +00:00
|
|
|
items: const [
|
2023-05-12 17:28:36 +00:00
|
|
|
BottomNavigationBarItem(
|
2023-05-30 21:56:26 +00:00
|
|
|
icon: Icon(Icons.mail_outline),
|
|
|
|
label: '',
|
2023-05-12 17:28:36 +00:00
|
|
|
),
|
2023-05-11 13:48:05 +00:00
|
|
|
BottomNavigationBarItem(
|
2023-05-30 21:56:26 +00:00
|
|
|
icon: Icon(Icons.search),
|
|
|
|
label: '',
|
2023-05-11 13:48:05 +00:00
|
|
|
),
|
|
|
|
BottomNavigationBarItem(
|
2023-05-30 21:56:26 +00:00
|
|
|
icon:
|
|
|
|
ImageIcon(AssetImage('assets/images/icons/drifter_vector.png')),
|
|
|
|
label: '',
|
|
|
|
),
|
|
|
|
BottomNavigationBarItem(
|
|
|
|
icon: Icon(Icons.notifications_outlined),
|
|
|
|
label: '',
|
|
|
|
),
|
|
|
|
|
|
|
|
BottomNavigationBarItem(
|
|
|
|
icon: Icon(Icons.person_2_outlined),
|
|
|
|
label: '',
|
2023-05-11 13:48:05 +00:00
|
|
|
),
|
2023-05-22 20:04:20 +00:00
|
|
|
// BottomNavigationBarItem(
|
|
|
|
// icon: Icon(Icons.login),
|
|
|
|
// label: 'Login',
|
|
|
|
// ),
|
2023-05-11 13:48:05 +00:00
|
|
|
],
|
|
|
|
onTap: onSelectedtap,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|