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
b3c237ce
Unverified
Commit
b3c237ce
authored
Jun 15, 2020
by
Justin McCandless
Committed by
GitHub
Jun 15, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Modernize selection menu appearance (#59115)
parent
c79de782
Changes
14
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
373 additions
and
241 deletions
+373
-241
material_localizations.dart
...ages/flutter/lib/src/material/material_localizations.dart
+4
-4
text_selection.dart
packages/flutter/lib/src/material/text_selection.dart
+48
-12
text_field_test.dart
packages/flutter/test/cupertino/text_field_test.dart
+1
-1
app_test.dart
packages/flutter/test/material/app_test.dart
+1
-1
date_picker_test.dart
packages/flutter/test/material/date_picker_test.dart
+1
-1
search_test.dart
packages/flutter/test/material/search_test.dart
+1
-1
text_field_test.dart
packages/flutter/test/material/text_field_test.dart
+47
-47
text_form_field_test.dart
packages/flutter/test/material/text_form_field_test.dart
+2
-2
text_selection_test.dart
packages/flutter/test/material/text_selection_test.dart
+129
-129
editable_text_cursor_test.dart
packages/flutter/test/widgets/editable_text_cursor_test.dart
+4
-4
editable_text_test.dart
packages/flutter/test/widgets/editable_text_test.dart
+20
-20
selectable_text_test.dart
packages/flutter/test/widgets/selectable_text_test.dart
+11
-11
generated_material_localizations.dart
...ations/lib/src/l10n/generated_material_localizations.dart
+100
-4
material_en.arb
packages/flutter_localizations/lib/src/l10n/material_en.arb
+4
-4
No files found.
packages/flutter/lib/src/material/material_localizations.dart
View file @
b3c237ce
...
@@ -872,19 +872,19 @@ class DefaultMaterialLocalizations implements MaterialLocalizations {
...
@@ -872,19 +872,19 @@ class DefaultMaterialLocalizations implements MaterialLocalizations {
String
get
continueButtonLabel
=>
'CONTINUE'
;
String
get
continueButtonLabel
=>
'CONTINUE'
;
@override
@override
String
get
copyButtonLabel
=>
'C
OPY
'
;
String
get
copyButtonLabel
=>
'C
opy
'
;
@override
@override
String
get
cutButtonLabel
=>
'C
UT
'
;
String
get
cutButtonLabel
=>
'C
ut
'
;
@override
@override
String
get
okButtonLabel
=>
'OK'
;
String
get
okButtonLabel
=>
'OK'
;
@override
@override
String
get
pasteButtonLabel
=>
'P
ASTE
'
;
String
get
pasteButtonLabel
=>
'P
aste
'
;
@override
@override
String
get
selectAllButtonLabel
=>
'S
ELECT ALL
'
;
String
get
selectAllButtonLabel
=>
'S
elect all
'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENSES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENSES'
;
...
...
packages/flutter/lib/src/material/text_selection.dart
View file @
b3c237ce
...
@@ -11,6 +11,9 @@ import 'package:flutter/scheduler.dart';
...
@@ -11,6 +11,9 @@ import 'package:flutter/scheduler.dart';
import
'package:flutter/services.dart'
;
import
'package:flutter/services.dart'
;
import
'package:flutter/widgets.dart'
;
import
'package:flutter/widgets.dart'
;
import
'button_theme.dart'
;
import
'colors.dart'
;
import
'constants.dart'
;
import
'debug.dart'
;
import
'debug.dart'
;
import
'flat_button.dart'
;
import
'flat_button.dart'
;
import
'icon_button.dart'
;
import
'icon_button.dart'
;
...
@@ -54,6 +57,18 @@ class _TextSelectionToolbar extends StatefulWidget {
...
@@ -54,6 +57,18 @@ class _TextSelectionToolbar extends StatefulWidget {
_TextSelectionToolbarState
createState
()
=>
_TextSelectionToolbarState
();
_TextSelectionToolbarState
createState
()
=>
_TextSelectionToolbarState
();
}
}
// Intermediate data used for building menu items with the _getItems method.
class
_ItemData
{
const
_ItemData
(
this
.
onPressed
,
this
.
label
,
)
:
assert
(
onPressed
!=
null
),
assert
(
label
!=
null
);
final
VoidCallback
onPressed
;
final
String
label
;
}
class
_TextSelectionToolbarState
extends
State
<
_TextSelectionToolbar
>
with
TickerProviderStateMixin
{
class
_TextSelectionToolbarState
extends
State
<
_TextSelectionToolbar
>
with
TickerProviderStateMixin
{
ClipboardStatusNotifier
_clipboardStatus
;
ClipboardStatusNotifier
_clipboardStatus
;
...
@@ -65,11 +80,25 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
...
@@ -65,11 +80,25 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
// The key for _TextSelectionToolbarContainer.
// The key for _TextSelectionToolbarContainer.
UniqueKey
_containerKey
=
UniqueKey
();
UniqueKey
_containerKey
=
UniqueKey
();
FlatButton
_getItem
(
VoidCallback
onPressed
,
String
label
)
{
Widget
_getItem
(
_ItemData
itemData
,
bool
isFirst
,
bool
isLast
)
{
assert
(
onPressed
!=
null
);
assert
(
isFirst
!=
null
);
return
FlatButton
(
assert
(
isLast
!=
null
);
child:
Text
(
label
),
return
ButtonTheme
.
fromButtonThemeData
(
onPressed:
onPressed
,
data:
ButtonTheme
.
of
(
context
).
copyWith
(
height:
kMinInteractiveDimension
,
minWidth:
kMinInteractiveDimension
,
),
child:
FlatButton
(
onPressed:
itemData
.
onPressed
,
padding:
EdgeInsets
.
only
(
// These values were eyeballed to match the native text selection menu
// on a Pixel 2 running Android 10.
left:
9.5
+
(
isFirst
?
5.0
:
0.0
),
right:
9.5
+
(
isLast
?
5.0
:
0.0
),
),
shape:
Border
.
all
(
width:
0.0
,
color:
Colors
.
transparent
),
child:
Text
(
itemData
.
label
),
),
);
);
}
}
...
@@ -153,20 +182,20 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
...
@@ -153,20 +182,20 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
}
}
final
MaterialLocalizations
localizations
=
MaterialLocalizations
.
of
(
context
);
final
MaterialLocalizations
localizations
=
MaterialLocalizations
.
of
(
context
);
final
List
<
Widget
>
items
=
<
Widget
>[
final
List
<
_ItemData
>
itemDatas
=
<
_ItemData
>[
if
(
widget
.
handleCut
!=
null
)
if
(
widget
.
handleCut
!=
null
)
_
getItem
(
widget
.
handleCut
,
localizations
.
cutButtonLabel
),
_
ItemData
(
widget
.
handleCut
,
localizations
.
cutButtonLabel
),
if
(
widget
.
handleCopy
!=
null
)
if
(
widget
.
handleCopy
!=
null
)
_
getItem
(
widget
.
handleCopy
,
localizations
.
copyButtonLabel
),
_
ItemData
(
widget
.
handleCopy
,
localizations
.
copyButtonLabel
),
if
(
widget
.
handlePaste
!=
null
if
(
widget
.
handlePaste
!=
null
&&
_clipboardStatus
.
value
==
ClipboardStatus
.
pasteable
)
&&
_clipboardStatus
.
value
==
ClipboardStatus
.
pasteable
)
_
getItem
(
widget
.
handlePaste
,
localizations
.
pasteButtonLabel
),
_
ItemData
(
widget
.
handlePaste
,
localizations
.
pasteButtonLabel
),
if
(
widget
.
handleSelectAll
!=
null
)
if
(
widget
.
handleSelectAll
!=
null
)
_
getItem
(
widget
.
handleSelectAll
,
localizations
.
selectAllButtonLabel
),
_
ItemData
(
widget
.
handleSelectAll
,
localizations
.
selectAllButtonLabel
),
];
];
// If there is no option available, build an empty widget.
// If there is no option available, build an empty widget.
if
(
items
.
isEmpty
)
{
if
(
item
Data
s
.
isEmpty
)
{
return
const
SizedBox
(
width:
0.0
,
height:
0.0
);
return
const
SizedBox
(
width:
0.0
,
height:
0.0
);
}
}
...
@@ -179,7 +208,12 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
...
@@ -179,7 +208,12 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
// API 28.
// API 28.
duration:
const
Duration
(
milliseconds:
140
),
duration:
const
Duration
(
milliseconds:
140
),
child:
Material
(
child:
Material
(
// This value was eyeballed to match the native text selection menu on
// a Pixel 2 running Android 10.
borderRadius:
const
BorderRadius
.
all
(
Radius
.
circular
(
7.0
)),
clipBehavior:
Clip
.
antiAlias
,
elevation:
1.0
,
elevation:
1.0
,
type:
MaterialType
.
card
,
child:
_TextSelectionToolbarItems
(
child:
_TextSelectionToolbarItems
(
isAbove:
widget
.
isAbove
,
isAbove:
widget
.
isAbove
,
overflowOpen:
_overflowOpen
,
overflowOpen:
_overflowOpen
,
...
@@ -187,6 +221,7 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
...
@@ -187,6 +221,7 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
// The navButton that shows and hides the overflow menu is the
// The navButton that shows and hides the overflow menu is the
// first child.
// first child.
Material
(
Material
(
type:
MaterialType
.
card
,
child:
IconButton
(
child:
IconButton
(
// TODO(justinmc): This should be an AnimatedIcon, but
// TODO(justinmc): This should be an AnimatedIcon, but
// AnimatedIcons doesn't yet support arrow_back to more_vert.
// AnimatedIcons doesn't yet support arrow_back to more_vert.
...
@@ -202,7 +237,8 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
...
@@ -202,7 +237,8 @@ class _TextSelectionToolbarState extends State<_TextSelectionToolbar> with Ticke
:
localizations
.
moreButtonTooltip
,
:
localizations
.
moreButtonTooltip
,
),
),
),
),
...
items
,
for
(
int
i
=
0
;
i
<
itemDatas
.
length
;
i
++)
_getItem
(
itemDatas
[
i
],
i
==
0
,
i
==
itemDatas
.
length
-
1
)
],
],
),
),
),
),
...
...
packages/flutter/test/cupertino/text_field_test.dart
View file @
b3c237ce
...
@@ -175,7 +175,7 @@ void main() {
...
@@ -175,7 +175,7 @@ void main() {
setUp
(()
async
{
setUp
(()
async
{
EditableText
.
debugDeterministicCursor
=
false
;
EditableText
.
debugDeterministicCursor
=
false
;
// Fill the clipboard so that the P
ASTE
option is available in the text
// Fill the clipboard so that the P
aste
option is available in the text
// selection menu.
// selection menu.
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
});
});
...
...
packages/flutter/test/material/app_test.dart
View file @
b3c237ce
...
@@ -507,7 +507,7 @@ void main() {
...
@@ -507,7 +507,7 @@ void main() {
);
);
// Default US "select all" text.
// Default US "select all" text.
expect
(
find
.
text
(
'S
ELECT ALL
'
),
findsOneWidget
);
expect
(
find
.
text
(
'S
elect all
'
),
findsOneWidget
);
// Default Cupertino US "select all" text.
// Default Cupertino US "select all" text.
expect
(
find
.
text
(
'Select All'
),
findsOneWidget
);
expect
(
find
.
text
(
'Select All'
),
findsOneWidget
);
});
});
...
...
packages/flutter/test/material/date_picker_test.dart
View file @
b3c237ce
...
@@ -73,7 +73,7 @@ void main() {
...
@@ -73,7 +73,7 @@ void main() {
fieldLabelText
=
null
;
fieldLabelText
=
null
;
helpText
=
null
;
helpText
=
null
;
// Fill the clipboard so that the P
ASTE
option is available in the text
// Fill the clipboard so that the P
aste
option is available in the text
// selection menu.
// selection menu.
SystemChannels
.
platform
.
setMockMethodCallHandler
(
mockClipboard
.
handleMethodCall
);
SystemChannels
.
platform
.
setMockMethodCallHandler
(
mockClipboard
.
handleMethodCall
);
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
...
...
packages/flutter/test/material/search_test.dart
View file @
b3c237ce
...
@@ -32,7 +32,7 @@ void main() {
...
@@ -32,7 +32,7 @@ void main() {
final
MockClipboard
mockClipboard
=
MockClipboard
();
final
MockClipboard
mockClipboard
=
MockClipboard
();
setUp
(()
async
{
setUp
(()
async
{
// Fill the clipboard so that the P
ASTE
option is available in the text
// Fill the clipboard so that the P
aste
option is available in the text
// selection menu.
// selection menu.
SystemChannels
.
platform
.
setMockMethodCallHandler
(
mockClipboard
.
handleMethodCall
);
SystemChannels
.
platform
.
setMockMethodCallHandler
(
mockClipboard
.
handleMethodCall
);
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
...
...
packages/flutter/test/material/text_field_test.dart
View file @
b3c237ce
This diff is collapsed.
Click to expand it.
packages/flutter/test/material/text_form_field_test.dart
View file @
b3c237ce
...
@@ -338,8 +338,8 @@ void main() {
...
@@ -338,8 +338,8 @@ void main() {
await
tester
.
pump
();
await
tester
.
pump
();
// Context menu should not have paste.
// Context menu should not have paste.
expect
(
find
.
text
(
'S
ELECT ALL
'
),
findsOneWidget
);
expect
(
find
.
text
(
'S
elect all
'
),
findsOneWidget
);
expect
(
find
.
text
(
'P
ASTE
'
),
findsNothing
);
expect
(
find
.
text
(
'P
aste
'
),
findsNothing
);
final
EditableTextState
editableTextState
=
tester
.
firstState
(
find
.
byType
(
EditableText
));
final
EditableTextState
editableTextState
=
tester
.
firstState
(
find
.
byType
(
EditableText
));
final
RenderEditable
renderEditable
=
editableTextState
.
renderEditable
;
final
RenderEditable
renderEditable
=
editableTextState
.
renderEditable
;
...
...
packages/flutter/test/material/text_selection_test.dart
View file @
b3c237ce
This diff is collapsed.
Click to expand it.
packages/flutter/test/widgets/editable_text_cursor_test.dart
View file @
b3c237ce
...
@@ -22,7 +22,7 @@ const Color cursorColor = Color.fromARGB(0xFF, 0xFF, 0x00, 0x00);
...
@@ -22,7 +22,7 @@ const Color cursorColor = Color.fromARGB(0xFF, 0xFF, 0x00, 0x00);
void
main
(
)
{
void
main
(
)
{
setUp
(()
async
{
setUp
(()
async
{
// Fill the clipboard so that the P
ASTE
option is available in the text
// Fill the clipboard so that the P
aste
option is available in the text
// selection menu.
// selection menu.
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
});
});
...
@@ -88,7 +88,7 @@ void main() {
...
@@ -88,7 +88,7 @@ void main() {
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
tap
(
find
.
text
(
'P
ASTE
'
));
await
tester
.
tap
(
find
.
text
(
'P
aste
'
));
await
tester
.
pump
();
await
tester
.
pump
();
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
...
@@ -141,7 +141,7 @@ void main() {
...
@@ -141,7 +141,7 @@ void main() {
tester
.
state
<
EditableTextState
>(
textFinder
).
showToolbar
();
tester
.
state
<
EditableTextState
>(
textFinder
).
showToolbar
();
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
await
tester
.
tap
(
find
.
text
(
'P
ASTE
'
));
await
tester
.
tap
(
find
.
text
(
'P
aste
'
));
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
changedValue
,
clipboardContent
);
expect
(
changedValue
,
clipboardContent
);
...
@@ -779,7 +779,7 @@ void main() {
...
@@ -779,7 +779,7 @@ void main() {
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
tap
(
find
.
text
(
'P
ASTE
'
));
await
tester
.
tap
(
find
.
text
(
'P
aste
'
));
await
tester
.
pump
();
await
tester
.
pump
();
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
await
tester
.
pump
(
const
Duration
(
milliseconds:
500
));
...
...
packages/flutter/test/widgets/editable_text_test.dart
View file @
b3c237ce
...
@@ -54,7 +54,7 @@ void main() {
...
@@ -54,7 +54,7 @@ void main() {
setUp
(()
async
{
setUp
(()
async
{
debugResetSemanticsIdCounter
();
debugResetSemanticsIdCounter
();
controller
=
TextEditingController
();
controller
=
TextEditingController
();
// Fill the clipboard so that the P
ASTE
option is available in the text
// Fill the clipboard so that the P
aste
option is available in the text
// selection menu.
// selection menu.
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
await
Clipboard
.
setData
(
const
ClipboardData
(
text:
'Clipboard data'
));
});
});
...
@@ -1096,7 +1096,7 @@ void main() {
...
@@ -1096,7 +1096,7 @@ void main() {
// Can't show the toolbar when there's no focus.
// Can't show the toolbar when there's no focus.
expect
(
state
.
showToolbar
(),
false
);
expect
(
state
.
showToolbar
(),
false
);
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
expect
(
find
.
text
(
'P
ASTE
'
),
findsNothing
);
expect
(
find
.
text
(
'P
aste
'
),
findsNothing
);
// Can show the toolbar when focused even though there's no text.
// Can show the toolbar when focused even though there's no text.
state
.
renderEditable
.
selectWordsInRange
(
state
.
renderEditable
.
selectWordsInRange
(
...
@@ -1106,19 +1106,19 @@ void main() {
...
@@ -1106,19 +1106,19 @@ void main() {
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
state
.
showToolbar
(),
true
);
expect
(
state
.
showToolbar
(),
true
);
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
expect
(
find
.
text
(
'P
ASTE
'
),
findsOneWidget
);
expect
(
find
.
text
(
'P
aste
'
),
findsOneWidget
);
// Hide the menu again.
// Hide the menu again.
state
.
hideToolbar
();
state
.
hideToolbar
();
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
find
.
text
(
'P
ASTE
'
),
findsNothing
);
expect
(
find
.
text
(
'P
aste
'
),
findsNothing
);
// Can show the menu with text and a selection.
// Can show the menu with text and a selection.
controller
.
text
=
'blah'
;
controller
.
text
=
'blah'
;
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
state
.
showToolbar
(),
true
);
expect
(
state
.
showToolbar
(),
true
);
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
expect
(
find
.
text
(
'P
ASTE
'
),
findsOneWidget
);
expect
(
find
.
text
(
'P
aste
'
),
findsOneWidget
);
},
skip:
isBrowser
);
},
skip:
isBrowser
);
testWidgets
(
'can show the toolbar after clearing all text'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'can show the toolbar after clearing all text'
,
(
WidgetTester
tester
)
async
{
...
@@ -1149,7 +1149,7 @@ void main() {
...
@@ -1149,7 +1149,7 @@ void main() {
await
tester
.
pump
();
await
tester
.
pump
();
// Clear the text and selection.
// Clear the text and selection.
expect
(
find
.
text
(
'P
ASTE
'
),
findsNothing
);
expect
(
find
.
text
(
'P
aste
'
),
findsNothing
);
state
.
updateEditingValue
(
const
TextEditingValue
(
state
.
updateEditingValue
(
const
TextEditingValue
(
text:
''
,
text:
''
,
));
));
...
@@ -1158,7 +1158,7 @@ void main() {
...
@@ -1158,7 +1158,7 @@ void main() {
// Should be able to show the toolbar.
// Should be able to show the toolbar.
expect
(
state
.
showToolbar
(),
true
);
expect
(
state
.
showToolbar
(),
true
);
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
expect
(
find
.
text
(
'P
ASTE
'
),
findsOneWidget
);
expect
(
find
.
text
(
'P
aste
'
),
findsOneWidget
);
});
});
testWidgets
(
'can dynamically disable options in toolbar'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'can dynamically disable options in toolbar'
,
(
WidgetTester
tester
)
async
{
...
@@ -1190,10 +1190,10 @@ void main() {
...
@@ -1190,10 +1190,10 @@ void main() {
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
state
.
showToolbar
(),
true
);
expect
(
state
.
showToolbar
(),
true
);
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
find
.
text
(
'S
ELECT ALL
'
),
findsOneWidget
);
expect
(
find
.
text
(
'S
elect all
'
),
findsOneWidget
);
expect
(
find
.
text
(
'C
OPY
'
),
findsOneWidget
);
expect
(
find
.
text
(
'C
opy
'
),
findsOneWidget
);
expect
(
find
.
text
(
'P
ASTE
'
),
findsNothing
);
expect
(
find
.
text
(
'P
aste
'
),
findsNothing
);
expect
(
find
.
text
(
'C
UT
'
),
findsNothing
);
expect
(
find
.
text
(
'C
ut
'
),
findsNothing
);
});
});
testWidgets
(
'can dynamically disable select all option in toolbar - cupertino'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'can dynamically disable select all option in toolbar - cupertino'
,
(
WidgetTester
tester
)
async
{
...
@@ -1256,10 +1256,10 @@ void main() {
...
@@ -1256,10 +1256,10 @@ void main() {
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
state
.
showToolbar
(),
true
);
expect
(
state
.
showToolbar
(),
true
);
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
find
.
text
(
'S
ELECT ALL
'
),
findsNothing
);
expect
(
find
.
text
(
'S
elect all
'
),
findsNothing
);
expect
(
find
.
text
(
'C
OPY
'
),
findsOneWidget
);
expect
(
find
.
text
(
'C
opy
'
),
findsOneWidget
);
expect
(
find
.
text
(
'P
ASTE
'
),
findsNothing
);
expect
(
find
.
text
(
'P
aste
'
),
findsNothing
);
expect
(
find
.
text
(
'C
UT
'
),
findsNothing
);
expect
(
find
.
text
(
'C
ut
'
),
findsNothing
);
});
});
testWidgets
(
'cut and paste are disabled in read only mode even if explicit set'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'cut and paste are disabled in read only mode even if explicit set'
,
(
WidgetTester
tester
)
async
{
...
@@ -1294,10 +1294,10 @@ void main() {
...
@@ -1294,10 +1294,10 @@ void main() {
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
state
.
showToolbar
(),
true
);
expect
(
state
.
showToolbar
(),
true
);
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
find
.
text
(
'S
ELECT ALL
'
),
findsOneWidget
);
expect
(
find
.
text
(
'S
elect all
'
),
findsOneWidget
);
expect
(
find
.
text
(
'C
OPY
'
),
findsOneWidget
);
expect
(
find
.
text
(
'C
opy
'
),
findsOneWidget
);
expect
(
find
.
text
(
'P
ASTE
'
),
findsNothing
);
expect
(
find
.
text
(
'P
aste
'
),
findsNothing
);
expect
(
find
.
text
(
'C
UT
'
),
findsNothing
);
expect
(
find
.
text
(
'C
ut
'
),
findsNothing
);
});
});
testWidgets
(
'Fires onChanged when text changes via TextSelectionOverlay'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'Fires onChanged when text changes via TextSelectionOverlay'
,
(
WidgetTester
tester
)
async
{
...
@@ -1328,7 +1328,7 @@ void main() {
...
@@ -1328,7 +1328,7 @@ void main() {
tester
.
state
<
EditableTextState
>(
textFinder
).
showToolbar
();
tester
.
state
<
EditableTextState
>(
textFinder
).
showToolbar
();
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
await
tester
.
tap
(
find
.
text
(
'P
ASTE
'
));
await
tester
.
tap
(
find
.
text
(
'P
aste
'
));
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
changedValue
,
clipboardContent
);
expect
(
changedValue
,
clipboardContent
);
...
...
packages/flutter/test/widgets/selectable_text_test.dart
View file @
b3c237ce
...
@@ -456,7 +456,7 @@ void main() {
...
@@ -456,7 +456,7 @@ void main() {
await
tester
.
pumpAndSettle
();
await
tester
.
pumpAndSettle
();
await
tester
.
pump
(
const
Duration
(
seconds:
1
));
await
tester
.
pump
(
const
Duration
(
seconds:
1
));
expect
(
find
.
text
(
'S
ELECT ALL
'
),
findsOneWidget
);
expect
(
find
.
text
(
'S
elect all
'
),
findsOneWidget
);
});
});
testWidgets
(
'Caret position is updated on tap'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'Caret position is updated on tap'
,
(
WidgetTester
tester
)
async
{
...
@@ -633,9 +633,9 @@ void main() {
...
@@ -633,9 +633,9 @@ void main() {
await
tester
.
pump
();
await
tester
.
pump
();
// Context menu should not have paste and cut.
// Context menu should not have paste and cut.
expect
(
find
.
text
(
'C
OPY
'
),
findsOneWidget
);
expect
(
find
.
text
(
'C
opy
'
),
findsOneWidget
);
expect
(
find
.
text
(
'P
ASTE
'
),
findsNothing
);
expect
(
find
.
text
(
'P
aste
'
),
findsNothing
);
expect
(
find
.
text
(
'C
UT
'
),
findsNothing
);
expect
(
find
.
text
(
'C
ut
'
),
findsNothing
);
});
});
testWidgets
(
'selectable text can disable toolbar options'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'selectable text can disable toolbar options'
,
(
WidgetTester
tester
)
async
{
...
@@ -655,8 +655,8 @@ void main() {
...
@@ -655,8 +655,8 @@ void main() {
await
tester
.
longPressAt
(
dPos
);
await
tester
.
longPressAt
(
dPos
);
await
tester
.
pump
();
await
tester
.
pump
();
// Context menu should not have copy.
// Context menu should not have copy.
expect
(
find
.
text
(
'C
OPY
'
),
findsNothing
);
expect
(
find
.
text
(
'C
opy
'
),
findsNothing
);
expect
(
find
.
text
(
'S
ELECT ALL
'
),
findsOneWidget
);
expect
(
find
.
text
(
'S
elect all
'
),
findsOneWidget
);
});
});
testWidgets
(
'Can select text by dragging with a mouse'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'Can select text by dragging with a mouse'
,
(
WidgetTester
tester
)
async
{
...
@@ -948,14 +948,14 @@ void main() {
...
@@ -948,14 +948,14 @@ void main() {
await
tester
.
pump
();
await
tester
.
pump
();
await
tester
.
pump
(
const
Duration
(
milliseconds:
200
));
// skip past the frame where the opacity is zero
await
tester
.
pump
(
const
Duration
(
milliseconds:
200
));
// skip past the frame where the opacity is zero
// S
ELECT ALL
should select all the text.
// S
elect all
should select all the text.
await
tester
.
tap
(
find
.
text
(
'S
ELECT ALL
'
));
await
tester
.
tap
(
find
.
text
(
'S
elect all
'
));
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
controller
.
selection
.
baseOffset
,
0
);
expect
(
controller
.
selection
.
baseOffset
,
0
);
expect
(
controller
.
selection
.
extentOffset
,
testValue
.
length
);
expect
(
controller
.
selection
.
extentOffset
,
testValue
.
length
);
// C
OPY
should reset the selection.
// C
opy
should reset the selection.
await
tester
.
tap
(
find
.
text
(
'C
OPY
'
));
await
tester
.
tap
(
find
.
text
(
'C
opy
'
));
await
skipPastScrollingAnimation
(
tester
);
await
skipPastScrollingAnimation
(
tester
);
expect
(
controller
.
selection
.
isCollapsed
,
true
);
expect
(
controller
.
selection
.
isCollapsed
,
true
);
});
});
...
@@ -1086,7 +1086,7 @@ void main() {
...
@@ -1086,7 +1086,7 @@ void main() {
expect
(
controller
.
selection
.
baseOffset
,
5
);
expect
(
controller
.
selection
.
baseOffset
,
5
);
expect
(
controller
.
selection
.
extentOffset
,
50
);
expect
(
controller
.
selection
.
extentOffset
,
50
);
await
tester
.
tap
(
find
.
text
(
'C
OPY
'
));
await
tester
.
tap
(
find
.
text
(
'C
opy
'
));
await
tester
.
pump
();
await
tester
.
pump
();
expect
(
controller
.
selection
.
isCollapsed
,
true
);
expect
(
controller
.
selection
.
isCollapsed
,
true
);
});
});
...
...
packages/flutter_localizations/lib/src/l10n/generated_material_localizations.dart
View file @
b3c237ce
...
@@ -3855,10 +3855,10 @@ class MaterialLocalizationEn extends GlobalMaterialLocalizations {
...
@@ -3855,10 +3855,10 @@ class MaterialLocalizationEn extends GlobalMaterialLocalizations {
String
get
continueButtonLabel
=>
'CONTINUE'
;
String
get
continueButtonLabel
=>
'CONTINUE'
;
@override
@override
String
get
copyButtonLabel
=>
'C
OPY
'
;
String
get
copyButtonLabel
=>
'C
opy
'
;
@override
@override
String
get
cutButtonLabel
=>
'C
UT
'
;
String
get
cutButtonLabel
=>
'C
ut
'
;
@override
@override
String
get
dateHelpText
=>
'mm/dd/yyyy'
;
String
get
dateHelpText
=>
'mm/dd/yyyy'
;
...
@@ -3942,7 +3942,7 @@ class MaterialLocalizationEn extends GlobalMaterialLocalizations {
...
@@ -3942,7 +3942,7 @@ class MaterialLocalizationEn extends GlobalMaterialLocalizations {
String
get
pageRowsInfoTitleApproximateRaw
=>
'
\
$firstRow
–
\
$lastRow
of about
\
$rowCount
'
;
String
get
pageRowsInfoTitleApproximateRaw
=>
'
\
$firstRow
–
\
$lastRow
of about
\
$rowCount
'
;
@override
@override
String
get
pasteButtonLabel
=>
'P
ASTE
'
;
String
get
pasteButtonLabel
=>
'P
aste
'
;
@override
@override
String
get
popupMenuLabel
=>
'Popup menu'
;
String
get
popupMenuLabel
=>
'Popup menu'
;
...
@@ -4008,7 +4008,7 @@ class MaterialLocalizationEn extends GlobalMaterialLocalizations {
...
@@ -4008,7 +4008,7 @@ class MaterialLocalizationEn extends GlobalMaterialLocalizations {
String
get
searchFieldLabel
=>
'Search'
;
String
get
searchFieldLabel
=>
'Search'
;
@override
@override
String
get
selectAllButtonLabel
=>
'S
ELECT ALL
'
;
String
get
selectAllButtonLabel
=>
'S
elect all
'
;
@override
@override
String
get
selectYearSemanticsLabel
=>
'Select year'
;
String
get
selectYearSemanticsLabel
=>
'Select year'
;
...
@@ -4094,6 +4094,18 @@ class MaterialLocalizationEnAu extends MaterialLocalizationEn {
...
@@ -4094,6 +4094,18 @@ class MaterialLocalizationEnAu extends MaterialLocalizationEn {
@override
@override
String
get
licensesPageTitle
=>
'Licences'
;
String
get
licensesPageTitle
=>
'Licences'
;
@override
String
get
copyButtonLabel
=>
'COPY'
;
@override
String
get
cutButtonLabel
=>
'CUT'
;
@override
String
get
pasteButtonLabel
=>
'PASTE'
;
@override
String
get
selectAllButtonLabel
=>
'SELECT ALL'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
...
@@ -4142,6 +4154,18 @@ class MaterialLocalizationEnCa extends MaterialLocalizationEn {
...
@@ -4142,6 +4154,18 @@ class MaterialLocalizationEnCa extends MaterialLocalizationEn {
@override
@override
String
get
licensesPageTitle
=>
'Licences'
;
String
get
licensesPageTitle
=>
'Licences'
;
@override
String
get
copyButtonLabel
=>
'COPY'
;
@override
String
get
cutButtonLabel
=>
'CUT'
;
@override
String
get
pasteButtonLabel
=>
'PASTE'
;
@override
String
get
selectAllButtonLabel
=>
'SELECT ALL'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
...
@@ -4190,12 +4214,24 @@ class MaterialLocalizationEnGb extends MaterialLocalizationEn {
...
@@ -4190,12 +4214,24 @@ class MaterialLocalizationEnGb extends MaterialLocalizationEn {
@override
@override
TimeOfDayFormat
get
timeOfDayFormatRaw
=>
TimeOfDayFormat
.
HH_colon_mm
;
TimeOfDayFormat
get
timeOfDayFormatRaw
=>
TimeOfDayFormat
.
HH_colon_mm
;
@override
String
get
copyButtonLabel
=>
'COPY'
;
@override
String
get
selectAllButtonLabel
=>
'SELECT ALL'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
@override
@override
String
get
licensesPageTitle
=>
'Licences'
;
String
get
licensesPageTitle
=>
'Licences'
;
@override
String
get
pasteButtonLabel
=>
'PASTE'
;
@override
String
get
cutButtonLabel
=>
'CUT'
;
@override
@override
String
get
popupMenuLabel
=>
'Pop-up menu'
;
String
get
popupMenuLabel
=>
'Pop-up menu'
;
...
@@ -4241,12 +4277,24 @@ class MaterialLocalizationEnIe extends MaterialLocalizationEn {
...
@@ -4241,12 +4277,24 @@ class MaterialLocalizationEnIe extends MaterialLocalizationEn {
@override
@override
TimeOfDayFormat
get
timeOfDayFormatRaw
=>
TimeOfDayFormat
.
HH_colon_mm
;
TimeOfDayFormat
get
timeOfDayFormatRaw
=>
TimeOfDayFormat
.
HH_colon_mm
;
@override
String
get
copyButtonLabel
=>
'COPY'
;
@override
String
get
selectAllButtonLabel
=>
'SELECT ALL'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
@override
@override
String
get
licensesPageTitle
=>
'Licences'
;
String
get
licensesPageTitle
=>
'Licences'
;
@override
String
get
pasteButtonLabel
=>
'PASTE'
;
@override
String
get
cutButtonLabel
=>
'CUT'
;
@override
@override
String
get
popupMenuLabel
=>
'Pop-up menu'
;
String
get
popupMenuLabel
=>
'Pop-up menu'
;
...
@@ -4292,6 +4340,18 @@ class MaterialLocalizationEnIn extends MaterialLocalizationEn {
...
@@ -4292,6 +4340,18 @@ class MaterialLocalizationEnIn extends MaterialLocalizationEn {
@override
@override
String
get
licensesPageTitle
=>
'Licences'
;
String
get
licensesPageTitle
=>
'Licences'
;
@override
String
get
copyButtonLabel
=>
'COPY'
;
@override
String
get
cutButtonLabel
=>
'CUT'
;
@override
String
get
pasteButtonLabel
=>
'PASTE'
;
@override
String
get
selectAllButtonLabel
=>
'SELECT ALL'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
...
@@ -4340,6 +4400,18 @@ class MaterialLocalizationEnNz extends MaterialLocalizationEn {
...
@@ -4340,6 +4400,18 @@ class MaterialLocalizationEnNz extends MaterialLocalizationEn {
@override
@override
String
get
licensesPageTitle
=>
'Licences'
;
String
get
licensesPageTitle
=>
'Licences'
;
@override
String
get
copyButtonLabel
=>
'COPY'
;
@override
String
get
cutButtonLabel
=>
'CUT'
;
@override
String
get
pasteButtonLabel
=>
'PASTE'
;
@override
String
get
selectAllButtonLabel
=>
'SELECT ALL'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
...
@@ -4388,6 +4460,18 @@ class MaterialLocalizationEnSg extends MaterialLocalizationEn {
...
@@ -4388,6 +4460,18 @@ class MaterialLocalizationEnSg extends MaterialLocalizationEn {
@override
@override
String
get
licensesPageTitle
=>
'Licences'
;
String
get
licensesPageTitle
=>
'Licences'
;
@override
String
get
copyButtonLabel
=>
'COPY'
;
@override
String
get
cutButtonLabel
=>
'CUT'
;
@override
String
get
pasteButtonLabel
=>
'PASTE'
;
@override
String
get
selectAllButtonLabel
=>
'SELECT ALL'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
...
@@ -4436,12 +4520,24 @@ class MaterialLocalizationEnZa extends MaterialLocalizationEn {
...
@@ -4436,12 +4520,24 @@ class MaterialLocalizationEnZa extends MaterialLocalizationEn {
@override
@override
TimeOfDayFormat
get
timeOfDayFormatRaw
=>
TimeOfDayFormat
.
HH_colon_mm
;
TimeOfDayFormat
get
timeOfDayFormatRaw
=>
TimeOfDayFormat
.
HH_colon_mm
;
@override
String
get
copyButtonLabel
=>
'COPY'
;
@override
String
get
selectAllButtonLabel
=>
'SELECT ALL'
;
@override
@override
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
String
get
viewLicensesButtonLabel
=>
'VIEW LICENCES'
;
@override
@override
String
get
licensesPageTitle
=>
'Licences'
;
String
get
licensesPageTitle
=>
'Licences'
;
@override
String
get
pasteButtonLabel
=>
'PASTE'
;
@override
String
get
cutButtonLabel
=>
'CUT'
;
@override
@override
String
get
popupMenuLabel
=>
'Pop-up menu'
;
String
get
popupMenuLabel
=>
'Pop-up menu'
;
...
...
packages/flutter_localizations/lib/src/l10n/material_en.arb
View file @
b3c237ce
...
@@ -118,12 +118,12 @@
...
@@ -118,12 +118,12 @@
"description"
:
"The label for continue buttons and menu items."
"description"
:
"The label for continue buttons and menu items."
},
},
"copyButtonLabel"
:
"C
OPY
"
,
"copyButtonLabel"
:
"C
opy
"
,
"@copyButtonLabel"
:
{
"@copyButtonLabel"
:
{
"description"
:
"The label for copy buttons and menu items."
"description"
:
"The label for copy buttons and menu items."
},
},
"cutButtonLabel"
:
"C
UT
"
,
"cutButtonLabel"
:
"C
ut
"
,
"@cutButtonLabel"
:
{
"@cutButtonLabel"
:
{
"description"
:
"The label for cut buttons and menu items."
"description"
:
"The label for cut buttons and menu items."
},
},
...
@@ -133,12 +133,12 @@
...
@@ -133,12 +133,12 @@
"description"
:
"The label for OK buttons and menu items."
"description"
:
"The label for OK buttons and menu items."
},
},
"pasteButtonLabel"
:
"P
ASTE
"
,
"pasteButtonLabel"
:
"P
aste
"
,
"@pasteButtonLabel"
:
{
"@pasteButtonLabel"
:
{
"description"
:
"The label for paste buttons and menu items."
"description"
:
"The label for paste buttons and menu items."
},
},
"selectAllButtonLabel"
:
"S
ELECT ALL
"
,
"selectAllButtonLabel"
:
"S
elect all
"
,
"@selectAllButtonLabel"
:
{
"@selectAllButtonLabel"
:
{
"description"
:
"The label for select-all buttons and menu items."
"description"
:
"The label for select-all buttons and menu items."
},
},
...
...
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