Unverified Commit 210f6f8b authored by Ahmed Ashour's avatar Ahmed Ashour Committed by GitHub

Fix EditableText when a controller listener changes values (#85956)

parent e1534725
...@@ -2312,11 +2312,11 @@ class EditableTextState extends State<EditableText> with AutomaticKeepAliveClien ...@@ -2312,11 +2312,11 @@ class EditableTextState extends State<EditableText> with AutomaticKeepAliveClien
(userInteraction && (userInteraction &&
(cause == SelectionChangedCause.longPress || (cause == SelectionChangedCause.longPress ||
cause == SelectionChangedCause.keyboard))) { cause == SelectionChangedCause.keyboard))) {
_handleSelectionChanged(value.selection, cause); _handleSelectionChanged(_value.selection, cause);
} }
if (textChanged) { if (textChanged) {
try { try {
widget.onChanged?.call(value.text); widget.onChanged?.call(_value.text);
} catch (exception, stack) { } catch (exception, stack) {
FlutterError.reportError(FlutterErrorDetails( FlutterError.reportError(FlutterErrorDetails(
exception: exception, exception: exception,
......
...@@ -6212,6 +6212,41 @@ void main() { ...@@ -6212,6 +6212,41 @@ void main() {
final TextSpan textSpan = renderEditable.text! as TextSpan; final TextSpan textSpan = renderEditable.text! as TextSpan;
expect(textSpan.style!.color, color); expect(textSpan.style!.color, color);
}); });
testWidgets('controller listener changes value', (WidgetTester tester) async {
const double maxValue = 5.5555;
final TextEditingController controller = TextEditingController();
controller.addListener(() {
final double value = double.tryParse(controller.text.trim()) ?? .0;
if (value > maxValue) {
controller.text = maxValue.toString();
controller.selection = TextSelection.fromPosition(
TextPosition(offset: maxValue.toString().length));
}
});
await tester.pumpWidget(MaterialApp(
home: EditableText(
controller: controller,
focusNode: focusNode,
style: textStyle,
cursorColor: Colors.blue,
backgroundCursorColor: Colors.grey,
),
));
final EditableTextState state =
tester.state<EditableTextState>(find.byType(EditableText));
state.updateEditingValue(const TextEditingValue(text: '1', selection: TextSelection.collapsed(offset: 1)));
await tester.pump();
state.updateEditingValue(const TextEditingValue(text: '12', selection: TextSelection.collapsed(offset: 2)));
await tester.pump();
expect(controller.text, '5.5555');
expect(controller.selection.baseOffset, 6);
expect(controller.selection.extentOffset, 6);
});
}); });
testWidgets('autofocus:true on first frame does not throw', (WidgetTester tester) async { testWidgets('autofocus:true on first frame does not throw', (WidgetTester tester) async {
......
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