Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/olegccc/lm-router


https://github.com/olegccc/lm-router

Last synced: 19 days ago
JSON representation

Awesome Lists containing this project

README

        

# lm-router - simple AngularJS router with real dynamic routing

The idea of this router is to give the ability to have completely dynamic routes without any predefined structure (on the client side). This helps, for example, to build route system which is defined on the server side without the need to expose existing tree to the client, for security or any other purposes. Of course, there can be other usage scenarios as its interface is very generic.

Existing AngularJS routing frameworks require to define the routes on the client side, often without the possibility to override them later.

# Usage example

Suppose we have a server backend which has the following interface: when client asks for any URL the server responds with the following:
- is the url valid: true/false
- error message in case of any error
- template to be displayed
- data to be associated with the template

Then our server can be implemented like this (using Express.js):

```javascript
var express = require('express');
var app = express();
app.use(express.bodyParser());

app.post('/router', function(req, res) {

var url = req.body.url;

if (url === '/test/something') {
res.send({
valid: true,
template: '

{{contents}}

',
data: {
contents: 'abc'
}
})
} else {
res.send({
error: 'Unknown URL',
valid: false
});
}
});

app.listen(80);
```

And our client can look like this:

```javascript
var app = angular.module('app', ['lm-router']);

app.controller('main', ['$scope', '$parse', '$http', 'router', function($scope, $parse, $http, router) {

$scope.error = null;
$scope.body = "Start page";

$scope.click = function() {
router.navigate('/test/something');
};

router.on('(.*)', function(url) {

console.log('Our URL: ' + url);

$http.post('/router', {
url: url
}).success(function(response) {
if (response.valid) {
$scope.error = null;
$scope.body = $parse(response.template)(response.data);
} else {
$scope.error = response.error;
$scope.body = "";
}
});
});

router.start();
}]);

angular.bootstrap(document, ['app']);
```