mirror of
https://github.com/rustdesk/rustdesk.git
synced 2025-01-01 10:58:02 +08:00
121 lines
3.7 KiB
Dart
121 lines
3.7 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_hbb/common.dart';
|
|
import 'package:flutter_hbb/consts.dart';
|
|
import 'package:flutter_hbb/desktop/pages/desktop_home_page.dart';
|
|
import 'package:flutter_hbb/desktop/pages/desktop_setting_page.dart';
|
|
import 'package:flutter_hbb/desktop/widgets/tabbar_widget.dart';
|
|
import 'package:flutter_hbb/models/platform_model.dart';
|
|
import 'package:flutter_hbb/models/state_model.dart';
|
|
import 'package:get/get.dart';
|
|
import 'package:window_manager/window_manager.dart';
|
|
|
|
import '../../common/shared_state.dart';
|
|
|
|
class DesktopTabPage extends StatefulWidget {
|
|
const DesktopTabPage({Key? key}) : super(key: key);
|
|
|
|
@override
|
|
State<DesktopTabPage> createState() => _DesktopTabPageState();
|
|
|
|
static void onAddSetting(
|
|
{SettingsTabKey initialPage = SettingsTabKey.general}) {
|
|
try {
|
|
DesktopTabController tabController = Get.find();
|
|
tabController.add(TabInfo(
|
|
key: kTabLabelSettingPage,
|
|
label: kTabLabelSettingPage,
|
|
selectedIcon: Icons.build_sharp,
|
|
unselectedIcon: Icons.build_outlined,
|
|
page: DesktopSettingPage(
|
|
key: const ValueKey(kTabLabelSettingPage),
|
|
initialTabkey: initialPage,
|
|
)));
|
|
} catch (e) {
|
|
debugPrintStack(label: '$e');
|
|
}
|
|
}
|
|
}
|
|
|
|
class _DesktopTabPageState extends State<DesktopTabPage>
|
|
with WidgetsBindingObserver {
|
|
final tabController = DesktopTabController(tabType: DesktopTabType.main);
|
|
|
|
final RxBool _block = false.obs;
|
|
|
|
@override
|
|
void didChangeAppLifecycleState(AppLifecycleState state) {
|
|
super.didChangeAppLifecycleState(state);
|
|
if (state == AppLifecycleState.resumed) {
|
|
shouldBeBlocked(_block, canBeBlocked);
|
|
} else if (state == AppLifecycleState.inactive) {}
|
|
}
|
|
|
|
@override
|
|
void initState() {
|
|
super.initState();
|
|
WidgetsBinding.instance.addObserver(this);
|
|
Get.put<DesktopTabController>(tabController);
|
|
RemoteCountState.init();
|
|
tabController.add(TabInfo(
|
|
key: kTabLabelHomePage,
|
|
label: kTabLabelHomePage,
|
|
selectedIcon: Icons.home_sharp,
|
|
unselectedIcon: Icons.home_outlined,
|
|
closable: false,
|
|
page: DesktopHomePage(
|
|
key: const ValueKey(kTabLabelHomePage),
|
|
)));
|
|
if (bind.isIncomingOnly()) {
|
|
tabController.onSelected = (key) {
|
|
if (key == kTabLabelHomePage) {
|
|
windowManager.setSize(getIncomingOnlyHomeSize());
|
|
setResizable(false);
|
|
} else {
|
|
windowManager.setSize(getIncomingOnlySettingsSize());
|
|
setResizable(true);
|
|
}
|
|
};
|
|
}
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
WidgetsBinding.instance.removeObserver(this);
|
|
Get.delete<DesktopTabController>();
|
|
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final tabWidget = Container(
|
|
child: Scaffold(
|
|
backgroundColor: Theme.of(context).colorScheme.background,
|
|
body: DesktopTab(
|
|
controller: tabController,
|
|
tail: Offstage(
|
|
offstage: bind.isIncomingOnly() || bind.isDisableSettings(),
|
|
child: ActionIcon(
|
|
message: 'Settings',
|
|
icon: IconFont.menu,
|
|
onTap: DesktopTabPage.onAddSetting,
|
|
isClose: false,
|
|
),
|
|
),
|
|
)));
|
|
widget() => MouseRegion(
|
|
onEnter: (_) async {
|
|
await shouldBeBlocked(_block, canBeBlocked);
|
|
},
|
|
child: FocusScope(child: tabWidget, canRequestFocus: !_block.value));
|
|
return isMacOS || kUseCompatibleUiMode
|
|
? Obx(() => widget())
|
|
: Obx(
|
|
() => DragToResizeArea(
|
|
resizeEdgeSize: stateGlobal.resizeEdgeSize.value,
|
|
child: widget(),
|
|
),
|
|
);
|
|
}
|
|
}
|