Rather than having five different routes, I am trying to combined five different paths into a single function, but I still need to know which path it matched. So if I set up
I think the best way to do this would be to use a loop to define several routes.
_.each(["accounts", "contacts", "forecasts"], function (path) {
Router.route(path, function () {
// inside here you can reference path
});
});
Using one route with many unrelated paths seems like a hack to me.
I was able to use this.params after all by rewriting the regex as follows:
Router.route(/^\/(accounts|contacts|forecasts|analytics|activities)/, function() {
console.log('matched: '+this.params[0]);
}
Not sure if this is the best way to refer to a regex match tho.
This is a typical scenario for Iron.Router custom route controller! Check the guide here If you need some code, let me know. ;)
[Edit]
First, you define a route controller for all your sites, which inherit from the RouteController.
BaseController = RouteController.extend({
// Put repeating logic for your sites here
});
After that, you define your routes seperatly, not via regex. This is much more modular and maintainable. The big point here is, you don't have to find out by complicated functions, which site is current.
Router.map(function(){
this.route('accounts', {
path: '/accounts'
});
});
Now, give your routes his own controller
Router.map(function(){
this.route('accounts', {
path: '/accounts',
controller: 'AccountsController'
});
});
In this Example, your AccountsController
needs to inherit from your
new BaseController
. Put all your route logic, which is specific
for only this route, in your AccountsController
AccountsController = BaseController.extend({
// Put your specific route logic here
});
Make sure, your BaseController
is loading by meteor before your
routes. Check out Meteor File Load Order.You can do something like the following
client/routes
client/routes/routes.js
client/routes/controller/AccountsController.js
client/routes/controller/BaseController.js