mirror of
https://github.com/rustdesk/rustdesk.git
synced 2025-01-19 08:23:01 +08:00
930bf72c91
Signed-off-by: 21pages <pages21@163.com>
118 lines
3.6 KiB
Dart
118 lines
3.6 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/desktop/pages/file_manager_page.dart';
|
|
import 'package:flutter_hbb/desktop/widgets/tabbar_widget.dart';
|
|
import 'package:flutter_hbb/models/model.dart';
|
|
import 'package:flutter_hbb/utils/multi_window_manager.dart';
|
|
import 'package:get/get.dart';
|
|
|
|
/// File Transfer for multi tabs
|
|
class FileManagerTabPage extends StatefulWidget {
|
|
final Map<String, dynamic> params;
|
|
|
|
const FileManagerTabPage({Key? key, required this.params}) : super(key: key);
|
|
|
|
@override
|
|
State<FileManagerTabPage> createState() => _FileManagerTabPageState(params);
|
|
}
|
|
|
|
class _FileManagerTabPageState extends State<FileManagerTabPage> {
|
|
// refactor List<int> when using multi-tab
|
|
// this singleton is only for test
|
|
RxList<TabInfo> tabs = List<TabInfo>.empty(growable: true).obs;
|
|
final IconData selectedIcon = Icons.file_copy_sharp;
|
|
final IconData unselectedIcon = Icons.file_copy_outlined;
|
|
|
|
_FileManagerTabPageState(Map<String, dynamic> params) {
|
|
if (params['id'] != null) {
|
|
tabs.add(TabInfo(
|
|
key: params['id'],
|
|
label: params['id'],
|
|
selectedIcon: selectedIcon,
|
|
unselectedIcon: unselectedIcon));
|
|
}
|
|
}
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
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_file_transfer") {
|
|
final args = jsonDecode(call.arguments);
|
|
final id = args['id'];
|
|
window_on_top(windowId());
|
|
DesktopTabBar.onAdd(
|
|
tabs,
|
|
TabInfo(
|
|
key: id,
|
|
label: id,
|
|
selectedIcon: selectedIcon,
|
|
unselectedIcon: unselectedIcon));
|
|
} else if (call.method == "onDestroy") {
|
|
print(
|
|
"executing onDestroy hook, closing ${tabs.map((tab) => tab.label).toList()}");
|
|
tabs.forEach((tab) {
|
|
final tag = 'ft_${tab.label}';
|
|
ffi(tag).close().then((_) {
|
|
Get.delete<FFI>(tag: tag);
|
|
});
|
|
});
|
|
Get.back();
|
|
}
|
|
});
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return SubWindowDragToResizeArea(
|
|
windowId: windowId(),
|
|
child: Container(
|
|
decoration: BoxDecoration(
|
|
border: Border.all(color: MyTheme.color(context).border!)),
|
|
child: Scaffold(
|
|
backgroundColor: MyTheme.color(context).bg,
|
|
body: Column(
|
|
children: [
|
|
DesktopTabBar(
|
|
tabs: tabs,
|
|
onTabClose: onRemoveId,
|
|
dark: isDarkTheme(),
|
|
mainTab: false,
|
|
),
|
|
Expanded(
|
|
child: Obx(
|
|
() => PageView(
|
|
controller: DesktopTabBar.controller.value,
|
|
children: tabs
|
|
.map((tab) => FileManagerPage(
|
|
key: ValueKey(tab.label),
|
|
id: tab
|
|
.label)) //RemotePage(key: ValueKey(e), id: e))
|
|
.toList()),
|
|
),
|
|
)
|
|
],
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
|
|
void onRemoveId(String id) {
|
|
ffi("ft_$id").close();
|
|
if (tabs.length == 0) {
|
|
WindowController.fromWindowId(windowId()).close();
|
|
}
|
|
}
|
|
|
|
int windowId() {
|
|
return widget.params["windowId"];
|
|
}
|
|
}
|