2022-05-29 17:19:50 +08:00
|
|
|
import 'dart:convert';
|
|
|
|
|
2022-08-09 16:37:11 +08:00
|
|
|
import 'package:desktop_multi_window/desktop_multi_window.dart';
|
2022-05-29 17:19:50 +08:00
|
|
|
import 'package:flutter/material.dart';
|
2022-06-28 22:04:10 +08:00
|
|
|
import 'package:flutter_hbb/common.dart';
|
2022-08-03 15:31:19 +08:00
|
|
|
import 'package:flutter_hbb/consts.dart';
|
2022-05-29 17:19:50 +08:00
|
|
|
import 'package:flutter_hbb/desktop/pages/remote_page.dart';
|
2022-08-06 17:08:48 +08:00
|
|
|
import 'package:flutter_hbb/desktop/widgets/tabbar_widget.dart';
|
2022-05-29 17:19:50 +08:00
|
|
|
import 'package:flutter_hbb/utils/multi_window_manager.dart';
|
2022-06-28 22:04:10 +08:00
|
|
|
import 'package:get/get.dart';
|
|
|
|
|
|
|
|
import '../../models/model.dart';
|
2022-05-29 17:19:50 +08:00
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
2022-08-18 10:54:09 +08:00
|
|
|
class _ConnectionTabPageState extends State<ConnectionTabPage> {
|
2022-08-24 20:56:42 +08:00
|
|
|
final tabController = Get.put(DesktopTabController());
|
2022-08-16 20:48:36 +08:00
|
|
|
static final Rx<String> _fullscreenID = "".obs;
|
2022-08-24 20:56:42 +08:00
|
|
|
static final IconData selectedIcon = Icons.desktop_windows_sharp;
|
|
|
|
static final IconData unselectedIcon = Icons.desktop_windows_outlined;
|
2022-08-05 10:27:06 +08:00
|
|
|
|
|
|
|
var connectionMap = RxList<Widget>.empty(growable: true);
|
2022-05-29 17:19:50 +08:00
|
|
|
|
|
|
|
_ConnectionTabPageState(Map<String, dynamic> params) {
|
2022-05-31 16:27:54 +08:00
|
|
|
if (params['id'] != null) {
|
2022-08-24 20:56:42 +08:00
|
|
|
tabController.state.value.tabs.add(TabInfo(
|
2022-08-22 20:18:31 +08:00
|
|
|
key: params['id'],
|
2022-08-18 10:54:09 +08:00
|
|
|
label: params['id'],
|
|
|
|
selectedIcon: selectedIcon,
|
2022-08-24 20:56:42 +08:00
|
|
|
unselectedIcon: unselectedIcon,
|
|
|
|
page: RemotePage(
|
|
|
|
id: params['id'],
|
|
|
|
tabBarHeight:
|
|
|
|
_fullscreenID.value.isNotEmpty ? 0 : kDesktopRemoteTabBarHeight,
|
|
|
|
fullscreenID: _fullscreenID,
|
|
|
|
)));
|
2022-05-31 16:27:54 +08:00
|
|
|
}
|
2022-05-29 17:19:50 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
super.initState();
|
2022-08-24 20:56:42 +08:00
|
|
|
|
|
|
|
tabController.onRemove = (_, id) => onRemoveId(id);
|
|
|
|
|
2022-05-29 17:19:50 +08:00
|
|
|
rustDeskWinManager.setMethodHandler((call, fromWindowId) async {
|
|
|
|
print(
|
|
|
|
"call ${call.method} with args ${call.arguments} from window ${fromWindowId}");
|
|
|
|
// for simplify, just replace connectionId
|
|
|
|
if (call.method == "new_remote_desktop") {
|
2022-08-05 10:27:06 +08:00
|
|
|
final args = jsonDecode(call.arguments);
|
|
|
|
final id = args['id'];
|
2022-08-09 19:32:19 +08:00
|
|
|
window_on_top(windowId());
|
2022-08-24 20:56:42 +08:00
|
|
|
tabController.add(TabInfo(
|
|
|
|
key: id,
|
|
|
|
label: id,
|
|
|
|
selectedIcon: selectedIcon,
|
|
|
|
unselectedIcon: unselectedIcon,
|
|
|
|
closable: false,
|
|
|
|
page: RemotePage(
|
|
|
|
id: id,
|
|
|
|
tabBarHeight: _fullscreenID.value.isNotEmpty
|
|
|
|
? 0
|
|
|
|
: kDesktopRemoteTabBarHeight,
|
|
|
|
fullscreenID: _fullscreenID,
|
|
|
|
)));
|
2022-06-28 22:04:10 +08:00
|
|
|
} else if (call.method == "onDestroy") {
|
2022-08-24 20:56:42 +08:00
|
|
|
tabController.state.value.tabs.forEach((tab) {
|
|
|
|
print("executing onDestroy hook, closing ${tab.label}}");
|
|
|
|
final tag = tab.label;
|
2022-06-28 22:04:10 +08:00
|
|
|
ffi(tag).close().then((_) {
|
|
|
|
Get.delete<FFI>(tag: tag);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
Get.back();
|
2022-05-29 17:19:50 +08:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2022-08-24 20:56:42 +08:00
|
|
|
final theme = isDarkTheme() ? TarBarTheme.dark() : TarBarTheme.light();
|
2022-08-22 13:51:05 +08:00
|
|
|
return SubWindowDragToResizeArea(
|
|
|
|
windowId: windowId(),
|
2022-08-22 17:58:48 +08:00
|
|
|
child: Container(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
border: Border.all(color: MyTheme.color(context).border!)),
|
|
|
|
child: Scaffold(
|
2022-08-24 20:56:42 +08:00
|
|
|
backgroundColor: MyTheme.color(context).bg,
|
2022-08-24 21:20:50 +08:00
|
|
|
body: Obx(() => DesktopTab(
|
|
|
|
controller: tabController,
|
|
|
|
theme: theme,
|
|
|
|
isMainWindow: false,
|
|
|
|
showTabBar: _fullscreenID.value.isEmpty,
|
|
|
|
tail: AddButton(
|
|
|
|
theme: theme,
|
|
|
|
).paddingOnly(left: 10),
|
|
|
|
pageViewBuilder: (pageView) {
|
|
|
|
WindowController.fromWindowId(windowId())
|
|
|
|
.setFullscreen(_fullscreenID.value.isNotEmpty);
|
|
|
|
return pageView;
|
|
|
|
},
|
|
|
|
))),
|
2022-05-31 16:27:54 +08:00
|
|
|
),
|
2022-05-29 17:19:50 +08:00
|
|
|
);
|
|
|
|
}
|
2022-05-31 16:27:54 +08:00
|
|
|
|
|
|
|
void onRemoveId(String id) {
|
2022-08-16 22:15:45 +08:00
|
|
|
ffi(id).close();
|
2022-08-24 20:56:42 +08:00
|
|
|
if (tabController.state.value.tabs.length == 0) {
|
2022-08-09 16:37:11 +08:00
|
|
|
WindowController.fromWindowId(windowId()).close();
|
2022-08-09 09:01:06 +08:00
|
|
|
}
|
2022-05-31 16:27:54 +08:00
|
|
|
}
|
2022-08-09 16:37:11 +08:00
|
|
|
|
|
|
|
int windowId() {
|
|
|
|
return widget.params["windowId"];
|
|
|
|
}
|
2022-05-29 17:19:50 +08:00
|
|
|
}
|