mirror of
https://github.com/twonlyapp/twonly-app.git
synced 2026-01-15 14:08:40 +00:00
119 lines
3.6 KiB
Dart
119 lines
3.6 KiB
Dart
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
|
import 'package:pie_menu/pie_menu.dart';
|
|
import 'package:provider/provider.dart';
|
|
import 'package:twonly/src/providers/send_next_media_to.dart';
|
|
import 'camera_to_share/camera_preview_view.dart';
|
|
import 'chats/chat_list_view.dart';
|
|
import 'package:flutter/material.dart';
|
|
|
|
Function(int) globalUpdateOfHomeViewPageIndex = (a) {};
|
|
|
|
class HomeView extends StatefulWidget {
|
|
const HomeView({super.key, required this.initialPage});
|
|
final int initialPage;
|
|
|
|
@override
|
|
State<HomeView> createState() => HomeViewState();
|
|
}
|
|
|
|
class HomeViewState extends State<HomeView> {
|
|
int activePageIdx = 0;
|
|
late PageController homeViewPageController;
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
activePageIdx = widget.initialPage;
|
|
homeViewPageController = PageController(initialPage: widget.initialPage);
|
|
globalUpdateOfHomeViewPageIndex = (index) {
|
|
if (index == 1) {
|
|
context.read<SendNextMediaTo>().updateSendNextMediaTo(null);
|
|
}
|
|
homeViewPageController.jumpToPage(index);
|
|
setState(() {
|
|
activePageIdx = index;
|
|
});
|
|
};
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
// disable globalCallbacks to the flutter tree
|
|
globalUpdateOfHomeViewPageIndex = (a) {};
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return PieCanvas(
|
|
theme: PieTheme(
|
|
brightness: Theme.of(context).brightness,
|
|
rightClickShowsMenu: true,
|
|
radius: 70,
|
|
buttonTheme: PieButtonTheme(
|
|
backgroundColor: Theme.of(context).colorScheme.tertiary,
|
|
iconColor: Theme.of(context).colorScheme.surfaceBright,
|
|
),
|
|
buttonThemeHovered: PieButtonTheme(
|
|
backgroundColor: Theme.of(context).colorScheme.primary,
|
|
iconColor: Theme.of(context).colorScheme.surfaceBright,
|
|
),
|
|
tooltipPadding: EdgeInsets.all(20),
|
|
overlayColor: const Color.fromARGB(41, 0, 0, 0),
|
|
|
|
// spacing: 0,
|
|
tooltipTextStyle: TextStyle(
|
|
fontSize: 32,
|
|
fontWeight: FontWeight.w600,
|
|
),
|
|
),
|
|
child: Scaffold(
|
|
body: PageView(
|
|
controller: homeViewPageController,
|
|
onPageChanged: (index) {
|
|
if (index == 1) {
|
|
context.read<SendNextMediaTo>().updateSendNextMediaTo(null);
|
|
}
|
|
activePageIdx = index;
|
|
setState(() {});
|
|
},
|
|
children: [
|
|
CameraPreviewViewPermission(),
|
|
ChatListView(),
|
|
],
|
|
),
|
|
bottomNavigationBar: BottomNavigationBar(
|
|
showSelectedLabels: false,
|
|
showUnselectedLabels: false,
|
|
unselectedIconTheme: IconThemeData(
|
|
color:
|
|
Theme.of(context).colorScheme.inverseSurface.withAlpha(150)),
|
|
selectedIconTheme: IconThemeData(
|
|
color: Theme.of(context).colorScheme.inverseSurface),
|
|
items: [
|
|
BottomNavigationBarItem(
|
|
icon: FaIcon(FontAwesomeIcons.camera),
|
|
label: "",
|
|
),
|
|
BottomNavigationBarItem(
|
|
icon: FaIcon(FontAwesomeIcons.solidComments), label: ""),
|
|
],
|
|
onTap: (int index) {
|
|
activePageIdx = index;
|
|
if (index == 1) {
|
|
context.read<SendNextMediaTo>().updateSendNextMediaTo(null);
|
|
}
|
|
setState(() {
|
|
homeViewPageController.animateToPage(
|
|
index,
|
|
duration: const Duration(milliseconds: 100),
|
|
curve: Curves.bounceIn,
|
|
);
|
|
});
|
|
},
|
|
currentIndex: activePageIdx,
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|