Skip to content

Instantly share code, notes, and snippets.

@grapho
Forked from deliverea/controllers.application.js
Last active May 30, 2016 18:27
Show Gist options
  • Save grapho/8a8b1cebebc6b9e52d830b8e9da3794c to your computer and use it in GitHub Desktop.
Save grapho/8a8b1cebebc6b9e52d830b8e9da3794c to your computer and use it in GitHub Desktop.
Model Ref Self
import Ember from 'ember';
export default Ember.Controller.extend({
appName: 'Ember Twiddle'
});
import Ember from 'ember';
export default Ember.Controller.extend({
myObject: null,
actions: {
selectedSomething(index) {
console.log(index);
let newParent = this.get('items').objectAt(index);
this.set('myObject.parent', newParent);
}
}
});
import Model from "ember-data/model";
import attr from "ember-data/attr";
import { belongsTo, hasMany } from "ember-data/relationships";
export default Model.extend({
label: attr('string'),
parent: attr()
});
import Ember from 'ember';
const Router = Ember.Router.extend({
location: 'none'
});
Router.map(function() {
this.route('home', {path: '/'});
});
export default Router;
import Ember from 'ember';
export default Ember.Route.extend({
setupController: function(controller) {
controller.set('myObject', this.store.createRecord('my-model', {label: 'myObject'}));
controller.set('items', [
this.store.createRecord('my-model', {label: 'parentOne'}),
this.store.createRecord('my-model', {label: 'parentTwo'})
]);
}
});
<select onchange={{action "selectedSomething" value="target.selectedIndex"}}>
{{#each items as |item|}}
<option>{{item.label}}</option>
{{/each}}
</select>
<hr>
Controller: {{myObject.label}}<br>
Selected Parent: {{myObject.parent}}<br>
Parent's Label: {{myObject.parent.label}}
{
"version": "0.8.1",
"EmberENV": {
"FEATURES": {}
},
"options": {
"use_pods": false,
"enable-testing": false
},
"dependencies": {
"jquery": "https://cdnjs.cloudflare.com/ajax/libs/jquery/1.11.3/jquery.js",
"ember": "2.5.1",
"ember-data": "2.5.2",
"ember-template-compiler": "2.5.1"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment