diff --git a/flutter/assets/actions.svg b/flutter/assets/actions.svg
index feaf416cd..5403853db 100644
--- a/flutter/assets/actions.svg
+++ b/flutter/assets/actions.svg
@@ -1,3 +1,2 @@
-
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/chat.svg b/flutter/assets/chat.svg
index 830ef0d33..7088107b0 100644
--- a/flutter/assets/chat.svg
+++ b/flutter/assets/chat.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/close.svg b/flutter/assets/close.svg
index 1e9a30711..7488acc9f 100644
--- a/flutter/assets/close.svg
+++ b/flutter/assets/close.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/display.svg b/flutter/assets/display.svg
index 8a87116ff..b5a88106e 100644
--- a/flutter/assets/display.svg
+++ b/flutter/assets/display.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/fullscreen.svg b/flutter/assets/fullscreen.svg
index 73d79cf0e..cd01f93f9 100644
--- a/flutter/assets/fullscreen.svg
+++ b/flutter/assets/fullscreen.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/fullscreen_exit.svg b/flutter/assets/fullscreen_exit.svg
index f2b3ae27b..8d4414897 100644
--- a/flutter/assets/fullscreen_exit.svg
+++ b/flutter/assets/fullscreen_exit.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/keyboard.svg b/flutter/assets/keyboard.svg
index 569c68727..d5481d7a1 100644
--- a/flutter/assets/keyboard.svg
+++ b/flutter/assets/keyboard.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/pinned.svg b/flutter/assets/pinned.svg
index 2563015f7..dd718b96a 100644
--- a/flutter/assets/pinned.svg
+++ b/flutter/assets/pinned.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/rec.svg b/flutter/assets/rec.svg
index 14546b971..33a57e9d0 100644
--- a/flutter/assets/rec.svg
+++ b/flutter/assets/rec.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/assets/unpinned.svg b/flutter/assets/unpinned.svg
index ba4ab5328..9e9e3de8b 100644
--- a/flutter/assets/unpinned.svg
+++ b/flutter/assets/unpinned.svg
@@ -1,2 +1,2 @@
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/flutter/lib/desktop/pages/remote_page.dart b/flutter/lib/desktop/pages/remote_page.dart
index 211d36c39..dac62032f 100644
--- a/flutter/lib/desktop/pages/remote_page.dart
+++ b/flutter/lib/desktop/pages/remote_page.dart
@@ -201,7 +201,7 @@ class _RemotePageState extends State
Widget buildBody(BuildContext context) {
return Scaffold(
- backgroundColor: Theme.of(context).backgroundColor,
+ backgroundColor: Theme.of(context).colorScheme.background,
/// the Overlay key will be set with _blockableOverlayState in BlockableOverlay
/// see override build() in [BlockableOverlay]
diff --git a/flutter/lib/desktop/pages/remote_tab_page.dart b/flutter/lib/desktop/pages/remote_tab_page.dart
index 9b00b481f..610a7d1a5 100644
--- a/flutter/lib/desktop/pages/remote_tab_page.dart
+++ b/flutter/lib/desktop/pages/remote_tab_page.dart
@@ -22,7 +22,10 @@ import 'package:bot_toast/bot_toast.dart';
import '../../models/platform_model.dart';
class _MenuTheme {
- static const Color commonColor = MyTheme.accent;
+ static const Color blueColor = MyTheme.button;
+ static const Color hoverBlueColor = MyTheme.accent;
+ static const Color redColor = Colors.redAccent;
+ static const Color hoverRedColor = Colors.red;
// kMinInteractiveDimension
static const double height = 20.0;
static const double dividerHeight = 12.0;
@@ -134,7 +137,7 @@ class _ConnectionTabPageState extends State {
width: stateGlobal.windowBorderWidth.value),
),
child: Scaffold(
- backgroundColor: Theme.of(context).backgroundColor,
+ backgroundColor: Theme.of(context).colorScheme.background,
body: DesktopTab(
controller: tabController,
onWindowCloseButton: handleWindowCloseButton,
@@ -280,7 +283,7 @@ class _ConnectionTabPageState extends State {
.map((entry) => entry.build(
context,
const MenuConfig(
- commonColor: _MenuTheme.commonColor,
+ commonColor: _MenuTheme.blueColor,
height: _MenuTheme.height,
dividerHeight: _MenuTheme.dividerHeight,
)))
diff --git a/flutter/lib/desktop/widgets/material_mod_popup_menu.dart b/flutter/lib/desktop/widgets/material_mod_popup_menu.dart
index 666c9a6e2..05c3059d4 100644
--- a/flutter/lib/desktop/widgets/material_mod_popup_menu.dart
+++ b/flutter/lib/desktop/widgets/material_mod_popup_menu.dart
@@ -5,6 +5,8 @@
import 'package:flutter/foundation.dart';
import 'package:flutter/rendering.dart';
import 'package:flutter/material.dart';
+import 'package:flutter_hbb/common.dart';
+import 'package:flutter_hbb/desktop/widgets/menu_button.dart';
// Examples can assume:
// enum Commands { heroAndScholar, hurricaneCame }
@@ -1391,22 +1393,21 @@ class PopupMenuButtonState extends State> {
onTap: widget.enabled ? showButtonMenu : null,
onHover: widget.onHover,
canRequestFocus: _canRequestFocus,
- radius: widget.splashRadius,
enableFeedback: enableFeedback,
child: widget.child,
),
);
}
- return IconButton(
+ return MenuButton(
icon: widget.icon ?? Icon(Icons.adaptive.more),
- padding: widget.padding,
- splashRadius: widget.splashRadius,
iconSize: widget.iconSize ?? iconTheme.size ?? _kDefaultIconSize,
tooltip:
widget.tooltip ?? MaterialLocalizations.of(context).showMenuTooltip,
onPressed: widget.enabled ? showButtonMenu : null,
enableFeedback: enableFeedback,
+ color: MyTheme.button,
+ hoverColor: MyTheme.accent,
);
}
}
diff --git a/flutter/lib/desktop/widgets/menu_button.dart b/flutter/lib/desktop/widgets/menu_button.dart
new file mode 100644
index 000000000..ce63dcab1
--- /dev/null
+++ b/flutter/lib/desktop/widgets/menu_button.dart
@@ -0,0 +1,63 @@
+import 'package:flutter/material.dart';
+
+class MenuButton extends StatefulWidget {
+ final GestureTapCallback? onPressed;
+ final Color color;
+ final Color hoverColor;
+ final Color? splashColor;
+ final Widget icon;
+ final double iconSize;
+ final String tooltip;
+ final EdgeInsetsGeometry padding;
+ final bool enableFeedback;
+ const MenuButton({
+ super.key,
+ required this.onPressed,
+ required this.color,
+ required this.hoverColor,
+ required this.icon,
+ required this.iconSize,
+ required this.tooltip,
+ this.splashColor,
+ this.padding = const EdgeInsets.all(5),
+ this.enableFeedback = true,
+ });
+
+ @override
+ State createState() => _MenuButtonState();
+}
+
+class _MenuButtonState extends State {
+ bool _isHover = false;
+
+ @override
+ Widget build(BuildContext context) {
+ return Padding(
+ padding: widget.padding,
+ child: Tooltip(
+ message: widget.tooltip,
+ child: Material(
+ type: MaterialType.transparency,
+ child: Ink(
+ decoration: BoxDecoration(
+ borderRadius: BorderRadius.circular(5),
+ color: _isHover ? widget.hoverColor : widget.color,
+ ),
+ child: InkWell(
+ onHover: (val) {
+ setState(() {
+ _isHover = val;
+ });
+ },
+ borderRadius: BorderRadius.circular(5),
+ splashColor: widget.splashColor,
+ enableFeedback: widget.enableFeedback,
+ onTap: widget.onPressed,
+ child: widget.icon,
+ ),
+ ),
+ ),
+ ),
+ );
+ }
+}
diff --git a/flutter/lib/desktop/widgets/remote_menubar.dart b/flutter/lib/desktop/widgets/remote_menubar.dart
index 77d687d93..ff586a1f1 100644
--- a/flutter/lib/desktop/widgets/remote_menubar.dart
+++ b/flutter/lib/desktop/widgets/remote_menubar.dart
@@ -5,6 +5,7 @@ import 'dart:ui' as ui;
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
+import 'package:flutter_hbb/desktop/widgets/menu_button.dart';
import 'package:flutter_hbb/models/chat_model.dart';
import 'package:flutter_hbb/models/state_model.dart';
import 'package:flutter_hbb/consts.dart';
@@ -94,7 +95,10 @@ class MenubarState {
}
class _MenubarTheme {
- static const Color commonColor = MyTheme.accent;
+ static const Color blueColor = MyTheme.button;
+ static const Color hoverBlueColor = MyTheme.accent;
+ static const Color redColor = Colors.redAccent;
+ static const Color hoverRedColor = Colors.red;
// kMinInteractiveDimension
static const double height = 20.0;
static const double dividerHeight = 12.0;
@@ -412,7 +416,7 @@ class _RemoteMenubarState extends State {
if (widget.ffi.ffiModel.isPeerAndroid) {
menubarItems.add(IconButton(
tooltip: translate('Mobile Actions'),
- color: _MenubarTheme.commonColor,
+ color: _MenubarTheme.blueColor,
icon: const Icon(Icons.build),
onPressed: () {
widget.ffi.dialogManager
@@ -433,7 +437,7 @@ class _RemoteMenubarState extends State {
menubarItems.add(_buildClose(context, iconSize));
return PopupMenuTheme(
data: const PopupMenuThemeData(
- textStyle: TextStyle(color: _MenubarTheme.commonColor)),
+ textStyle: TextStyle(color: _MenubarTheme.blueColor)),
child: Column(
mainAxisSize: MainAxisSize.min,
children: [
@@ -457,8 +461,7 @@ class _RemoteMenubarState extends State {
Widget _buildPinMenubar(BuildContext context, double iconSize) {
return Obx(
- () => IconButton(
- padding: EdgeInsets.zero,
+ () => MenuButton(
iconSize: iconSize,
tooltip: translate(pin ? 'Unpin menubar' : 'Pin menubar'),
onPressed: () {
@@ -466,15 +469,16 @@ class _RemoteMenubarState extends State {
},
icon: SvgPicture.asset(
pin ? "assets/pinned.svg" : "assets/unpinned.svg",
- color: pin ? _MenubarTheme.commonColor : Colors.grey[800],
+ color: Colors.white,
),
+ color: pin ? _MenubarTheme.blueColor : Colors.grey[800]!,
+ hoverColor: pin ? _MenubarTheme.hoverBlueColor : Colors.grey[850]!,
),
);
}
Widget _buildFullscreen(BuildContext context, double iconSize) {
- return IconButton(
- padding: EdgeInsets.zero,
+ return MenuButton(
iconSize: iconSize,
tooltip: translate(isFullscreen ? 'Exit Fullscreen' : 'Fullscreen'),
onPressed: () {
@@ -482,8 +486,10 @@ class _RemoteMenubarState extends State {
},
icon: SvgPicture.asset(
isFullscreen ? "assets/fullscreen_exit.svg" : "assets/fullscreen.svg",
- color: _MenubarTheme.commonColor,
+ color: Colors.white,
),
+ color: _MenubarTheme.blueColor,
+ hoverColor: _MenubarTheme.hoverBlueColor,
);
}
@@ -492,14 +498,13 @@ class _RemoteMenubarState extends State {
return mod_menu.PopupMenuButton(
iconSize: iconSize,
tooltip: translate('Select Monitor'),
- padding: EdgeInsets.zero,
position: mod_menu.PopupMenuPosition.under,
icon: Stack(
alignment: Alignment.center,
children: [
SvgPicture.asset(
"assets/display.svg",
- color: _MenubarTheme.commonColor,
+ color: Colors.white,
),
Padding(
padding: const EdgeInsets.only(bottom: 3.9),
@@ -520,7 +525,10 @@ class _RemoteMenubarState extends State {
Stack(
alignment: Alignment.center,
children: [
- SvgPicture.asset("assets/display.svg"),
+ SvgPicture.asset(
+ "assets/display.svg",
+ color: Colors.white,
+ ),
TextButton(
child: Container(
alignment: AlignmentDirectional.center,
@@ -531,7 +539,7 @@ class _RemoteMenubarState extends State {
child: Text(
(i + 1).toString(),
style: TextStyle(
- color: Theme.of(context).scaffoldBackgroundColor,
+ color: Colors.white,
),
),
),
@@ -573,7 +581,7 @@ class _RemoteMenubarState extends State {
padding: EdgeInsets.zero,
icon: SvgPicture.asset(
"assets/actions.svg",
- color: _MenubarTheme.commonColor,
+ color: Colors.white,
),
tooltip: translate('Control Actions'),
position: mod_menu.PopupMenuPosition.under,
@@ -581,7 +589,7 @@ class _RemoteMenubarState extends State {
.map((entry) => entry.build(
context,
const MenuConfig(
- commonColor: _MenubarTheme.commonColor,
+ commonColor: _MenubarTheme.blueColor,
height: _MenubarTheme.height,
dividerHeight: _MenubarTheme.dividerHeight,
)))
@@ -606,7 +614,7 @@ class _RemoteMenubarState extends State {
padding: EdgeInsets.zero,
icon: SvgPicture.asset(
"assets/display.svg",
- color: _MenubarTheme.commonColor,
+ color: Colors.white,
),
tooltip: translate('Display Settings'),
position: mod_menu.PopupMenuPosition.under,
@@ -616,7 +624,7 @@ class _RemoteMenubarState extends State {
.map((entry) => entry.build(
context,
const MenuConfig(
- commonColor: _MenubarTheme.commonColor,
+ commonColor: _MenubarTheme.blueColor,
height: _MenubarTheme.height,
dividerHeight: _MenubarTheme.dividerHeight,
)))
@@ -640,7 +648,7 @@ class _RemoteMenubarState extends State {
padding: EdgeInsets.zero,
icon: SvgPicture.asset(
"assets/keyboard.svg",
- color: _MenubarTheme.commonColor,
+ color: Colors.white,
),
tooltip: translate('Keyboard Settings'),
position: mod_menu.PopupMenuPosition.under,
@@ -648,7 +656,7 @@ class _RemoteMenubarState extends State {
.map((entry) => entry.build(
context,
const MenuConfig(
- commonColor: _MenubarTheme.commonColor,
+ commonColor: _MenubarTheme.blueColor,
height: _MenubarTheme.height,
dividerHeight: _MenubarTheme.dividerHeight,
)))
@@ -661,8 +669,7 @@ class _RemoteMenubarState extends State {
return Consumer(builder: ((context, value, child) {
if (value.permissions['recording'] != false) {
return Consumer(
- builder: (context, value, child) => IconButton(
- padding: EdgeInsets.zero,
+ builder: (context, value, child) => MenuButton(
iconSize: iconSize,
tooltip: value.start
? translate('Stop session recording')
@@ -670,8 +677,13 @@ class _RemoteMenubarState extends State {
onPressed: () => value.toggle(),
icon: SvgPicture.asset(
"assets/rec.svg",
- color: value.start ? Colors.red : _MenubarTheme.commonColor,
+ color: Colors.white,
),
+ color:
+ value.start ? _MenubarTheme.redColor : _MenubarTheme.blueColor,
+ hoverColor: value.start
+ ? _MenubarTheme.hoverRedColor
+ : _MenubarTheme.hoverBlueColor,
),
);
} else {
@@ -681,17 +693,18 @@ class _RemoteMenubarState extends State {
}
Widget _buildClose(BuildContext context, double iconSize) {
- return IconButton(
+ return MenuButton(
iconSize: iconSize,
- padding: EdgeInsets.zero,
tooltip: translate('Close'),
onPressed: () {
clientClose(widget.id, widget.ffi.dialogManager);
},
icon: SvgPicture.asset(
"assets/close.svg",
- color: Colors.red,
+ color: Colors.white,
),
+ color: _MenubarTheme.redColor,
+ hoverColor: _MenubarTheme.hoverRedColor,
);
}
@@ -704,7 +717,7 @@ class _RemoteMenubarState extends State {
padding: EdgeInsets.zero,
icon: SvgPicture.asset(
"assets/chat.svg",
- color: _MenubarTheme.commonColor,
+ color: Colors.white,
),
tooltip: translate('Chat'),
position: mod_menu.PopupMenuPosition.under,
@@ -712,7 +725,7 @@ class _RemoteMenubarState extends State {
.map((entry) => entry.build(
context,
const MenuConfig(
- commonColor: _MenubarTheme.commonColor,
+ commonColor: _MenubarTheme.blueColor,
height: _MenubarTheme.height,
dividerHeight: _MenubarTheme.dividerHeight,
)))