caesar-transfer/flutter_test_gui/lib/main.dart

125 lines
3.5 KiB
Dart

import 'dart:io';
import 'package:flutter/material.dart';
import 'package:flutter_test_gui/src/rust/frb_generated.dart';
import 'package:bitsdojo_window/bitsdojo_window.dart';
import 'package:flutter_test_gui/pages/settings_screen.dart';
import 'package:flutter_test_gui/pages/send_screen.dart';
import 'package:flutter_test_gui/pages/receive_screen.dart';
import 'package:flutter_test_gui/consts/consts.dart';
Future<void> main() async {
await RustLib.init();
runApp(const MyApp());
if (Platform.isWindows || Platform.isLinux || Platform.isMacOS) {
doWhenWindowReady(() {
final win = appWindow;
const initialSize = Size(720, 512);
win.minSize = initialSize;
win.size = initialSize;
win.alignment = Alignment.center;
win.title = 'Caesar Test Demo';
win.show();
});
}
}
// const backColor = Color(0xFF32363E);
// const highlightColor = Color(0xFF98C379);
// const textColor = Color(0xFFABB2BF);
class MyApp extends StatefulWidget {
const MyApp({super.key});
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Caesar-Transfer',
theme: ThemeData(
useMaterial3: true,
),
home: const MyHomePage(title: 'Caesar-Transfer'),
);
}
}
class MyHomePage extends StatefulWidget {
const MyHomePage({super.key, required this.title});
final String title;
@override
State<MyHomePage> createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
final List<Widget> _screens = [
SendScreen(),
ReceiveScreen(),
];
int _selectedIndex = 0;
void _onItemTapped(int index) {
setState(() {
_selectedIndex = index;
});
}
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false,
home: Scaffold(
backgroundColor: Constants.backColor,
appBar: AppBar(
backgroundColor: const Color(0xFF292c3c), //0xFF282C34),
centerTitle: true,
title: Text(
widget.title,
style: const TextStyle(color: Constants.textColor),
),
actions: [
PopupMenuButton<String>(
onSelected: (String result) {
if (result == 'Settings') {
Navigator.push(
context,
MaterialPageRoute(builder: (context) => SettingsScreen()),
);
}
},
itemBuilder: (BuildContext context) => <PopupMenuEntry<String>>[
const PopupMenuItem<String>(
value: 'Settings',
child: Text('Settings'),
)
],
),
],
),
body: _screens[_selectedIndex],
bottomNavigationBar: BottomNavigationBar(
backgroundColor: const Color(0xFF292c3c), //0xFF282C34),
items: const <BottomNavigationBarItem>[
BottomNavigationBarItem(
icon: Icon(Icons.send),
label: 'Send',
),
BottomNavigationBarItem(
icon: Icon(Icons.download),
label: 'Receive',
),
],
currentIndex: _selectedIndex,
selectedItemColor: Constants.highlightColor,
unselectedItemColor: Constants.textColor,
onTap: _onItemTapped,
),
),
);
}
}