Unverified Commit b8df8a83 authored by Abdur Rafay Saleem's avatar Abdur Rafay Saleem Committed by GitHub

Allowed specifying reverseTransitionDuration in PageRouteBuilder class (#61752)

parent c816fabd
...@@ -62,6 +62,7 @@ class PageRouteBuilder<T> extends PageRoute<T> { ...@@ -62,6 +62,7 @@ class PageRouteBuilder<T> extends PageRoute<T> {
@required this.pageBuilder, @required this.pageBuilder,
this.transitionsBuilder = _defaultTransitionsBuilder, this.transitionsBuilder = _defaultTransitionsBuilder,
this.transitionDuration = const Duration(milliseconds: 300), this.transitionDuration = const Duration(milliseconds: 300),
this.reverseTransitionDuration = const Duration(milliseconds: 300),
this.opaque = true, this.opaque = true,
this.barrierDismissible = false, this.barrierDismissible = false,
this.barrierColor, this.barrierColor,
...@@ -93,6 +94,9 @@ class PageRouteBuilder<T> extends PageRoute<T> { ...@@ -93,6 +94,9 @@ class PageRouteBuilder<T> extends PageRoute<T> {
@override @override
final Duration transitionDuration; final Duration transitionDuration;
@override
final Duration reverseTransitionDuration;
@override @override
final bool opaque; final bool opaque;
...@@ -134,6 +138,7 @@ class TransitionBuilderPage<T> extends Page<T> { ...@@ -134,6 +138,7 @@ class TransitionBuilderPage<T> extends Page<T> {
@required this.pageBuilder, @required this.pageBuilder,
this.transitionsBuilder = _defaultTransitionsBuilder, this.transitionsBuilder = _defaultTransitionsBuilder,
this.transitionDuration = const Duration(milliseconds: 300), this.transitionDuration = const Duration(milliseconds: 300),
this.reverseTransitionDuration = const Duration(milliseconds: 300),
this.opaque = true, this.opaque = true,
this.barrierDismissible = false, this.barrierDismissible = false,
this.barrierColor, this.barrierColor,
...@@ -160,6 +165,9 @@ class TransitionBuilderPage<T> extends Page<T> { ...@@ -160,6 +165,9 @@ class TransitionBuilderPage<T> extends Page<T> {
/// {@macro flutter.widgets.transitionRoute.transitionDuration} /// {@macro flutter.widgets.transitionRoute.transitionDuration}
final Duration transitionDuration; final Duration transitionDuration;
/// {@macro flutter.widgets.transitionRoute.reverseTransitionDuration}
final Duration reverseTransitionDuration;
/// {@macro flutter.widgets.transitionRoute.opaque} /// {@macro flutter.widgets.transitionRoute.opaque}
final bool opaque; final bool opaque;
...@@ -197,6 +205,9 @@ class _PageBasedPageRouteBuilder<T> extends PageRoute<T>{ ...@@ -197,6 +205,9 @@ class _PageBasedPageRouteBuilder<T> extends PageRoute<T>{
@override @override
Duration get transitionDuration => _page.transitionDuration; Duration get transitionDuration => _page.transitionDuration;
@override
Duration get reverseTransitionDuration => _page.reverseTransitionDuration;
@override @override
bool get opaque => _page.opaque; bool get opaque => _page.opaque;
......
...@@ -674,6 +674,109 @@ void main() { ...@@ -674,6 +674,109 @@ void main() {
expect(find.text('second'), findsOneWidget); expect(find.text('second'), findsOneWidget);
}); });
group('PageRouteBuilder', () {
testWidgets('reverseTransitionDuration defaults to 300ms', (WidgetTester tester) async {
// Default PageRouteBuilder reverse transition duration should be 300ms.
await tester.pumpWidget(
MaterialApp(
onGenerateRoute: (RouteSettings settings) {
return MaterialPageRoute<dynamic>(
builder: (BuildContext context) {
return RaisedButton(
onPressed: () {
Navigator.of(context).push<void>(
PageRouteBuilder<void>(
settings: settings,
pageBuilder: (BuildContext context, Animation<double> input, Animation<double> out) {
return const Text('Page Two');
},
)
);
},
child: const Text('Open page'),
);
},
);
},
)
);
// Open the new route.
await tester.tap(find.byType(RaisedButton));
await tester.pumpAndSettle();
expect(find.text('Open page'), findsNothing);
expect(find.text('Page Two'), findsOneWidget);
// Pop the new route.
tester.state<NavigatorState>(find.byType(Navigator)).pop();
await tester.pump();
expect(find.text('Page Two'), findsOneWidget);
// Text('Page Two') should be present halfway through the reverse transition.
await tester.pump(const Duration(milliseconds: 150));
expect(find.text('Page Two'), findsOneWidget);
// Text('Page Two') should be present at the very end of the reverse transition.
await tester.pump(const Duration(milliseconds: 150));
expect(find.text('Page Two'), findsOneWidget);
// Text('Page Two') have transitioned out after 300ms.
await tester.pump(const Duration(milliseconds: 1));
expect(find.text('Page Two'), findsNothing);
expect(find.text('Open page'), findsOneWidget);
});
testWidgets('reverseTransitionDuration can be customized', (WidgetTester tester) async {
await tester.pumpWidget(MaterialApp(
onGenerateRoute: (RouteSettings settings) {
return MaterialPageRoute<dynamic>(
builder: (BuildContext context) {
return RaisedButton(
onPressed: () {
Navigator.of(context).push<void>(
PageRouteBuilder<void>(
settings: settings,
pageBuilder: (BuildContext context, Animation<double> input, Animation<double> out) {
return const Text('Page Two');
},
// modified value, default PageRouteBuilder reverse transition duration should be 300ms.
reverseTransitionDuration: const Duration(milliseconds: 150),
)
);
},
child: const Text('Open page'),
);
},
);
})
);
// Open the new route.
await tester.tap(find.byType(RaisedButton));
await tester.pumpAndSettle();
expect(find.text('Open page'), findsNothing);
expect(find.text('Page Two'), findsOneWidget);
// Pop the new route.
tester.state<NavigatorState>(find.byType(Navigator)).pop();
await tester.pump();
expect(find.text('Page Two'), findsOneWidget);
// Text('Page Two') should be present halfway through the reverse transition.
await tester.pump(const Duration(milliseconds: 75));
expect(find.text('Page Two'), findsOneWidget);
// Text('Page Two') should be present at the very end of the reverse transition.
await tester.pump(const Duration(milliseconds: 75));
expect(find.text('Page Two'), findsOneWidget);
// Text('Page Two') have transitioned out after 500ms.
await tester.pump(const Duration(milliseconds: 1));
expect(find.text('Page Two'), findsNothing);
expect(find.text('Open page'), findsOneWidget);
});
});
group('TransitionRoute', () { group('TransitionRoute', () {
testWidgets('secondary animation is kDismissed when next route finishes pop', (WidgetTester tester) async { testWidgets('secondary animation is kDismissed when next route finishes pop', (WidgetTester tester) async {
final GlobalKey<NavigatorState> navigator = GlobalKey<NavigatorState>(); final GlobalKey<NavigatorState> navigator = GlobalKey<NavigatorState>();
......
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