2022-05-29 12:19:50 +03:00
import ' dart:convert ' ;
2022-08-18 12:25:47 +03:00
import ' package:desktop_multi_window/desktop_multi_window.dart ' ;
2020-11-06 13:04:04 +03:00
import ' package:flutter/material.dart ' ;
2022-08-11 11:03:04 +03:00
import ' package:flutter_hbb/desktop/pages/desktop_tab_page.dart ' ;
2022-08-15 07:35:10 +03:00
import ' package:flutter_hbb/desktop/pages/server_page.dart ' ;
2022-06-17 17:57:41 +03:00
import ' package:flutter_hbb/desktop/screen/desktop_file_transfer_screen.dart ' ;
2022-05-29 12:19:50 +03:00
import ' package:flutter_hbb/desktop/screen/desktop_remote_screen.dart ' ;
import ' package:flutter_hbb/utils/multi_window_manager.dart ' ;
2022-07-29 11:47:24 +03:00
import ' package:get/get.dart ' ;
2020-11-15 15:04:05 +03:00
import ' package:provider/provider.dart ' ;
2022-08-09 08:39:30 +03:00
import ' package:window_manager/window_manager.dart ' ;
2022-07-27 09:29:47 +03:00
2022-06-27 04:48:35 +03:00
// import 'package:window_manager/window_manager.dart';
2022-05-24 19:28:59 +03:00
2022-03-07 17:54:34 +03:00
import ' common.dart ' ;
2022-08-03 17:03:31 +03:00
import ' consts.dart ' ;
2022-05-24 18:33:00 +03:00
import ' mobile/pages/home_page.dart ' ;
import ' mobile/pages/server_page.dart ' ;
import ' mobile/pages/settings_page.dart ' ;
2022-08-09 08:50:26 +03:00
import ' models/platform_model.dart ' ;
2022-02-02 12:25:56 +03:00
2022-05-29 12:19:50 +03:00
int ? windowId ;
Future < Null > main ( List < String > args ) async {
2020-11-29 09:00:59 +03:00
WidgetsFlutterBinding . ensureInitialized ( ) ;
2022-08-11 13:59:26 +03:00
print ( " launch args: $ args " ) ;
2022-05-29 12:19:50 +03:00
if ( ! isDesktop ) {
2022-08-23 09:12:30 +03:00
runMobileApp ( ) ;
2022-05-29 12:19:50 +03:00
return ;
}
2022-05-31 07:09:47 +03:00
// main window
2022-05-29 12:19:50 +03:00
if ( args . isNotEmpty & & args . first = = ' multi_window ' ) {
windowId = int . parse ( args [ 1 ] ) ;
2022-08-18 12:25:47 +03:00
WindowController . fromWindowId ( windowId ! ) . showTitleBar ( false ) ;
2022-05-29 12:19:50 +03:00
final argument = args [ 2 ] . isEmpty
? Map < String , dynamic > ( )
: jsonDecode ( args [ 2 ] ) as Map < String , dynamic > ;
int type = argument [ ' type ' ] ? ? - 1 ;
2022-08-09 11:37:11 +03:00
argument [ ' windowId ' ] = windowId ;
2022-05-29 12:19:50 +03:00
WindowType wType = type . windowType ;
switch ( wType ) {
case WindowType . RemoteDesktop:
2022-08-03 17:03:31 +03:00
runRemoteScreen ( argument ) ;
2022-05-29 12:19:50 +03:00
break ;
2022-06-17 17:57:41 +03:00
case WindowType . FileTransfer:
2022-08-03 17:03:31 +03:00
runFileTransferScreen ( argument ) ;
2022-06-17 17:57:41 +03:00
break ;
2022-05-29 12:19:50 +03:00
default :
break ;
}
2022-08-11 13:59:26 +03:00
} else if ( args . isNotEmpty & & args . first = = ' --cm ' ) {
2022-08-17 16:28:36 +03:00
print ( " --cm started " ) ;
2022-08-11 13:59:26 +03:00
await windowManager . ensureInitialized ( ) ;
runConnectionManagerScreen ( ) ;
2022-05-29 12:19:50 +03:00
} else {
2022-08-09 08:39:30 +03:00
await windowManager . ensureInitialized ( ) ;
windowManager . setPreventClose ( true ) ;
2022-08-03 17:03:31 +03:00
runMainApp ( true ) ;
}
}
ThemeData getCurrentTheme ( ) {
2022-08-09 08:50:26 +03:00
return isDarkTheme ( ) ? MyTheme . darkTheme : MyTheme . lightTheme ;
2022-08-03 17:03:31 +03: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();
refreshCurrentUser ( ) ;
}
void runMainApp ( bool startService ) async {
2022-08-18 06:07:53 +03:00
WindowOptions windowOptions = getHiddenTitleBarWindowOptions ( Size ( 1280 , 720 ) ) ;
await Future . wait ( [
initEnv ( kAppTypeMain ) ,
windowManager . waitUntilReadyToShow ( windowOptions , ( ) async {
await windowManager . show ( ) ;
await windowManager . focus ( ) ;
} )
] ) ;
2022-08-03 17:03:31 +03:00
if ( startService ) {
2022-06-27 04:48:35 +03:00
// await windowManager.ensureInitialized();
2022-06-02 11:45:04 +03:00
// disable tray
// initTray();
2022-06-13 16:07:26 +03:00
gFFI . serverModel . startService ( ) ;
2022-05-24 19:28:59 +03:00
}
2022-08-03 17:03:31 +03:00
runApp ( App ( ) ) ;
}
2022-08-23 09:12:30 +03:00
void runMobileApp ( ) async {
await initEnv ( kAppTypeMain ) ;
if ( isAndroid ) androidChannelInit ( ) ;
runApp ( App ( ) ) ;
}
2022-08-03 17:03:31 +03:00
void runRemoteScreen ( Map < String , dynamic > argument ) async {
await initEnv ( kAppTypeDesktopRemote ) ;
runApp ( GetMaterialApp (
2022-08-11 11:03:04 +03:00
navigatorKey: globalKey ,
debugShowCheckedModeBanner: false ,
title: ' RustDesk - Remote Desktop ' ,
2022-08-03 17:03:31 +03:00
theme: getCurrentTheme ( ) ,
home: DesktopRemoteScreen (
params: argument ,
) ,
2022-08-11 11:03:04 +03:00
navigatorObservers: [
// FirebaseAnalyticsObserver(analytics: analytics),
] ,
2022-08-03 17:03:31 +03:00
) ) ;
}
void runFileTransferScreen ( Map < String , dynamic > argument ) async {
await initEnv ( kAppTypeDesktopFileTransfer ) ;
runApp ( GetMaterialApp (
2022-08-11 11:03:04 +03:00
navigatorKey: globalKey ,
debugShowCheckedModeBanner: false ,
title: ' RustDesk - File Transfer ' ,
2022-08-03 17:03:31 +03:00
theme: getCurrentTheme ( ) ,
2022-08-11 11:03:04 +03:00
home: DesktopFileTransferScreen ( params: argument ) ,
navigatorObservers: [
// FirebaseAnalyticsObserver(analytics: analytics),
2022-08-12 13:42:02 +03:00
] ) ) ;
2020-11-06 13:04:04 +03:00
}
2022-08-11 13:59:26 +03:00
void runConnectionManagerScreen ( ) async {
2022-08-18 04:51:19 +03:00
// initialize window
2022-08-18 06:07:53 +03:00
WindowOptions windowOptions = getHiddenTitleBarWindowOptions ( Size ( 300 , 400 ) ) ;
2022-08-17 19:34:04 +03:00
await Future . wait ( [
initEnv ( kAppTypeConnectionManager ) ,
2022-08-18 04:51:19 +03:00
windowManager . waitUntilReadyToShow ( windowOptions , ( ) async {
await windowManager . setAlignment ( Alignment . topRight ) ;
await windowManager . show ( ) ;
await windowManager . focus ( ) ;
} )
2022-08-17 19:34:04 +03:00
] ) ;
2022-08-18 06:07:53 +03:00
runApp ( GetMaterialApp (
debugShowCheckedModeBanner: false ,
theme: getCurrentTheme ( ) ,
home: DesktopServerPage ( ) ) ) ;
}
WindowOptions getHiddenTitleBarWindowOptions ( Size size ) {
return WindowOptions (
size: size ,
center: true ,
backgroundColor: Colors . transparent ,
skipTaskbar: false ,
titleBarStyle: TitleBarStyle . hidden ,
) ;
2022-08-11 13:59:26 +03:00
}
2020-11-15 20:13:26 +03:00
class App extends StatelessWidget {
2020-11-06 13:04:04 +03:00
@ override
Widget build ( BuildContext context ) {
2022-05-23 11:24:56 +03:00
// final analytics = FirebaseAnalytics.instance;
2022-03-24 12:58:33 +03:00
return MultiProvider (
2022-03-25 11:34:27 +03:00
providers: [
2022-06-17 17:57:41 +03:00
// global configuration
// use session related FFI when in remote control or file transfer page
2022-06-13 16:07:26 +03:00
ChangeNotifierProvider . value ( value: gFFI . ffiModel ) ,
ChangeNotifierProvider . value ( value: gFFI . imageModel ) ,
ChangeNotifierProvider . value ( value: gFFI . cursorModel ) ,
ChangeNotifierProvider . value ( value: gFFI . canvasModel ) ,
2022-07-27 09:29:47 +03:00
ChangeNotifierProvider . value ( value: gFFI . abModel ) ,
ChangeNotifierProvider . value ( value: gFFI . userModel ) ,
2022-03-25 11:34:27 +03:00
] ,
2022-06-13 16:07:26 +03:00
child: GetMaterialApp (
2022-04-20 14:00:05 +03:00
navigatorKey: globalKey ,
debugShowCheckedModeBanner: false ,
title: ' RustDesk ' ,
2022-07-29 11:47:24 +03:00
theme: getCurrentTheme ( ) ,
2022-05-23 11:02:37 +03:00
home: isDesktop
2022-08-11 11:03:04 +03:00
? DesktopTabPage ( )
2022-05-23 11:02:37 +03:00
: ! isAndroid
2022-06-13 16:07:26 +03:00
? WebHomePage ( )
: HomePage ( ) ,
2022-04-20 14:00:05 +03:00
navigatorObservers: [
2022-05-23 11:24:56 +03:00
// FirebaseAnalyticsObserver(analytics: analytics),
2022-04-20 14:00:05 +03:00
] ,
2022-08-12 13:42:02 +03:00
builder: isAndroid
? ( _ , child ) = > AccessibilityListener (
child: child ,
)
: null ) ,
2022-01-23 08:59:57 +03:00
) ;
2020-11-06 13:04:04 +03:00
}
}