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
dc40e238
Unverified
Commit
dc40e238
authored
Apr 19, 2021
by
Chinmoy
Committed by
GitHub
Apr 19, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added enableFeedback property to DropdownButton (#69880)
parent
895b317e
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
98 additions
and
1 deletion
+98
-1
dropdown.dart
packages/flutter/lib/src/material/dropdown.dart
+26
-1
dropdown_test.dart
packages/flutter/test/material/dropdown_test.dart
+72
-0
No files found.
packages/flutter/lib/src/material/dropdown.dart
View file @
dc40e238
...
...
@@ -97,6 +97,7 @@ class _DropdownMenuItemButton<T> extends StatefulWidget {
required
this
.
buttonRect
,
required
this
.
constraints
,
required
this
.
itemIndex
,
required
this
.
enableFeedback
,
})
:
super
(
key:
key
);
final
_DropdownRoute
<
T
>
route
;
...
...
@@ -104,6 +105,7 @@ class _DropdownMenuItemButton<T> extends StatefulWidget {
final
Rect
buttonRect
;
final
BoxConstraints
constraints
;
final
int
itemIndex
;
final
bool
enableFeedback
;
@override
_DropdownMenuItemButtonState
<
T
>
createState
()
=>
_DropdownMenuItemButtonState
<
T
>();
...
...
@@ -173,6 +175,7 @@ class _DropdownMenuItemButtonState<T> extends State<_DropdownMenuItemButton<T>>
if
(
dropdownMenuItem
.
enabled
)
{
child
=
InkWell
(
autofocus:
widget
.
itemIndex
==
widget
.
route
.
selectedIndex
,
enableFeedback:
widget
.
enableFeedback
,
child:
child
,
onTap:
_handleOnTap
,
onFocusChange:
_handleFocusChange
,
...
...
@@ -197,6 +200,7 @@ class _DropdownMenu<T> extends StatefulWidget {
required
this
.
buttonRect
,
required
this
.
constraints
,
this
.
dropdownColor
,
required
this
.
enableFeedback
,
})
:
super
(
key:
key
);
final
_DropdownRoute
<
T
>
route
;
...
...
@@ -204,6 +208,7 @@ class _DropdownMenu<T> extends StatefulWidget {
final
Rect
buttonRect
;
final
BoxConstraints
constraints
;
final
Color
?
dropdownColor
;
final
bool
enableFeedback
;
@override
_DropdownMenuState
<
T
>
createState
()
=>
_DropdownMenuState
<
T
>();
...
...
@@ -253,6 +258,7 @@ class _DropdownMenuState<T> extends State<_DropdownMenu<T>> {
buttonRect:
widget
.
buttonRect
,
constraints:
widget
.
constraints
,
itemIndex:
itemIndex
,
enableFeedback:
widget
.
enableFeedback
,
),
];
...
...
@@ -411,6 +417,7 @@ class _DropdownRoute<T> extends PopupRoute<_DropdownRouteResult<T>> {
this
.
itemHeight
,
this
.
dropdownColor
,
this
.
menuMaxHeight
,
required
this
.
enableFeedback
,
})
:
assert
(
style
!=
null
),
itemHeights
=
List
<
double
>.
filled
(
items
.
length
,
itemHeight
??
kMinInteractiveDimension
);
...
...
@@ -424,7 +431,7 @@ class _DropdownRoute<T> extends PopupRoute<_DropdownRouteResult<T>> {
final
double
?
itemHeight
;
final
Color
?
dropdownColor
;
final
double
?
menuMaxHeight
;
final
bool
enableFeedback
;
final
List
<
double
>
itemHeights
;
ScrollController
?
scrollController
;
...
...
@@ -456,6 +463,7 @@ class _DropdownRoute<T> extends PopupRoute<_DropdownRouteResult<T>> {
capturedThemes:
capturedThemes
,
style:
style
,
dropdownColor:
dropdownColor
,
enableFeedback:
enableFeedback
,
);
},
);
...
...
@@ -551,6 +559,7 @@ class _DropdownRoutePage<T> extends StatelessWidget {
required
this
.
capturedThemes
,
this
.
style
,
required
this
.
dropdownColor
,
required
this
.
enableFeedback
,
})
:
super
(
key:
key
);
final
_DropdownRoute
<
T
>
route
;
...
...
@@ -563,6 +572,7 @@ class _DropdownRoutePage<T> extends StatelessWidget {
final
CapturedThemes
capturedThemes
;
final
TextStyle
?
style
;
final
Color
?
dropdownColor
;
final
bool
enableFeedback
;
@override
Widget
build
(
BuildContext
context
)
{
...
...
@@ -586,6 +596,7 @@ class _DropdownRoutePage<T> extends StatelessWidget {
buttonRect:
buttonRect
,
constraints:
constraints
,
dropdownColor:
dropdownColor
,
enableFeedback:
enableFeedback
,
);
return
MediaQuery
.
removePadding
(
...
...
@@ -854,6 +865,7 @@ class DropdownButton<T> extends StatefulWidget {
this
.
autofocus
=
false
,
this
.
dropdownColor
,
this
.
menuMaxHeight
,
this
.
enableFeedback
,
// When adding new arguments, consider adding similar arguments to
// DropdownButtonFormField.
})
:
assert
(
items
==
null
||
items
.
isEmpty
||
value
==
null
||
...
...
@@ -1114,6 +1126,18 @@ class DropdownButton<T> extends StatefulWidget {
/// and bottom of the menu by at one menu item's height.
final
double
?
menuMaxHeight
;
/// Whether detected gestures should provide acoustic and/or haptic feedback.
///
/// For example, on Android a tap will produce a clicking sound and a
/// long-press will produce a short vibration, when feedback is enabled.
///
/// By default, platform-specific feedback is enabled.
///
/// See also:
///
/// * [Feedback] for providing platform-specific feedback to certain actions.
final
bool
?
enableFeedback
;
@override
_DropdownButtonState
<
T
>
createState
()
=>
_DropdownButtonState
<
T
>();
}
...
...
@@ -1266,6 +1290,7 @@ class _DropdownButtonState<T> extends State<DropdownButton<T>> with WidgetsBindi
itemHeight:
widget
.
itemHeight
,
dropdownColor:
widget
.
dropdownColor
,
menuMaxHeight:
widget
.
menuMaxHeight
,
enableFeedback:
widget
.
enableFeedback
??
true
,
);
navigator
.
push
(
_dropdownRoute
!).
then
<
void
>((
_DropdownRouteResult
<
T
>?
newValue
)
{
...
...
packages/flutter/test/material/dropdown_test.dart
View file @
dc40e238
...
...
@@ -12,6 +12,7 @@ import 'package:flutter/services.dart';
import
'../rendering/mock_canvas.dart'
;
import
'../widgets/semantics_tester.dart'
;
import
'feedback_tester.dart'
;
const
List
<
String
>
menuItems
=
<
String
>[
'one'
,
'two'
,
'three'
,
'four'
];
void
onChanged
<
T
>(
T
_
)
{
}
...
...
@@ -3242,4 +3243,75 @@ void main() {
final
Element
disabledItem
=
tester
.
element
(
find
.
text
(
'disabled'
).
hitTestable
());
expect
(
Focus
.
maybeOf
(
disabledItem
),
null
,
reason:
'Disabled menu item should not be able to request focus'
);
});
group
(
'feedback'
,
()
{
late
FeedbackTester
feedback
;
setUp
(()
{
feedback
=
FeedbackTester
();
});
tearDown
(()
{
feedback
.
dispose
();
});
Widget
feedbackBoilerplate
({
bool
?
enableFeedback
})
{
return
MaterialApp
(
home
:
Material
(
child:
DropdownButton
<
String
>(
value:
'One'
,
enableFeedback:
enableFeedback
,
underline:
Container
(
height:
2
,
color:
Colors
.
deepPurpleAccent
,
),
onChanged:
(
String
?
value
)
{},
items:
<
String
>[
'One'
,
'Two'
].
map
<
DropdownMenuItem
<
String
>>((
String
value
)
{
return
DropdownMenuItem
<
String
>(
value:
value
,
child:
Text
(
value
),
);
}).
toList
(),
),
),
);
}
testWidgets
(
'Dropdown with enabled feedback'
,
(
WidgetTester
tester
)
async
{
const
bool
enableFeedback
=
true
;
await
tester
.
pumpWidget
(
feedbackBoilerplate
(
enableFeedback:
enableFeedback
));
await
tester
.
tap
(
find
.
text
(
'One'
));
await
tester
.
pumpAndSettle
();
await
tester
.
tap
(
find
.
widgetWithText
(
InkWell
,
'One'
));
await
tester
.
pumpAndSettle
();
expect
(
feedback
.
clickSoundCount
,
1
);
expect
(
feedback
.
hapticCount
,
0
);
});
testWidgets
(
'Dropdown with disabled feedback'
,
(
WidgetTester
tester
)
async
{
const
bool
enableFeedback
=
false
;
await
tester
.
pumpWidget
(
feedbackBoilerplate
(
enableFeedback:
enableFeedback
));
await
tester
.
tap
(
find
.
text
(
'One'
));
await
tester
.
pumpAndSettle
();
await
tester
.
tap
(
find
.
widgetWithText
(
InkWell
,
'One'
));
await
tester
.
pumpAndSettle
();
expect
(
feedback
.
clickSoundCount
,
0
);
expect
(
feedback
.
hapticCount
,
0
);
});
testWidgets
(
'Dropdown with enabled feedback by default'
,
(
WidgetTester
tester
)
async
{
await
tester
.
pumpWidget
(
feedbackBoilerplate
());
await
tester
.
tap
(
find
.
text
(
'One'
));
await
tester
.
pumpAndSettle
();
await
tester
.
tap
(
find
.
widgetWithText
(
InkWell
,
'Two'
));
await
tester
.
pumpAndSettle
();
expect
(
feedback
.
clickSoundCount
,
1
);
expect
(
feedback
.
hapticCount
,
0
);
});
});
}
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