How do I postpone the evaluation of angular expressions in the HTML after an asynchronous operation?
I need the translate function that only becomes defined after an AJAX call.
Here is the code:
angular.module('app', [])
  .run(['$rootScope', '$http', function($rootScope, $http) {
    $rootScope.locale = 'en';
    $http.get('/resources').then(response => {
      let dictionary = response.data;
      $rootScope.tr = (key, ...args) => {
        let text = dictionary[$rootScope.locale][key];
        args.forEach((value, index) => text = text.replace(`{${index}}`, value));
        return text;
      };
    });
  }
In the HTML,
<body ng-app="app"> {{tr('page.title')}} </body>

tr()is not declared yet? Then 1. declare function as all other components - from very beginning; 2. after loading data re-declare translation data; 3. everything else will do $digest loop for you PS. use one-time binding for translations - except template ones - they are never changed