From cef6708638659a8113591119d7cf1c8f947b2c10 Mon Sep 17 00:00:00 2001 From: Vladislav Turbanov Date: Fri, 5 Jun 2015 20:35:47 +0300 Subject: [PATCH] fix(history): maintain nextViewOptions with resolves Closes #3027. Closes #3892 An updated fix for https://github.com/driftyco/ionic/issues/3027 Launches the expiration timer only after successful state transition. --- js/angular/service/history.js | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/js/angular/service/history.js b/js/angular/service/history.js index 8e453aa0230..254b0efc5df 100644 --- a/js/angular/service/history.js +++ b/js/angular/service/history.js @@ -42,7 +42,7 @@ function($rootScope, $state, $location, $window, $timeout, $ionicViewSwitcher, $ var DIRECTION_NONE = 'none'; var stateChangeCounter = 0; - var lastStateId, nextViewOptions, nextViewExpireTimer, forcedNav; + var lastStateId, nextViewOptions, deregisterStateChangeListener, nextViewExpireTimer, forcedNav; var viewHistory = { histories: { root: { historyId: 'root', parentHistoryId: null, stack: [], cursor: -1 } }, @@ -367,6 +367,7 @@ function($rootScope, $state, $location, $window, $timeout, $ionicViewSwitcher, $ hist.stack.push(viewHistory.views[viewId]); } + deregisterStateChangeListener && deregisterStateChangeListener(); $timeout.cancel(nextViewExpireTimer); if (nextViewOptions) { if (nextViewOptions.disableAnimate) direction = DIRECTION_NONE; @@ -682,6 +683,7 @@ function($rootScope, $state, $location, $window, $timeout, $ionicViewSwitcher, $ * ``` */ nextViewOptions: function(opts) { + deregisterStateChangeListener && deregisterStateChangeListener(); if (arguments.length) { $timeout.cancel(nextViewExpireTimer); if (opts === null) { @@ -690,9 +692,11 @@ function($rootScope, $state, $location, $window, $timeout, $ionicViewSwitcher, $ nextViewOptions = nextViewOptions || {}; extend(nextViewOptions, opts); if (nextViewOptions.expire) { - nextViewExpireTimer = $timeout(function() { - nextViewOptions = null; - }, nextViewOptions.expire); + deregisterStateChangeListener = $rootScope.$on('$stateChangeSuccess', function() { + nextViewExpireTimer = $timeout(function(){ + nextViewOptions = null; + }, nextViewOptions.expire); + }); } } }