Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Ui-Router $state.go() does not refresh data

I have a Product List state and Product Edit/Add state in my Angular app.

Product List data gets loaded in the controller (I didn't think I need resolve to be defined in state config) which gets data from an ngResource:

function InventoryListCtrl (myResource) {
  var vm = this;

  myResource.query(function (data) {
    vm.products = data;
  });
}

On Edit Controller, after I edit a product I get back to list state like this:

vm.product.$update().$promise;
$state.go('productList');

It doesn't load list with new data always, it shows old data in first run generally, then after I do second update and manually get back to list state it starts to refresh after each update.

I've tried this, but didn't work either:

vm.product.$update().$promise;
$state.go('productList', {}, { reload: true });

What am I missing?

like image 953
Bogac Avatar asked Feb 10 '15 12:02

Bogac


2 Answers

I think you're loading the new state before the update has completed - try moving the state transition to after the update completion:

vm.product.$update().then(function(){
  $state.go('productList', {}, { reload: true });
});
like image 95
Brad Barber Avatar answered Nov 10 '22 16:11

Brad Barber


i think this should work for current state refresh.

$state.go($state.current, {}, {reload: true}); //second parameter is for $stateParams
like image 37
manish1706 Avatar answered Nov 10 '22 17:11

manish1706