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
2f657536
Unverified
Commit
2f657536
authored
May 07, 2022
by
Taha Tesser
Committed by
GitHub
May 07, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix `DropdownButton` menu clip (#102970)
parent
90868d3b
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
55 additions
and
21 deletions
+55
-21
dropdown.dart
packages/flutter/lib/src/material/dropdown.dart
+24
-21
dropdown_test.dart
packages/flutter/test/material/dropdown_test.dart
+31
-0
No files found.
packages/flutter/lib/src/material/dropdown.dart
View file @
2f657536
...
...
@@ -286,27 +286,30 @@ class _DropdownMenuState<T> extends State<_DropdownMenu<T>> {
namesRoute:
true
,
explicitChildNodes:
true
,
label:
localizations
.
popupMenuLabel
,
child:
Material
(
type:
MaterialType
.
transparency
,
textStyle:
route
.
style
,
child:
ScrollConfiguration
(
// Dropdown menus should never overscroll or display an overscroll indicator.
// Scrollbars are built-in below.
// Platform must use Theme and ScrollPhysics must be Clamping.
behavior:
ScrollConfiguration
.
of
(
context
).
copyWith
(
scrollbars:
false
,
overscroll:
false
,
physics:
const
ClampingScrollPhysics
(),
platform:
Theme
.
of
(
context
).
platform
,
),
child:
PrimaryScrollController
(
controller:
widget
.
route
.
scrollController
!,
child:
Scrollbar
(
thumbVisibility:
true
,
child:
ListView
(
padding:
kMaterialListPadding
,
shrinkWrap:
true
,
children:
children
,
child:
ClipRRect
(
borderRadius:
widget
.
borderRadius
??
BorderRadius
.
zero
,
child:
Material
(
type:
MaterialType
.
transparency
,
textStyle:
route
.
style
,
child:
ScrollConfiguration
(
// Dropdown menus should never overscroll or display an overscroll indicator.
// Scrollbars are built-in below.
// Platform must use Theme and ScrollPhysics must be Clamping.
behavior:
ScrollConfiguration
.
of
(
context
).
copyWith
(
scrollbars:
false
,
overscroll:
false
,
physics:
const
ClampingScrollPhysics
(),
platform:
Theme
.
of
(
context
).
platform
,
),
child:
PrimaryScrollController
(
controller:
widget
.
route
.
scrollController
!,
child:
Scrollbar
(
thumbVisibility:
true
,
child:
ListView
(
padding:
kMaterialListPadding
,
shrinkWrap:
true
,
children:
children
,
),
),
),
),
...
...
packages/flutter/test/material/dropdown_test.dart
View file @
2f657536
...
...
@@ -3839,4 +3839,35 @@ void main() {
expect
(
tester
.
getBottomRight
(
find
.
text
(
hintText
)).
dx
,
776.0
);
expect
(
tester
.
getBottomRight
(
find
.
text
(
hintText
)).
dy
,
350.0
);
});
testWidgets
(
'BorderRadius property clips dropdown menu'
,
(
WidgetTester
tester
)
async
{
const
double
radius
=
20.0
;
await
tester
.
pumpWidget
(
MaterialApp
(
home:
Scaffold
(
body:
Center
(
child:
DropdownButtonFormField
<
String
>(
borderRadius:
BorderRadius
.
circular
(
radius
),
value:
'One'
,
items:
<
String
>[
'One'
,
'Two'
,
'Three'
,
'Four'
]
.
map
<
DropdownMenuItem
<
String
>>((
String
value
)
{
return
DropdownMenuItem
<
String
>(
value:
value
,
child:
Text
(
value
),
);
}).
toList
(),
onChanged:
(
_
)
{
},
),
),
),
),
);
await
tester
.
tap
(
find
.
text
(
'One'
));
await
tester
.
pumpAndSettle
();
final
RenderClipRRect
renderClip
=
tester
.
allRenderObjects
.
whereType
<
RenderClipRRect
>().
first
;
expect
(
renderClip
.
borderRadius
,
BorderRadius
.
circular
(
radius
));
});
}
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