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
9a243a12
Unverified
Commit
9a243a12
authored
Jun 02, 2021
by
xubaolin
Committed by
GitHub
Jun 02, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix a Scaffold.bottomSheet update bug (#83689)
parent
63c49c3d
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
24 additions
and
1 deletion
+24
-1
scaffold.dart
packages/flutter/lib/src/material/scaffold.dart
+7
-1
persistent_bottom_sheet_test.dart
...s/flutter/test/material/persistent_bottom_sheet_test.dart
+17
-0
No files found.
packages/flutter/lib/src/material/scaffold.dart
View file @
9a243a12
...
@@ -2415,7 +2415,7 @@ class ScaffoldState extends State<Scaffold> with TickerProviderStateMixin, Resto
...
@@ -2415,7 +2415,7 @@ class ScaffoldState extends State<Scaffold> with TickerProviderStateMixin, Resto
// bottom sheet.
// bottom sheet.
final
List
<
_StandardBottomSheet
>
_dismissedBottomSheets
=
<
_StandardBottomSheet
>[];
final
List
<
_StandardBottomSheet
>
_dismissedBottomSheets
=
<
_StandardBottomSheet
>[];
PersistentBottomSheetController
<
dynamic
>?
_currentBottomSheet
;
PersistentBottomSheetController
<
dynamic
>?
_currentBottomSheet
;
final
GlobalKey
_currentBottomSheetKey
=
GlobalKey
();
GlobalKey
_currentBottomSheetKey
=
GlobalKey
();
void
_maybeBuildPersistentBottomSheet
()
{
void
_maybeBuildPersistentBottomSheet
()
{
if
(
widget
.
bottomSheet
!=
null
&&
_currentBottomSheet
==
null
)
{
if
(
widget
.
bottomSheet
!=
null
&&
_currentBottomSheet
==
null
)
{
...
@@ -2443,8 +2443,14 @@ class ScaffoldState extends State<Scaffold> with TickerProviderStateMixin, Resto
...
@@ -2443,8 +2443,14 @@ class ScaffoldState extends State<Scaffold> with TickerProviderStateMixin, Resto
return
false
;
return
false
;
}
}
// It is possible that the fade-out animation of the sheet has not finished
// yet, and the key needs to be regenerated at this time, otherwise, there will
// be an exception of duplicate GlobalKey.
if
(
_currentBottomSheetKey
.
currentState
!=
null
)
_currentBottomSheetKey
=
GlobalKey
();
_currentBottomSheet
=
_buildBottomSheet
<
void
>(
_currentBottomSheet
=
_buildBottomSheet
<
void
>(
(
BuildContext
context
)
{
(
BuildContext
context
)
{
assert
(
_currentBottomSheetKey
.
currentState
==
null
);
return
NotificationListener
<
DraggableScrollableNotification
>(
return
NotificationListener
<
DraggableScrollableNotification
>(
onNotification:
_persistentBottomSheetExtentChanged
,
onNotification:
_persistentBottomSheetExtentChanged
,
child:
DraggableScrollableActuator
(
child:
DraggableScrollableActuator
(
...
...
packages/flutter/test/material/persistent_bottom_sheet_test.dart
View file @
9a243a12
...
@@ -501,6 +501,23 @@ void main() {
...
@@ -501,6 +501,23 @@ void main() {
},
},
);
);
// Regression test for https://github.com/flutter/flutter/issues/83668
testWidgets
(
'Scaffold.bottomSheet update test'
,
(
WidgetTester
tester
)
async
{
Widget
buildFrame
(
Widget
?
bottomSheet
)
{
return
MaterialApp
(
home:
Scaffold
(
body:
const
Placeholder
(),
bottomSheet:
bottomSheet
,
),
);
}
await
tester
.
pumpWidget
(
buildFrame
(
const
Text
(
'I love Flutter!'
)));
await
tester
.
pumpWidget
(
buildFrame
(
null
));
// The disappearing animation has not yet been completed.
await
tester
.
pumpWidget
(
buildFrame
(
const
Text
(
'I love Flutter!'
)));
});
testWidgets
(
'Verify that visual properties are passed through'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'Verify that visual properties are passed through'
,
(
WidgetTester
tester
)
async
{
final
GlobalKey
<
ScaffoldState
>
scaffoldKey
=
GlobalKey
<
ScaffoldState
>();
final
GlobalKey
<
ScaffoldState
>
scaffoldKey
=
GlobalKey
<
ScaffoldState
>();
const
Color
color
=
Colors
.
pink
;
const
Color
color
=
Colors
.
pink
;
...
...
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