I'm currently working on a Angular/Ionic/Cordova project and we've recently upgraded to the latest Ionic beta. From the version the project was using before, this introduced the view cache. It has also however introduced an issue in doing so.
The application is customer-facing and is very data-centric. A user must authenticate to view data associated with their account, currently however; when a user logs out, and logs into another account, because the view(s) are still cached they are presented with the views of the last account.
The app should still cache the views when the user is logged in, as it helps make the app feel much quicker, but the cache should be purged when a user logs out.
Setting cache-view="false"
is not an option, as it would completely disable the cache.
I've also tried setting $ionicConfig.views.maxCache(0);
and then back to the default of 10 in the hopes that it would purge the cache in doing so, but it had no effect.
The last thing I can think of to do is fire an event when a user logs in that refreshes all data that's currently loaded into the views - however, this would take a bit more effort than I feel it should.
Is there a way to simply clear the view cache?
In the state definition in app.js you can add cache:false
to disable caching (See Disable cache within state provider in the Ionic docs. Or, you can keep caching except when you know data has changed.
$state.go($state.currentState, {}, {reload:true})
$ionicHistory.clearCache().then(function(){ $state.go('app.fooState') })
Note, the latter requires clearCache to return a promise. See the changes I made in this pull request and compare the implementation of clearCache that you have now with mine: https://github.com/driftyco/ionic/pull/3724