2024-10-26 12:47:45 +00:00
|
|
|
import 'package:dialer/features/composition/composition.dart';
|
2024-09-16 15:07:04 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2024-10-18 19:45:35 +00:00
|
|
|
import 'package:dialer/features/contacts/contact_page.dart'; // Import ContactPage
|
|
|
|
import 'package:dialer/features/favorites/favorites_page.dart'; // Import FavoritePage
|
|
|
|
import 'package:dialer/features/history/history_page.dart'; // Import HistoryPage
|
2024-09-16 15:07:04 +00:00
|
|
|
|
|
|
|
class _MyHomePageState extends State<MyHomePage> with SingleTickerProviderStateMixin {
|
|
|
|
late TabController _tabController;
|
|
|
|
|
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
super.initState();
|
2024-10-02 22:03:47 +00:00
|
|
|
_tabController = TabController(length: 4, vsync: this, initialIndex: 1);
|
2024-09-16 15:07:04 +00:00
|
|
|
_tabController.addListener(_handleTabIndex);
|
2024-10-26 12:47:45 +00:00
|
|
|
|
2024-09-16 15:07:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void dispose() {
|
|
|
|
_tabController.removeListener(_handleTabIndex);
|
|
|
|
_tabController.dispose();
|
|
|
|
super.dispose();
|
|
|
|
}
|
|
|
|
|
|
|
|
void _handleTabIndex() {
|
|
|
|
setState(() {});
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
2024-10-02 22:03:47 +00:00
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Scaffold(
|
|
|
|
backgroundColor: Colors.black,
|
|
|
|
body: Stack(
|
|
|
|
children: [
|
|
|
|
TabBarView(
|
2024-09-16 15:07:04 +00:00
|
|
|
controller: _tabController,
|
2024-10-02 22:03:47 +00:00
|
|
|
children: const [
|
|
|
|
FavoritePage(),
|
|
|
|
HistoryPage(),
|
|
|
|
ContactPage(),
|
|
|
|
CompositionPage(),
|
2024-09-16 15:07:04 +00:00
|
|
|
],
|
|
|
|
),
|
2024-10-02 22:03:47 +00:00
|
|
|
if (_tabController.index != 3)
|
|
|
|
Positioned(
|
2024-10-02 22:30:24 +00:00
|
|
|
right: 20,
|
|
|
|
bottom: 20,
|
2024-10-02 22:03:47 +00:00
|
|
|
child: FloatingActionButton(
|
|
|
|
onPressed: () {
|
2024-10-26 12:47:45 +00:00
|
|
|
|
2024-10-02 22:30:24 +00:00
|
|
|
_tabController.animateTo(3);
|
2024-10-02 22:03:47 +00:00
|
|
|
},
|
|
|
|
backgroundColor: Colors.blue,
|
|
|
|
shape: RoundedRectangleBorder(
|
2024-10-02 22:30:24 +00:00
|
|
|
borderRadius: BorderRadius.circular(45),
|
2024-10-02 22:03:47 +00:00
|
|
|
),
|
|
|
|
child: Padding(
|
|
|
|
padding: const EdgeInsets.all(8.0),
|
|
|
|
child: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
children: const [
|
|
|
|
Icon(Icons.dialpad, color: Colors.white),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
bottomNavigationBar: Container(
|
|
|
|
color: Colors.black,
|
|
|
|
child: TabBar(
|
|
|
|
controller: _tabController,
|
|
|
|
tabs: [
|
|
|
|
Tab(icon: Icon(_tabController.index == 0 ? Icons.star : Icons.star_border)),
|
|
|
|
Tab(icon: Icon(_tabController.index == 1 ? Icons.access_time_filled : Icons.access_time_outlined)),
|
|
|
|
Tab(icon: Icon(_tabController.index == 2 ? Icons.contacts : Icons.contacts_outlined)),
|
|
|
|
Tab(icon: Icon(_tabController.index == 3 ? Icons.create : Icons.create_outlined)),
|
|
|
|
],
|
|
|
|
labelColor: Colors.white,
|
|
|
|
unselectedLabelColor: Colors.grey,
|
|
|
|
indicatorSize: TabBarIndicatorSize.label,
|
|
|
|
indicatorColor: Colors.white,
|
2024-09-16 15:07:04 +00:00
|
|
|
),
|
2024-10-02 22:03:47 +00:00
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2024-09-16 15:07:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
class MyHomePage extends StatefulWidget {
|
|
|
|
const MyHomePage({super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
_MyHomePageState createState() => _MyHomePageState();
|
|
|
|
}
|