165 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			165 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'dart:convert';
 | |
| 
 | |
| import 'package:desktop_multi_window/desktop_multi_window.dart';
 | |
| import 'package:flutter/material.dart';
 | |
| import 'package:flutter_hbb/common.dart';
 | |
| import 'package:flutter_hbb/common/shared_state.dart';
 | |
| import 'package:flutter_hbb/consts.dart';
 | |
| import 'package:flutter_hbb/desktop/pages/remote_page.dart';
 | |
| import 'package:flutter_hbb/desktop/widgets/tabbar_widget.dart';
 | |
| import 'package:flutter_hbb/utils/multi_window_manager.dart';
 | |
| import 'package:get/get.dart';
 | |
| 
 | |
| class ConnectionTabPage extends StatefulWidget {
 | |
|   final Map<String, dynamic> params;
 | |
| 
 | |
|   const ConnectionTabPage({Key? key, required this.params}) : super(key: key);
 | |
| 
 | |
|   @override
 | |
|   State<ConnectionTabPage> createState() => _ConnectionTabPageState(params);
 | |
| }
 | |
| 
 | |
| class _ConnectionTabPageState extends State<ConnectionTabPage> {
 | |
|   final tabController =
 | |
|       Get.put(DesktopTabController(tabType: DesktopTabType.remoteScreen));
 | |
|   static const IconData selectedIcon = Icons.desktop_windows_sharp;
 | |
|   static const IconData unselectedIcon = Icons.desktop_windows_outlined;
 | |
| 
 | |
|   var connectionMap = RxList<Widget>.empty(growable: true);
 | |
| 
 | |
|   _ConnectionTabPageState(Map<String, dynamic> params) {
 | |
|     final RxBool fullscreen = Get.find(tag: 'fullscreen');
 | |
|     final peerId = params['id'];
 | |
|     if (peerId != null) {
 | |
|       ConnectionTypeState.init(peerId);
 | |
|       tabController.add(TabInfo(
 | |
|           key: peerId,
 | |
|           label: peerId,
 | |
|           selectedIcon: selectedIcon,
 | |
|           unselectedIcon: unselectedIcon,
 | |
|           page: Obx(() => RemotePage(
 | |
|                 key: ValueKey(peerId),
 | |
|                 id: peerId,
 | |
|                 tabBarHeight:
 | |
|                     fullscreen.isTrue ? 0 : kDesktopRemoteTabBarHeight,
 | |
|               ))));
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   void initState() {
 | |
|     super.initState();
 | |
| 
 | |
|     tabController.onRemove = (_, id) => onRemoveId(id);
 | |
| 
 | |
|     rustDeskWinManager.setMethodHandler((call, fromWindowId) async {
 | |
|       print(
 | |
|           "call ${call.method} with args ${call.arguments} from window ${fromWindowId}");
 | |
| 
 | |
|       final RxBool fullscreen = Get.find(tag: 'fullscreen');
 | |
|       // for simplify, just replace connectionId
 | |
|       if (call.method == "new_remote_desktop") {
 | |
|         final args = jsonDecode(call.arguments);
 | |
|         final id = args['id'];
 | |
|         ConnectionTypeState.init(id);
 | |
|         window_on_top(windowId());
 | |
|         ConnectionTypeState.init(id);
 | |
|         tabController.add(TabInfo(
 | |
|             key: id,
 | |
|             label: id,
 | |
|             selectedIcon: selectedIcon,
 | |
|             unselectedIcon: unselectedIcon,
 | |
|             page: Obx(() => RemotePage(
 | |
|                   key: ValueKey(id),
 | |
|                   id: id,
 | |
|                   tabBarHeight:
 | |
|                       fullscreen.isTrue ? 0 : kDesktopRemoteTabBarHeight,
 | |
|                 ))));
 | |
|       } else if (call.method == "onDestroy") {
 | |
|         tabController.clear();
 | |
|       }
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   Widget build(BuildContext context) {
 | |
|     final theme = isDarkTheme() ? TarBarTheme.dark() : TarBarTheme.light();
 | |
|     final RxBool fullscreen = Get.find(tag: 'fullscreen');
 | |
|     return Obx(() => SubWindowDragToResizeArea(
 | |
|           resizeEdgeSize: fullscreen.value ? 1.0 : 8.0,
 | |
|           windowId: windowId(),
 | |
|           child: Container(
 | |
|             decoration: BoxDecoration(
 | |
|                 border: Border.all(color: MyTheme.color(context).border!)),
 | |
|             child: Scaffold(
 | |
|                 backgroundColor: MyTheme.color(context).bg,
 | |
|                 body: Obx(() => DesktopTab(
 | |
|                       controller: tabController,
 | |
|                       theme: theme,
 | |
|                       showTabBar: fullscreen.isFalse,
 | |
|                       onClose: () {
 | |
|                         tabController.clear();
 | |
|                       },
 | |
|                       tail: AddButton(
 | |
|                         theme: theme,
 | |
|                       ).paddingOnly(left: 10),
 | |
|                       pageViewBuilder: (pageView) {
 | |
|                         WindowController.fromWindowId(windowId())
 | |
|                             .setFullscreen(fullscreen.isTrue);
 | |
|                         return pageView;
 | |
|                       },
 | |
|                       tabBuilder: (key, icon, label, themeConf) => Obx(() {
 | |
|                         final connectionType = ConnectionTypeState.find(key);
 | |
|                         if (!connectionType.isValid()) {
 | |
|                           return Row(
 | |
|                             mainAxisAlignment: MainAxisAlignment.center,
 | |
|                             children: [
 | |
|                               icon,
 | |
|                               label,
 | |
|                             ],
 | |
|                           );
 | |
|                         } else {
 | |
|                           final msgDirect = translate(
 | |
|                               connectionType.direct.value ==
 | |
|                                       ConnectionType.strDirect
 | |
|                                   ? 'Direct Connection'
 | |
|                                   : 'Relay Connection');
 | |
|                           final msgSecure = translate(
 | |
|                               connectionType.secure.value ==
 | |
|                                       ConnectionType.strSecure
 | |
|                                   ? 'Secure Connection'
 | |
|                                   : 'Insecure Connection');
 | |
|                           return Row(
 | |
|                             mainAxisAlignment: MainAxisAlignment.center,
 | |
|                             children: [
 | |
|                               icon,
 | |
|                               Tooltip(
 | |
|                                 message: '$msgDirect\n$msgSecure',
 | |
|                                 child: Image.asset(
 | |
|                                   'assets/${connectionType.secure.value}${connectionType.direct.value}.png',
 | |
|                                   width: themeConf.iconSize,
 | |
|                                   height: themeConf.iconSize,
 | |
|                                 ).paddingOnly(right: 5),
 | |
|                               ),
 | |
|                               label,
 | |
|                             ],
 | |
|                           );
 | |
|                         }
 | |
|                       }),
 | |
|                     ))),
 | |
|           ),
 | |
|         ));
 | |
|   }
 | |
| 
 | |
|   void onRemoveId(String id) {
 | |
|     if (tabController.state.value.tabs.isEmpty) {
 | |
|       WindowController.fromWindowId(windowId()).hide();
 | |
|     }
 | |
|     ConnectionTypeState.delete(id);
 | |
|   }
 | |
| 
 | |
|   int windowId() {
 | |
|     return widget.params["windowId"];
 | |
|   }
 | |
| }
 |