Skip to content

Commit

Permalink
Fix off-screen selected text throws exception (flutter#123595)
Browse files Browse the repository at this point in the history
Fix off-screen selected text throws exception
  • Loading branch information
TahaTesser authored Mar 29, 2023
1 parent 47c92c0 commit d74a1bb
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,12 @@ class TextSelectionToolbarAnchors {
renderBox.localToGlobal(Offset.zero),
renderBox.localToGlobal(renderBox.size.bottomRight(Offset.zero)),
);

if (editingRegion.left.isNaN || editingRegion.top.isNaN
|| editingRegion.right.isNaN || editingRegion.bottom.isNaN) {
return const TextSelectionToolbarAnchors(primaryAnchor: Offset.zero);
}

final bool isMultiline = selectionEndpoints.last.point.dy - selectionEndpoints.first.point.dy >
endGlyphHeight / 2;

Expand Down
55 changes: 55 additions & 0 deletions packages/flutter/test/widgets/selectable_text_test.dart
Original file line number Diff line number Diff line change
Expand Up @@ -5399,4 +5399,59 @@ void main() {
);
expect(count, 1); // The `onSelectionChanged` will not be triggered.
});

testWidgets("Off-screen selected text doesn't throw exception", (WidgetTester tester) async {
// This is a regression test for https://github.com/flutter/flutter/issues/123527

TextSelection? selection;
await tester.pumpWidget(
MaterialApp(
home: Material(
child: Builder(
builder: (BuildContext context) {
return Column(
children: <Widget>[
Expanded(
child: ListView.builder(
itemCount: 100,
itemBuilder: (BuildContext context, int index) {
return SelectableText(
'I love Flutter! $index',
onSelectionChanged: (TextSelection s, _) {
selection = s;
},
);
},
),
),
TextButton(
onPressed: () {
Navigator.pop(context);
},
child: const Text('Pop'),
),
],
);
}
),
),
));

expect(selection, null);

final Offset selectableTextStart = tester.getTopLeft(find.byType(SelectableText).first);
final TestGesture gesture = await tester.startGesture(selectableTextStart + const Offset(50, 5));
await tester.pump(const Duration(milliseconds: 500));
await gesture.up();

expect(selection, isNotNull);

await tester.drag(find.byType(ListView), const Offset(0.0, -3000.0));
await tester.pumpAndSettle();

await tester.tap(find.text('Pop'));
await tester.pumpAndSettle();

expect(tester.takeException(), isNull);
});
}

0 comments on commit d74a1bb

Please sign in to comment.