Skip to content

Instantly share code, notes, and snippets.

@rjschie
Last active October 25, 2018 23:20
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save rjschie/3ca44ea0f4ddb09ea5fe0e2e19f1a3f4 to your computer and use it in GitHub Desktop.
Save rjschie/3ca44ea0f4ddb09ea5fe0e2e19f1a3f4 to your computer and use it in GitHub Desktop.
Route Computed Props
import Ember from 'ember';
export default Ember.Controller.extend({
appName: 'Ember Twiddle',
});
import Ember from 'ember';
export default Ember.Controller.extend({
actions: {
changeState() {
this.set('model.state', 'new');
},
},
});
import Ember from 'ember';
import { computed } from '@ember/object';
export default Ember.Controller.extend({
});
import Model from 'ember-data/model';
import attr from 'ember-data/attr';
import { belongsTo, hasMany } from 'ember-data/relationships';
export default Model.extend({
title: attr('string'),
objs: hasMany(),
});
import Model from 'ember-data/model';
import attr from 'ember-data/attr';
import { belongsTo, hasMany } from 'ember-data/relationships';
export default Model.extend({
val: attr('string'),
container: belongsTo(),
});
import EmberRouter from '@ember/routing/router';
import config from './config/environment';
const Router = EmberRouter.extend({
location: 'none',
rootURL: config.rootURL
});
Router.map(function() {
this.route('my-route', { path: '/' }, function() {
this.route('index', { path: '/' });
this.route('edit', { path: ':obj_id' });
});
});
export default Router;
import Ember from 'ember';
export default Ember.Route.extend({
model() {
const container = this.store.createRecord('container', {
id: 1,
title: 'heading thing',
});
this.store.createRecord('obj', {
id: 1,
val: 'initial',
container,
});
this.store.createRecord('obj', {
id: 2,
val: 'initial',
container,
});
this.store.createRecord('obj', {
id: 3,
val: 'initial',
container,
});
},
});
import Ember from 'ember';
export default Ember.Route.extend({
model() {
},
});
import Ember from 'ember';
import { A } from '@ember/array';
import EmberObject from '@ember/object';
export default Ember.Route.extend({
model() {
return this.store.peekRecord('container', 1);
}
});
<h1>Welcome to {{appName}}</h1>
{{outlet}}
I'm the edit route!
{{#link-to 'my-route.index'}}
Nav Back
{{/link-to}}
<br><br>
<div>
<input value={{model.val}}>
</div>
Hello, I'm the index
<br><br>
Container Title: "{{model.title}}"
{{#each model.objs as |obj|}}
<div>
{{#link-to 'my-route.edit' obj}}
{{obj.id}} - {{obj.val}}
{{/link-to}}
</div>
{{/each}}
{
"version": "0.15.1",
"EmberENV": {
"FEATURES": {}
},
"options": {
"use_pods": false,
"enable-testing": false
},
"dependencies": {
"jquery": "https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.js",
"ember": "3.1.4",
"ember-template-compiler": "3.1.4",
"ember-testing": "3.1.4"
},
"addons": {
"ember-data": "3.4.2"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment