Unverified Commit 07b0252d authored by Qun Cheng's avatar Qun Cheng Committed by GitHub

Change mouse cursor to be SystemMouseCursors.click when not focusable (#121353)

Co-authored-by: 's avatarQun Cheng <quncheng@google.com>
parent b1d8a4e4
...@@ -498,6 +498,8 @@ class _DropdownMenuState<T> extends State<DropdownMenu<T>> { ...@@ -498,6 +498,8 @@ class _DropdownMenuState<T> extends State<DropdownMenu<T>> {
?? theme.inputDecorationTheme ?? theme.inputDecorationTheme
?? defaults.inputDecorationTheme!; ?? defaults.inputDecorationTheme!;
final MouseCursor effectiveMouseCursor = canRequestFocus() ? SystemMouseCursors.text : SystemMouseCursors.click;
return Shortcuts( return Shortcuts(
shortcuts: _kMenuTraversalShortcuts, shortcuts: _kMenuTraversalShortcuts,
child: Actions( child: Actions(
...@@ -539,6 +541,7 @@ class _DropdownMenuState<T> extends State<DropdownMenu<T>> { ...@@ -539,6 +541,7 @@ class _DropdownMenuState<T> extends State<DropdownMenu<T>> {
width: widget.width, width: widget.width,
children: <Widget>[ children: <Widget>[
TextField( TextField(
mouseCursor: effectiveMouseCursor,
canRequestFocus: canRequestFocus(), canRequestFocus: canRequestFocus(),
enableInteractiveSelection: canRequestFocus(), enableInteractiveSelection: canRequestFocus(),
textAlignVertical: TextAlignVertical.center, textAlignVertical: TextAlignVertical.center,
......
...@@ -3,7 +3,10 @@ ...@@ -3,7 +3,10 @@
// found in the LICENSE file. // found in the LICENSE file.
import 'dart:ui';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/rendering.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:flutter_test/flutter_test.dart'; import 'package:flutter_test/flutter_test.dart';
...@@ -1031,6 +1034,32 @@ void main() { ...@@ -1031,6 +1034,32 @@ void main() {
await tester.pump(); await tester.pump();
expect(find.widgetWithText(TextField, 'Item 0'), findsOneWidget); expect(find.widgetWithText(TextField, 'Item 0'), findsOneWidget);
}, variant: TargetPlatformVariant.all()); }, variant: TargetPlatformVariant.all());
testWidgets('If requestFocusOnTap is false, the mouse cursor should be clickable when hovered', (WidgetTester tester) async {
Widget buildDropdownMenu() => MaterialApp(
home: Scaffold(
body: Column(
children: <Widget>[
DropdownMenu<TestMenu>(
requestFocusOnTap: false,
dropdownMenuEntries: menuChildren,
),
],
),
),
);
await tester.pumpWidget(buildDropdownMenu());
await tester.pumpAndSettle();
final Finder textFieldFinder = find.byType(TextField);
final TextField textField = tester.widget<TextField>(textFieldFinder);
expect(textField.canRequestFocus, false);
final TestGesture gesture = await tester.createGesture(kind: PointerDeviceKind.mouse, pointer: 1);
await gesture.moveTo(tester.getCenter(textFieldFinder));
expect(RendererBinding.instance.mouseTracker.debugDeviceActiveCursor(1), SystemMouseCursors.click);
});
} }
enum TestMenu { enum TestMenu {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment