Unverified Commit 6e7f5803 authored by xubaolin's avatar xubaolin Committed by GitHub

fix a TextFormField bug (#120182)

* fix a TextFormField bug

* review feedback
parent 1e6e6d41
...@@ -3463,11 +3463,9 @@ class EditableTextState extends State<EditableText> with AutomaticKeepAliveClien ...@@ -3463,11 +3463,9 @@ class EditableTextState extends State<EditableText> with AutomaticKeepAliveClien
); );
} else { } else {
_scrollController.jumpTo(targetOffset.offset); _scrollController.jumpTo(targetOffset.offset);
if (_value.selection.isCollapsed) { renderEditable.showOnScreen(
renderEditable.showOnScreen( rect: caretPadding.inflateRect(rectToReveal),
rect: caretPadding.inflateRect(rectToReveal), );
);
}
} }
}); });
} }
......
...@@ -132,6 +132,52 @@ void main() { ...@@ -132,6 +132,52 @@ void main() {
expect(tester.testTextInput.setClientArgs!['inputAction'], equals(serializedActionName)); expect(tester.testTextInput.setClientArgs!['inputAction'], equals(serializedActionName));
} }
testWidgets('Text with selection can be shown on the screen when the keyboard shown', (WidgetTester tester) async {
// Regression test for https://github.com/flutter/flutter/issues/119628
final ScrollController scrollController = ScrollController();
final TextEditingController textController = TextEditingController.fromValue(
const TextEditingValue(text: 'I love flutter'),
);
final Widget widget = MaterialApp(
home: Scaffold(
body: SingleChildScrollView(
controller: scrollController,
child: Column(
children: <Widget>[
const SizedBox(height: 1000.0),
SizedBox(
height: 20.0,
child: EditableText(
controller: textController,
backgroundCursorColor: Colors.grey,
focusNode: focusNode,
style: const TextStyle(),
cursorColor: Colors.red,
),
),
],
),
),
),
);
await tester.pumpWidget(widget);
await tester.showKeyboard(find.byType(EditableText));
TestWidgetsFlutterBinding.instance.window.viewInsetsTestValue = const _TestWindowPadding(bottom: 500);
addTearDown(TestWidgetsFlutterBinding.instance.window.clearViewInsetsTestValue);
textController.selection = TextSelection(
baseOffset: 0,
extentOffset: textController.text.length,
);
await tester.pump();
// The offset of the scrollController should change immediately after window changes its metrics.
final double offsetAfter = scrollController.offset;
expect(offsetAfter, isNot(0.0));
});
// Related issue: https://github.com/flutter/flutter/issues/98115 // Related issue: https://github.com/flutter/flutter/issues/98115
testWidgets('ScheduleShowCaretOnScreen with no animation when the window changes metrics', (WidgetTester tester) async { testWidgets('ScheduleShowCaretOnScreen with no animation when the window changes metrics', (WidgetTester tester) async {
final ScrollController scrollController = ScrollController(); final ScrollController scrollController = ScrollController();
...@@ -170,6 +216,7 @@ void main() { ...@@ -170,6 +216,7 @@ void main() {
await tester.pumpWidget(widget); await tester.pumpWidget(widget);
await tester.showKeyboard(find.byType(EditableText)); await tester.showKeyboard(find.byType(EditableText));
TestWidgetsFlutterBinding.instance.window.viewInsetsTestValue = const _TestWindowPadding(bottom: 500); TestWidgetsFlutterBinding.instance.window.viewInsetsTestValue = const _TestWindowPadding(bottom: 500);
addTearDown(TestWidgetsFlutterBinding.instance.window.clearViewInsetsTestValue);
await tester.pump(); await tester.pump();
// The offset of the scrollController should change immediately after window changes its metrics. // The offset of the scrollController should change immediately after window changes its metrics.
......
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