2022-05-29 17:19:50 +08:00
|
|
|
import 'dart:convert';
|
|
|
|
|
2020-11-06 18:04:04 +08:00
|
|
|
import 'package:flutter/material.dart';
|
2022-05-24 23:33:00 +08:00
|
|
|
import 'package:flutter_hbb/desktop/pages/desktop_home_page.dart';
|
2022-06-17 22:57:41 +08:00
|
|
|
import 'package:flutter_hbb/desktop/screen/desktop_file_transfer_screen.dart';
|
2022-05-29 17:19:50 +08:00
|
|
|
import 'package:flutter_hbb/desktop/screen/desktop_remote_screen.dart';
|
|
|
|
import 'package:flutter_hbb/utils/multi_window_manager.dart';
|
2022-04-19 13:07:45 +08:00
|
|
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
2022-07-29 16:47:24 +08:00
|
|
|
import 'package:get/get.dart';
|
2022-06-13 21:07:26 +08:00
|
|
|
import 'package:get/route_manager.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';
|
2022-07-27 14:29:47 +08:00
|
|
|
|
2022-06-27 09:48:35 +08:00
|
|
|
// import 'package:window_manager/window_manager.dart';
|
2022-05-25 00:28:59 +08:00
|
|
|
|
2022-03-07 22:54:34 +08:00
|
|
|
import 'common.dart';
|
2022-08-03 22:03:31 +08:00
|
|
|
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';
|
2022-08-09 13:50:26 +08:00
|
|
|
import 'models/platform_model.dart';
|
2022-02-02 17:25:56 +08:00
|
|
|
|
2022-05-29 17:19:50 +08:00
|
|
|
int? windowId;
|
|
|
|
|
|
|
|
Future<Null> main(List<String> args) async {
|
2020-11-29 14:00:59 +08:00
|
|
|
WidgetsFlutterBinding.ensureInitialized();
|
2022-05-29 17:19:50 +08:00
|
|
|
|
|
|
|
if (!isDesktop) {
|
2022-08-03 22:03:31 +08:00
|
|
|
runMainApp(false);
|
2022-05-29 17:19:50 +08:00
|
|
|
return;
|
|
|
|
}
|
2022-05-31 12:09:47 +08:00
|
|
|
// main window
|
2022-05-29 17:19:50 +08:00
|
|
|
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;
|
2022-08-09 16:37:11 +08:00
|
|
|
argument['windowId'] = windowId;
|
2022-05-29 17:19:50 +08:00
|
|
|
WindowType wType = type.windowType;
|
|
|
|
switch (wType) {
|
|
|
|
case WindowType.RemoteDesktop:
|
2022-08-03 22:03:31 +08:00
|
|
|
runRemoteScreen(argument);
|
2022-05-29 17:19:50 +08:00
|
|
|
break;
|
2022-06-17 22:57:41 +08:00
|
|
|
case WindowType.FileTransfer:
|
2022-08-03 22:03:31 +08:00
|
|
|
runFileTransferScreen(argument);
|
2022-06-17 22:57:41 +08:00
|
|
|
break;
|
2022-05-29 17:19:50 +08:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} else {
|
2022-08-09 13:39:30 +08:00
|
|
|
await windowManager.ensureInitialized();
|
|
|
|
windowManager.setPreventClose(true);
|
2022-08-03 22:03:31 +08:00
|
|
|
runMainApp(true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ThemeData getCurrentTheme() {
|
2022-08-09 13:50:26 +08:00
|
|
|
return isDarkTheme() ? MyTheme.darkTheme : MyTheme.lightTheme;
|
2022-08-03 22:03:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
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) {
|
2022-06-27 09:48:35 +08:00
|
|
|
// await windowManager.ensureInitialized();
|
2022-06-02 16:45:04 +08:00
|
|
|
// disable tray
|
|
|
|
// initTray();
|
2022-06-13 21:07:26 +08:00
|
|
|
gFFI.serverModel.startService();
|
2022-05-25 00:28:59 +08:00
|
|
|
}
|
2022-08-03 22:03:31 +08:00
|
|
|
runApp(App());
|
|
|
|
}
|
|
|
|
|
|
|
|
void runRemoteScreen(Map<String, dynamic> argument) async {
|
|
|
|
await initEnv(kAppTypeDesktopRemote);
|
|
|
|
runApp(GetMaterialApp(
|
|
|
|
theme: getCurrentTheme(),
|
|
|
|
home: DesktopRemoteScreen(
|
|
|
|
params: argument,
|
|
|
|
),
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
void runFileTransferScreen(Map<String, dynamic> argument) async {
|
|
|
|
await initEnv(kAppTypeDesktopFileTransfer);
|
|
|
|
runApp(GetMaterialApp(
|
|
|
|
theme: getCurrentTheme(),
|
|
|
|
home: DesktopFileTransferScreen(params: argument)));
|
2020-11-06 18:04:04 +08:00
|
|
|
}
|
|
|
|
|
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: [
|
2022-06-17 22:57:41 +08:00
|
|
|
// global configuration
|
|
|
|
// use session related FFI when in remote control or file transfer page
|
2022-06-13 21:07:26 +08:00
|
|
|
ChangeNotifierProvider.value(value: gFFI.ffiModel),
|
|
|
|
ChangeNotifierProvider.value(value: gFFI.imageModel),
|
|
|
|
ChangeNotifierProvider.value(value: gFFI.cursorModel),
|
|
|
|
ChangeNotifierProvider.value(value: gFFI.canvasModel),
|
2022-07-27 14:29:47 +08:00
|
|
|
ChangeNotifierProvider.value(value: gFFI.abModel),
|
|
|
|
ChangeNotifierProvider.value(value: gFFI.userModel),
|
2022-03-25 16:34:27 +08:00
|
|
|
],
|
2022-06-13 21:07:26 +08:00
|
|
|
child: GetMaterialApp(
|
2022-04-20 19:00:05 +08:00
|
|
|
navigatorKey: globalKey,
|
|
|
|
debugShowCheckedModeBanner: false,
|
|
|
|
title: 'RustDesk',
|
2022-07-29 16:47:24 +08:00
|
|
|
theme: getCurrentTheme(),
|
2022-05-23 16:02:37 +08:00
|
|
|
home: isDesktop
|
|
|
|
? DesktopHomePage()
|
|
|
|
: !isAndroid
|
2022-06-13 21:07:26 +08:00
|
|
|
? 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
|
|
|
FlutterSmartDialog.observer
|
|
|
|
],
|
|
|
|
builder: FlutterSmartDialog.init(
|
|
|
|
builder: isAndroid
|
|
|
|
? (_, child) => AccessibilityListener(
|
2022-08-03 22:03:31 +08:00
|
|
|
child: child,
|
|
|
|
)
|
2022-04-20 19:00:05 +08:00
|
|
|
: null)),
|
2022-01-23 13:59:57 +08:00
|
|
|
);
|
2020-11-06 18:04:04 +08:00
|
|
|
}
|
|
|
|
}
|