Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to defer routes definition in Angular.js?

I have configured some basic routes that are available for all users before they log in:

App.config(function ($routeProvider) {     $routeProvider.         when('/login', { templateUrl: 'views/login.html', controller: PageStartCtrl.Controller }).         otherwise({ redirectTo: '/login' }); }); 

So the only thing user can do is to log in. After the user logs in, I would like to register additional routes like this:

$http   .post('api/Users/Login', {   User: userName, Password: userPassword })   .success(function (response : any) {     App.config(function ($routeProvider) {       $routeProvider         .when('/dashboard',                { templateUrl: 'part/dashboard.html',                controller: DashboardCtrl.Controller });   }); 

However, I suppose I should call .config method only once, because the $routeProvider is brand new instance that knows nothing about /login route. Further debugging showed me that the first instance of $resourceProvider is used when resolving view change.

Q: Is there a way how to register routes later?

Solution from Add routes and templates dynamically to $routeProvider might work, but is quite ugly (involved global variable nastyGlobalReferenceToRouteProvider).

like image 794
stej Avatar asked Oct 31 '12 07:10

stej


People also ask

What is dynamic routing in angular?

As the name suggests, the primary purpose of Angular Route Guards is to guard access to a certain route, such as an authenticated area of your app, or an admin section that requires special permissions to be accessed.

What is $state in AngularJS?

$stateProvider is used to define different states of one route. You can give the state a name, different controller, different view without having to use a direct href to a route. There are different methods that use the concept of $stateprovider in AngularJS.


1 Answers

Since routes are defined on a provider level, normally new routes can only be defined in the configuration block. The trouble is that in the configuration block all the vital services are still undefined (most notably $http). So, on the surface it looks like w can't define routes dynamically.

Now, it turns out that in practice it is quite easy to add / remove routes at any point of the application life-cycle! Looking at the $route source code we can see that all the routes definition are simply kept in the $route.routes hash which can be modified at any point in time like so (simplified example):

myApp.controller('MyCtrl', function($scope, $route) {         $scope.defineRoute = function() {         $route.routes['/dynamic'] = {templateUrl: 'dynamic.tpl.html'};     }; }); 

Here is the jsFiddle that demonstrates this in action: http://jsfiddle.net/4zwdf/6/

In reality, if we want to be close to what AngularJS is doing the route definition logic should be a bit more complex as AngularJS is also defining a redirect route to correctly handle routes with / at the end (make it effectively optional).

So, while the above technique will work, we need to note the following:

  • This technique depends on the internal implementation and might break if the AngularJS team decides to change the way routes are defined / matched.
  • It is also possible to define the otherwise route using the $route.routes as the default route is stored in the same hash under the null key
like image 75
pkozlowski.opensource Avatar answered Sep 20 '22 23:09

pkozlowski.opensource