diff --git a/lib/services/manager_api.dart b/lib/services/manager_api.dart index 091ddf2256..5257dddf8e 100644 --- a/lib/services/manager_api.dart +++ b/lib/services/manager_api.dart @@ -619,8 +619,8 @@ class ManagerAPI { return showDialog( barrierDismissible: false, context: context, - builder: (context) => PopScope( - canPop: false, + builder: (context) => WillPopScope( + onWillPop: () async => false, child: AlertDialog( title: Text(t.warning), content: ValueListenableBuilder( diff --git a/lib/ui/views/installer/installer_view.dart b/lib/ui/views/installer/installer_view.dart index 49fe9b9df0..2ff230b39e 100644 --- a/lib/ui/views/installer/installer_view.dart +++ b/lib/ui/views/installer/installer_view.dart @@ -16,9 +16,12 @@ class InstallerView extends StatelessWidget { return ViewModelBuilder.reactive( onViewModelReady: (model) => model.initialize(context), viewModelBuilder: () => InstallerViewModel(), - builder: (context, model, child) => PopScope( - onPopInvoked: (bool didPop) => model.onWillPop(context), - canPop: false, + builder: (context, model, child) => WillPopScope( + /* + TODO(any): migrate to [PopScope], + we've tried to migrate it two times but + reverted it because we couldn't exit out of the screen. + */ child: SafeArea( top: false, bottom: model.isPatching, @@ -108,6 +111,7 @@ class InstallerView extends StatelessWidget { ), ), ), + onWillPop: () => model.onWillPop(context), ), ); } diff --git a/lib/ui/views/navigation/navigation_view.dart b/lib/ui/views/navigation/navigation_view.dart index 285331fc8f..65a41ca375 100644 --- a/lib/ui/views/navigation/navigation_view.dart +++ b/lib/ui/views/navigation/navigation_view.dart @@ -13,10 +13,14 @@ class NavigationView extends StatelessWidget { return ViewModelBuilder.reactive( onViewModelReady: (model) => model.initialize(context), viewModelBuilder: () => locator(), - builder: (context, model, child) => PopScope( - canPop: model.currentIndex == 0, - onPopInvoked: (bool didPop) => { - if (!didPop) model.setIndex(0), + builder: (context, model, child) => WillPopScope( + onWillPop: () async { + if (model.currentIndex == 0) { + return true; + } else { + model.setIndex(0); + return false; + } }, child: Scaffold( body: PageTransitionSwitcher(