Note: This package can be used on any platform, and is not specific to iOS.
ConditionalWillPopScope
andCupertinoWillPopScopePageTransionsBuilder
can each be used seprately.
The key to this package is a modified version of Flutter's CupertinoPageRoute, which has been enhanced with the following:
- Visual feedback when users attempt to "swipe to go back" - the screen is allowed to be dragged a bit before it is snapped back to place.
- If an enclosing route has
willPop
callbacks, they are triggered once the screen is snapped back to place.
When using this widget, be sure to update shouldAddCallbacks
based on the state of your screen, and only set it to true
when the screen should not be allowed to pop. Additionally, the onWillPop
property should not be changed once set.
A working app using this package can be found in the example folder.
To use this package, add cupertino_will_pop_scope
as a dependency in your pubspec.yaml file.
// main.dart
import 'package:decorated_icon/cupertino_will_pop_scope.dart';
Set the transition builder of the desired platform to CupertinoWillPopScopePageTransionsBuilder
in your theme configuration.
// main.dart
theme = ThemeData(
...
pageTransitionsTheme: PageTransitionsTheme(
builders: {
TargetPlatform.android: ZoomPageTransitionsBuilder(),
TargetPlatform.iOS: CupertinoWillPopScopePageTransionsBuilder(),
},
),
);
// main.dart
MaterialApp(
...
theme: theme,
home: HomeScreen(),
);
Using the included ConditionalWillPopScope
widget, or Flutter's WillPopScope widget, wrap your screen and define an onWillPop
callback for it.
Note that
onWillPop
should always return abool
. See the Flutter Docs for more.
// my_screen.dart
@override
Widget build(BuildContext context) {
return ConditionalWillPopScope(
child: _MyScreenContent(),
onWillPop: _onWillPop,
shouldAddCallbacks: _hasChanges,
);
}
// my_screen.dart
@override
Widget build(BuildContext context) {
return WillPopScope(
child: _MyScreenContent(),
onWillPop: _hasChanges ? _onWillPop : null,
);
}
⚠️ When using Flutter'sWillPopScope
widget, theonWillPop
must be set conditionally. Otherwise, the "swipe to go back" gesture will be cancelled. In the example above, this is achieved by using_hasChanges
as the condition.