Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why don't nested resources in Ember.js preserve the params hash?

Given the following Ember.js application (using Ember 1.0.0.rc.6.1 and Ember Data 0.13):

App = Ember.Application.create({ LOG_TRANSITIONS: true });

App.Store = DS.Store.extend();

App.Router.map(function() {
    this.resource('promotions', function() {
        this.resource('promotion', { path: '/:promotion_id' }, function() {
            this.resource('entrants', function() {
                this.resource('entrant', { path: '/:entrant_id' });
            });
        });
    });
});

App.PromotionRoute = Ember.Route.extend({
    model: function() {
        return { id: 1, name: 'My Promotion' };
    }
});

App.EntrantsIndexRoute = Ember.Route.extend({
    model: function(params) {
        console.warn('EntrantsIndexRoute', '\nparams:', params, '\nparams.promotion_id:', params.promotion_id, '\narguments:', arguments);
        console.log('params should be:', { promotion_id: 1 });
        console.log('The queried URL should be:', '/entrants?promotion_id=1');
        return App.Entrant.find({promotion_id: params.promotion_id});
    }
});

App.Entrant = DS.Model.extend({
    name: DS.attr('string')
});

If you enter the url #/promotions/1/entrants, which should be a nested resource, the params is an empty object. How can I access promotion_id there? JSFiddle here, take a look at the console after clicking on "Click me": http://jsfiddle.net/Kerrick/4GufZ/

like image 651
Kerrick Avatar asked Aug 05 '13 19:08

Kerrick


1 Answers

While you can't access the dynamic segments of the parent route, you still can retrieve the model for the parent route and get its ID, like this:

App.EntrantsIndexRoute = Ember.Route.extend({
  model: function() {
    var promotion_id = this.modelFor('promotion').id;
    return App.Entrant.find({ promotion_id: promotion_id });
  }
});

Or, if there is a has-many relation between promotion and entrants, you even might do:

App.EntrantsIndexRoute = Ember.Route.extend({
  model: function() {
    return this.modelFor('promotion').get('entrants');
  }
});
like image 98
Gosha A Avatar answered Oct 20 '22 06:10

Gosha A