Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
3f02d4b4
Unverified
Commit
3f02d4b4
authored
Feb 03, 2023
by
Callum Moffat
Committed by
GitHub
Feb 03, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Tweak to floating-cursor-end behaviour (#119893)
* Tweak to floating-cursor-end behaviour * Simplify
parent
51b05ac7
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
87 additions
and
10 deletions
+87
-10
editable_text.dart
packages/flutter/lib/src/widgets/editable_text.dart
+3
-3
editable_text_test.dart
packages/flutter/test/widgets/editable_text_test.dart
+84
-7
No files found.
packages/flutter/lib/src/widgets/editable_text.dart
View file @
3f02d4b4
...
@@ -2915,9 +2915,9 @@ class EditableTextState extends State<EditableText> with AutomaticKeepAliveClien
...
@@ -2915,9 +2915,9 @@ class EditableTextState extends State<EditableText> with AutomaticKeepAliveClien
final
Offset
finalPosition
=
renderEditable
.
getLocalRectForCaret
(
_lastTextPosition
!).
centerLeft
-
_floatingCursorOffset
;
final
Offset
finalPosition
=
renderEditable
.
getLocalRectForCaret
(
_lastTextPosition
!).
centerLeft
-
_floatingCursorOffset
;
if
(
_floatingCursorResetController
!.
isCompleted
)
{
if
(
_floatingCursorResetController
!.
isCompleted
)
{
renderEditable
.
setFloatingCursor
(
FloatingCursorDragState
.
End
,
finalPosition
,
_lastTextPosition
!);
renderEditable
.
setFloatingCursor
(
FloatingCursorDragState
.
End
,
finalPosition
,
_lastTextPosition
!);
// Only change if
new position is out of current selection range, as the
// Only change if
the current selection range is collapsed, to prevent
//
selection may have been modified using
the iOS keyboard selection gesture.
//
overwriting the result of
the iOS keyboard selection gesture.
if
(
_lastTextPosition
!.
offset
<
renderEditable
.
selection
!.
start
||
_lastTextPosition
!.
offset
>=
renderEditable
.
selection
!.
en
d
)
{
if
(
renderEditable
.
selection
!.
isCollapse
d
)
{
// The cause is technically the force cursor, but the cause is listed as tap as the desired functionality is the same.
// The cause is technically the force cursor, but the cause is listed as tap as the desired functionality is the same.
_handleSelectionChanged
(
TextSelection
.
fromPosition
(
_lastTextPosition
!),
SelectionChangedCause
.
forcePress
);
_handleSelectionChanged
(
TextSelection
.
fromPosition
(
_lastTextPosition
!),
SelectionChangedCause
.
forcePress
);
}
}
...
...
packages/flutter/test/widgets/editable_text_test.dart
View file @
3f02d4b4
...
@@ -12016,8 +12016,8 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
...
@@ -12016,8 +12016,8 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
EditableText
.
debugDeterministicCursor
=
true
;
EditableText
.
debugDeterministicCursor
=
true
;
final
FocusNode
focusNode
=
FocusNode
();
final
FocusNode
focusNode
=
FocusNode
();
final
GlobalKey
key
=
GlobalKey
();
final
GlobalKey
key
=
GlobalKey
();
// Set it up so that there will be word-wrap.
final
TextEditingController
controller
=
TextEditingController
(
text:
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
);
final
TextEditingController
controller
=
TextEditingController
(
text:
'ABCDEFGHIJKLMNOPQRSTUVWXYZ
\n
1234567890
'
);
controller
.
selection
=
const
TextSelection
.
collapsed
(
offset:
0
);
controller
.
selection
=
const
TextSelection
.
collapsed
(
offset:
0
);
await
tester
.
pumpWidget
(
await
tester
.
pumpWidget
(
MaterialApp
(
MaterialApp
(
...
@@ -12030,6 +12030,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
...
@@ -12030,6 +12030,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
cursorColor:
Colors
.
blue
,
cursorColor:
Colors
.
blue
,
backgroundCursorColor:
Colors
.
grey
,
backgroundCursorColor:
Colors
.
grey
,
cursorOpacityAnimates:
true
,
cursorOpacityAnimates:
true
,
maxLines:
2
,
),
),
),
),
);
);
...
@@ -12040,7 +12041,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
...
@@ -12040,7 +12041,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Start
,
offset:
Offset
.
zero
));
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Start
,
offset:
Offset
.
zero
));
await
tester
.
pump
();
await
tester
.
pump
();
// The
floating
cursor should be drawn at the start of the line.
// The cursor should be drawn at the start of the line.
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
rrect:
RRect
.
fromRectAndRadius
(
const
Rect
.
fromLTWH
(
0.5
,
1
,
3
,
12
),
const
Rect
.
fromLTWH
(
0.5
,
1
,
3
,
12
),
...
@@ -12051,7 +12052,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
...
@@ -12051,7 +12052,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Update
,
offset:
const
Offset
(
50
,
0
)));
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Update
,
offset:
const
Offset
(
50
,
0
)));
await
tester
.
pump
();
await
tester
.
pump
();
// The
floating
cursor should be drawn somewhere in the middle of the line
// The cursor should be drawn somewhere in the middle of the line
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
rrect:
RRect
.
fromRectAndRadius
(
const
Rect
.
fromLTWH
(
50.5
,
1
,
3
,
12
),
const
Rect
.
fromLTWH
(
50.5
,
1
,
3
,
12
),
...
@@ -12069,7 +12070,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
...
@@ -12069,7 +12070,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Start
,
offset:
Offset
.
zero
));
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Start
,
offset:
Offset
.
zero
));
await
tester
.
pump
();
await
tester
.
pump
();
// The
floating
cursor should be drawn near to the previous position.
// The cursor should be drawn near to the previous position.
// It's different because it's snapped to exactly between characters.
// It's different because it's snapped to exactly between characters.
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
rrect:
RRect
.
fromRectAndRadius
(
...
@@ -12081,7 +12082,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
...
@@ -12081,7 +12082,7 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Update
,
offset:
const
Offset
(-
56
,
0
)));
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Update
,
offset:
const
Offset
(-
56
,
0
)));
await
tester
.
pump
();
await
tester
.
pump
();
// The
floating
cursor should be drawn at the start of the line.
// The cursor should be drawn at the start of the line.
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
rrect:
RRect
.
fromRectAndRadius
(
const
Rect
.
fromLTWH
(
0.5
,
1
,
3
,
12
),
const
Rect
.
fromLTWH
(
0.5
,
1
,
3
,
12
),
...
@@ -12096,11 +12097,87 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
...
@@ -12096,11 +12097,87 @@ testWidgets('Floating cursor ending with selection', (WidgetTester tester) async
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
End
,
offset:
Offset
.
zero
));
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
End
,
offset:
Offset
.
zero
));
await
tester
.
pump
();
await
tester
.
pump
();
// Selection should not be
updated as the new position is within the selection range
.
// Selection should not be
changed since it wasn't previously collapsed
.
expect
(
controller
.
selection
.
isCollapsed
,
false
);
expect
(
controller
.
selection
.
isCollapsed
,
false
);
expect
(
controller
.
selection
.
baseOffset
,
0
);
expect
(
controller
.
selection
.
baseOffset
,
0
);
expect
(
controller
.
selection
.
extentOffset
,
4
);
expect
(
controller
.
selection
.
extentOffset
,
4
);
// Now test using keyboard selection in a forwards direction.
controller
.
selection
=
const
TextSelection
.
collapsed
(
offset:
0
);
await
tester
.
pump
();
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Start
,
offset:
Offset
.
zero
));
await
tester
.
pump
();
// The cursor should be drawn in the same (start) position.
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
const
Rect
.
fromLTWH
(
0.5
,
1
,
3
,
12
),
const
Radius
.
circular
(
1
)
)
));
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Update
,
offset:
const
Offset
(
56
,
0
)));
await
tester
.
pump
();
// The cursor should be drawn somewhere in the middle of the line.
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
const
Rect
.
fromLTWH
(
56.5
,
1
,
3
,
12
),
const
Radius
.
circular
(
1
)
)
));
// Simulate UIKit setting the selection using keyboard selection.
controller
.
selection
=
const
TextSelection
(
baseOffset:
0
,
extentOffset:
4
);
await
tester
.
pump
();
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
End
,
offset:
Offset
.
zero
));
await
tester
.
pump
();
// Selection should not be changed since it wasn't previously collapsed.
expect
(
controller
.
selection
.
isCollapsed
,
false
);
expect
(
controller
.
selection
.
baseOffset
,
0
);
expect
(
controller
.
selection
.
extentOffset
,
4
);
// Test that the affinity is updated in case the floating cursor ends at the same offset.
// Put the selection at the beginning of the second line.
controller
.
selection
=
const
TextSelection
.
collapsed
(
offset:
27
);
await
tester
.
pump
();
// Now test using keyboard selection in a forwards direction.
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Start
,
offset:
Offset
.
zero
));
await
tester
.
pump
();
// The cursor should be drawn at the start of the second line.
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
const
Rect
.
fromLTWH
(
0.5
,
15
,
3
,
12
),
const
Radius
.
circular
(
1
)
)
));
// Move the cursor to the end of the first line.
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
Update
,
offset:
const
Offset
(
9999
,
-
14
)));
await
tester
.
pump
();
// The cursor should be drawn at the end of the first line.
expect
(
key
.
currentContext
!.
findRenderObject
(),
paints
..
rrect
(
rrect:
RRect
.
fromRectAndRadius
(
const
Rect
.
fromLTWH
(
800.5
,
1
,
3
,
12
),
const
Radius
.
circular
(
1
)
)
));
state
.
updateFloatingCursor
(
RawFloatingCursorPoint
(
state:
FloatingCursorDragState
.
End
,
offset:
Offset
.
zero
));
await
tester
.
pump
();
// Selection should be changed as it was previously collapsed.
expect
(
controller
.
selection
.
isCollapsed
,
true
);
expect
(
controller
.
selection
.
baseOffset
,
27
);
expect
(
controller
.
selection
.
extentOffset
,
27
);
EditableText
.
debugDeterministicCursor
=
false
;
EditableText
.
debugDeterministicCursor
=
false
;
});
});
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment