Unverified Commit e10df3c1 authored by Shi-Hao Hong's avatar Shi-Hao Hong Committed by GitHub

Step 1.5 of 3: AboutDialog uses scrollable AlertDialog (#49913)

parent 8600d230
...@@ -362,8 +362,7 @@ class AboutDialog extends StatelessWidget { ...@@ -362,8 +362,7 @@ class AboutDialog extends StatelessWidget {
final String version = applicationVersion ?? _defaultApplicationVersion(context); final String version = applicationVersion ?? _defaultApplicationVersion(context);
final Widget icon = applicationIcon ?? _defaultApplicationIcon(context); final Widget icon = applicationIcon ?? _defaultApplicationIcon(context);
return AlertDialog( return AlertDialog(
content: SingleChildScrollView( content: ListBody(
child: ListBody(
children: <Widget>[ children: <Widget>[
Row( Row(
crossAxisAlignment: CrossAxisAlignment.start, crossAxisAlignment: CrossAxisAlignment.start,
...@@ -387,7 +386,6 @@ class AboutDialog extends StatelessWidget { ...@@ -387,7 +386,6 @@ class AboutDialog extends StatelessWidget {
...?children, ...?children,
], ],
), ),
),
actions: <Widget>[ actions: <Widget>[
FlatButton( FlatButton(
child: Text(MaterialLocalizations.of(context).viewLicensesButtonLabel), child: Text(MaterialLocalizations.of(context).viewLicensesButtonLabel),
...@@ -408,6 +406,7 @@ class AboutDialog extends StatelessWidget { ...@@ -408,6 +406,7 @@ class AboutDialog extends StatelessWidget {
}, },
), ),
], ],
scrollable: true,
); );
} }
} }
......
...@@ -469,6 +469,54 @@ void main() { ...@@ -469,6 +469,54 @@ void main() {
findsNothing, findsNothing,
); );
}); });
testWidgets("AboutDialog's contents are scrollable", (WidgetTester tester) async {
final Key contentKey = UniqueKey();
await tester.pumpWidget(MaterialApp(
home: Navigator(
onGenerateRoute: (RouteSettings settings) {
return MaterialPageRoute<dynamic>(
builder: (BuildContext context) {
return RaisedButton(
onPressed: () {
showAboutDialog(
context: context,
useRootNavigator: false,
applicationName: 'A',
children: <Widget>[
Container(
key: contentKey,
color: Colors.orange,
height: 500,
),
],
);
},
child: const Text('Show About Dialog'),
);
},
);
},
),
));
await tester.tap(find.text('Show About Dialog'));
await tester.pumpAndSettle();
// Try dragging by the [AboutDialog]'s title.
RenderBox box = tester.renderObject(find.text('A'));
Offset originalOffset = box.localToGlobal(Offset.zero);
await tester.drag(find.byKey(contentKey), const Offset(0.0, -20.0));
expect(box.localToGlobal(Offset.zero), equals(originalOffset.translate(0.0, -20.0)));
// Try dragging by the additional children in contents.
box = tester.renderObject(find.byKey(contentKey));
originalOffset = box.localToGlobal(Offset.zero);
await tester.drag(find.byKey(contentKey), const Offset(0.0, -20.0));
expect(box.localToGlobal(Offset.zero), equals(originalOffset.translate(0.0, -20.0)));
});
} }
class FakeLicenseEntry extends LicenseEntry { class FakeLicenseEntry extends LicenseEntry {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment