I'm having an issue where I'm unable to get nested outlets to appear properly in my Ember CLI app. The view tree I want is as follows:
- application (list of all resources, of which client_availability is one)
- - client_availabilities.index (list of client_availabilities)
- -- client_availability (individual client_availability)
This is very similar to the "application > posts.index > post" hierarchy in the Ember Starter Kit. My desired behavior is for a list of client_availabilities to appear in "mainoutlet" when I navigate to client_availabilities.index, then persist when I bring up an individual client_availability in "suboutlet".
Easy, right? This is the default behavior & why we all love Ember. However, I can't seem to get it working. When I explicitly target my named suboutlet in client_availabilities.index and click on an individual client_availability, nothing shows up in either outlet:
Scenario 1: Render suboutlet inside client_availabilities
/app/template/application.hbs:
    {{link-to 'Client Availabilities' 'client_availabilities'}}
    {{outlet 'mainoutlet'}}
/app/template/client-availabilities/index.hbs:
    {{outlet 'suboutlet'}}
/app/routes/client-availabilities/index.js:
    import Ember from 'ember';
    export default Ember.Route.extend({
      renderTemplate: function(){
          this.render({
            into: "application",
            outlet: "mainoutlet"
          });
      },
      model: function() {
        return this.store.find('client_availability');
      }
    });
/app/routes/client-availability.js:
    import Ember from 'ember';
    export default Ember.Route.extend({
      renderTemplate: function(){
          this.render('client_availability', {
            into: "client_availabilities",
            outlet: "suboutlet"
          });
      },
      model: function(params) {
        return this.store.find('client_availability', params.client_availability_id);
      }
    });
Alternately, when I target my mainoutlet in application, client_availability appears in "suboutlet" client_availabilities.index disappears from "mainoutlet":
Scenario 2: Render suboutlet inside application
/app/template/application.hbs:
    {{link-to 'Client Availabilities' 'client_availabilities'}}
    {{outlet 'mainoutlet'}}
    {{outlet 'suboutlet'}}
/app/template/client-availabilities/index.hbs: (empty)
/app/routes/client-availabilities/index.js:
    import Ember from 'ember';
    export default Ember.Route.extend({
      renderTemplate: function(){
          this.render({
            into: "application",
            outlet: "mainoutlet"
          });
      },
      model: function() {
        return this.store.find('client_availability');
      }
    });
/app/routes/client-availability.js:
    import Ember from 'ember';
    export default Ember.Route.extend({
      renderTemplate: function(){
          this.render('client_availability', {
            into: "application",
            outlet: "suboutlet"
          });
      },
      model: function(params) {
        return this.store.find('client_availability', params.client_availability_id);
      }
    });
And here's my router, the same in both cases:
/app/router.js:
    import Ember from 'ember';
    var Router = Ember.Router.extend({
      location: 'auto'
    });
    Router.map(function() {
      this.resource('client_availabilities', function() {
        this.resource('client_availability', { path: ':client_availability_id' });
      });
    });
    export default Router;
I'm happy to share more code, but the application is split into several files and unfortunately not something I can post in its entirety. Can anyone see what I'm doing wrong? The rest of the app is working fine, I just can't seem to get this basic behavior to work.