Skip to content

Commit

Permalink
[BUGFIX release] Add model hook in route blueprint
Browse files Browse the repository at this point in the history
When generating a route with a dynamic segment, say via:

    ember g route foo --path="bar/:buzz_id"

The default empty route definition will cause an awkward assertion to be
thrown.

* In 3.28 without any data layer, the user is prompted via assertion to
  implement a model hook.
* In 3.28 with Ember Data, an implicit fetch via Ember Data happens.
* In 4.0 without any data layer, the user would be prompted via
  assertion to implement a model hook.
* In 4.0 with Ember Data, the user would be prompted via assertion to
  either add a `find` method (old assertion) or to implement a model
  hook (new assertion via
  #19858).

It is doubtless that many users will still encounter these behaviors,
but updating the blueprints to generate a model hook by default improves
on the happy path.

In theory this could do back to 3.28, however the value there is
somewhat less since Ember Data's implicit store injection remains in
that version (and therefore the assertions/messages are less confusing).
  • Loading branch information
mixonic committed Nov 30, 2021
1 parent b88bd24 commit 69915f3
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 4 deletions.
11 changes: 9 additions & 2 deletions blueprints/route/files/__root__/__path__/__name__.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,11 @@
import Route from '@ember/routing/route';

export default Route.extend({
});
export default Route.extend({<% if (hasDynamicSegment) {%>
model(params) {
/**
* This route was generated with a dynamic segment. Implement data loading
* based on that dynamic segment here in the model hook.
*/
return params;
}
<%}%>});
1 change: 1 addition & 0 deletions blueprints/route/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@ module.exports = useEditionDetector({
moduleName: stringUtil.dasherize(moduleName),
routeName: stringUtil.classify(rawRouteName),
addTitle: emberPageTitleExists,
hasDynamicSegment: options.entity.path?.includes(':'),
};
},

Expand Down
11 changes: 9 additions & 2 deletions blueprints/route/native-files/__root__/__path__/__name__.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,11 @@
import Route from '@ember/routing/route';

export default class <%= classifiedModuleName %>Route extends Route {
}
export default class <%= classifiedModuleName %>Route extends Route {<% if (hasDynamicSegment) {%>
model(params) {
/**
* This route was generated with a dynamic segment. Implement data loading
* based on that dynamic segment here in the model hook.
*/
return params;
}
<%}%>}

0 comments on commit 69915f3

Please sign in to comment.