Search code examples
angularjsangularjs-serviceangularjs-httpangularjs-rootscope

angularjs change rootscope after promise in a controller


I'm trying to change some $rootscope variables from within a controller after a I have received a promise from a service.

The $rootscope variables are used to set the html page title attribute etc.

Below is the code I have, I created a function called changeRootPageNotFound() to change the $rootscope variables. It does not work if it's called in the promise.then function.

app.controller('mainController', ['$routeParams', '$scope', '$rootScope', 'mainService', function ($routeParams, $scope, $rootScope, mainService) {
    var mainCtrl = this;
    mainCtrl.id = $routeParams.itemId;

    var promise = mainService.getData($routeParams.id);

    promise.then(function (response)
    {
        if (response.data.data) {
            mainCtrl.data = response.data.data;
        } else {
            mainCtrl.data = false;
            changeRootPageNotFound();
        }
    });
    function changeRootPageNotFound() {
        $rootScope.title = "Page Not Found - 404";
        $rootScope.titleSuffix = "";
    }
    // changeRootPageNotFound();  // works here
}]);

How can I change the $rootscope variables after I have received the deferred promise from the service?


Solution

  • Add a .catch method:

    promise.then(function (response)
    {
        //if (response.data.data) {
            mainCtrl.data = response.data.data;
        //} else {
        //    mainCtrl.data = false;
        //    changeRootPageNotFound();
        //}
    }).catch(function(errorResponse) {
        console.log(errorResponse.status);
        mainCtrl.data = false;
        changeRootPageNotFound();
        throw errorResponse;
    });
    

    The $http service rejects the promise when the status is outside the range 200-299.


    What is the throw errorResponse; for, can it be left out?

    If the throw errorResponse is omitted, the rejection handler returns a value of undefined. This will convert the rejected promise to a fulfilled promise that resolves as undefined. If there is no further chaining, it can be left out.

    A common cause of problems is programmers being unaware of this and unintentionally converting promises.


    instead of .catch you can pass the same function to then as the 2nd argument

    One of the subtle differences between .catch and using the 2nd argument of the .then method, is that runtime errors in the .then success handler will not be caught in the rejection handler of the 2nd argument.