rustdesk/flutter/lib/main.dart

165 lines
4.9 KiB
Dart
Raw Normal View History

import 'dart:convert';
2020-11-06 18:04:04 +08:00
import 'package:flutter/material.dart';
import 'package:flutter_hbb/desktop/pages/desktop_tab_page.dart';
import 'package:flutter_hbb/desktop/pages/server_page.dart';
import 'package:flutter_hbb/desktop/screen/desktop_file_transfer_screen.dart';
import 'package:flutter_hbb/desktop/screen/desktop_remote_screen.dart';
import 'package:flutter_hbb/utils/multi_window_manager.dart';
import 'package:get/get.dart';
2020-11-15 20:04:05 +08:00
import 'package:provider/provider.dart';
2022-08-09 13:39:30 +08:00
import 'package:window_manager/window_manager.dart';
// import 'package:window_manager/window_manager.dart';
2022-03-07 22:54:34 +08:00
import 'common.dart';
import 'consts.dart';
2022-05-24 23:33:00 +08:00
import 'mobile/pages/home_page.dart';
import 'mobile/pages/server_page.dart';
import 'mobile/pages/settings_page.dart';
import 'models/platform_model.dart';
2022-02-02 17:25:56 +08:00
int? windowId;
Future<Null> main(List<String> args) async {
2020-11-29 14:00:59 +08:00
WidgetsFlutterBinding.ensureInitialized();
print("launch args: $args");
if (!isDesktop) {
runMainApp(false);
return;
}
// main window
if (args.isNotEmpty && args.first == 'multi_window') {
windowId = int.parse(args[1]);
final argument = args[2].isEmpty
? Map<String, dynamic>()
: jsonDecode(args[2]) as Map<String, dynamic>;
int type = argument['type'] ?? -1;
argument['windowId'] = windowId;
WindowType wType = type.windowType;
switch (wType) {
case WindowType.RemoteDesktop:
runRemoteScreen(argument);
break;
case WindowType.FileTransfer:
runFileTransferScreen(argument);
break;
default:
break;
}
} else if (args.isNotEmpty && args.first == '--cm') {
print("--cm started");
await windowManager.ensureInitialized();
runConnectionManagerScreen();
} else {
2022-08-09 13:39:30 +08:00
await windowManager.ensureInitialized();
windowManager.setPreventClose(true);
runMainApp(true);
}
}
ThemeData getCurrentTheme() {
return isDarkTheme() ? MyTheme.darkTheme : MyTheme.lightTheme;
}
Future<void> initEnv(String appType) async {
await platformFFI.init(appType);
// global FFI, use this **ONLY** for global configuration
// for convenience, use global FFI on mobile platform
// focus on multi-ffi on desktop first
await initGlobalFFI();
// await Firebase.initializeApp();
if (isAndroid) {
toAndroidChannelInit();
}
refreshCurrentUser();
}
void runMainApp(bool startService) async {
await initEnv(kAppTypeMain);
if (startService) {
// await windowManager.ensureInitialized();
// disable tray
// initTray();
gFFI.serverModel.startService();
}
runApp(App());
}
void runRemoteScreen(Map<String, dynamic> argument) async {
await initEnv(kAppTypeDesktopRemote);
runApp(GetMaterialApp(
navigatorKey: globalKey,
debugShowCheckedModeBanner: false,
title: 'RustDesk - Remote Desktop',
theme: getCurrentTheme(),
home: DesktopRemoteScreen(
params: argument,
),
navigatorObservers: [
// FirebaseAnalyticsObserver(analytics: analytics),
],
));
}
void runFileTransferScreen(Map<String, dynamic> argument) async {
await initEnv(kAppTypeDesktopFileTransfer);
runApp(GetMaterialApp(
navigatorKey: globalKey,
debugShowCheckedModeBanner: false,
title: 'RustDesk - File Transfer',
theme: getCurrentTheme(),
home: DesktopFileTransferScreen(params: argument),
navigatorObservers: [
// FirebaseAnalyticsObserver(analytics: analytics),
2022-08-12 18:42:02 +08:00
]));
2020-11-06 18:04:04 +08:00
}
void runConnectionManagerScreen() async {
await Future.wait([
initEnv(kAppTypeConnectionManager),
windowManager
.setSize(Size(300, 400))
.then((value) => windowManager.setAlignment(Alignment.topRight))
]);
runApp(GetMaterialApp(theme: getCurrentTheme(), home: DesktopServerPage()));
}
2020-11-16 01:13:26 +08:00
class App extends StatelessWidget {
2020-11-06 18:04:04 +08:00
@override
Widget build(BuildContext context) {
2022-05-23 16:24:56 +08:00
// final analytics = FirebaseAnalytics.instance;
2022-03-24 17:58:33 +08:00
return MultiProvider(
2022-03-25 16:34:27 +08:00
providers: [
// global configuration
// use session related FFI when in remote control or file transfer page
ChangeNotifierProvider.value(value: gFFI.ffiModel),
ChangeNotifierProvider.value(value: gFFI.imageModel),
ChangeNotifierProvider.value(value: gFFI.cursorModel),
ChangeNotifierProvider.value(value: gFFI.canvasModel),
ChangeNotifierProvider.value(value: gFFI.abModel),
ChangeNotifierProvider.value(value: gFFI.userModel),
2022-03-25 16:34:27 +08:00
],
child: GetMaterialApp(
2022-04-20 19:00:05 +08:00
navigatorKey: globalKey,
debugShowCheckedModeBanner: false,
title: 'RustDesk',
theme: getCurrentTheme(),
2022-05-23 16:02:37 +08:00
home: isDesktop
? DesktopTabPage()
2022-05-23 16:02:37 +08:00
: !isAndroid
? WebHomePage()
: HomePage(),
2022-04-20 19:00:05 +08:00
navigatorObservers: [
2022-05-23 16:24:56 +08:00
// FirebaseAnalyticsObserver(analytics: analytics),
2022-04-20 19:00:05 +08:00
],
2022-08-12 18:42:02 +08:00
builder: isAndroid
? (_, child) => AccessibilityListener(
child: child,
)
: null),
2022-01-23 13:59:57 +08:00
);
2020-11-06 18:04:04 +08:00
}
}