Skip to content

Instantly share code, notes, and snippets.

@chrislopresto
Last active August 29, 2015 14:26
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 chrislopresto/06419ab364fed6f45297 to your computer and use it in GitHub Desktop.
Save chrislopresto/06419ab364fed6f45297 to your computer and use it in GitHub Desktop.
Spotlight: Ember Closure Actions
import Ember from 'ember';
export default Ember.Component.extend({
actions: {
hodorSigil() {
console.log('HODOR!!!');
}
}
});
import Ember from 'ember';
export default Ember.Component.extend({
actions: {
lannisterSigil() {
console.log('Gold Lion');
}
}
});
import Ember from 'ember';
export default Ember.Component.extend({
actions: {
starkSigil() {
console.log('Grey Direwolf');
}
}
});
import Ember from 'ember';
export default Ember.Controller.extend({
appName:'Ember Twiddle'
});
import Ember from 'ember';
const characters = Ember.A([
Ember.Object.create({
id: 1,
componentName: 'got-stark',
name: 'Ned Stark',
title: 'King of the North'
}),
Ember.Object.create({
id: 2,
componentName: 'got-lannister',
name: 'Jaime Lannister',
title: 'Kingslayer'
}),
Ember.Object.create({
id: 3,
componentName: 'got-hodor',
name: 'Hodor',
title: 'Hodor!'
})
])
export default Ember.Route.extend({
model() {
return characters;
},
actions: {
error: function(error) {
log(error.message);
}
}
});
{{#each model as |character|}}
{{#component character.componentName char=character as | houseSigil |}}
<p>
<b>{{character.name}}</b> <span>~~{{character.title}}~~</span>
</p>
<button {{action houseSigil}}>Log House Sigil</button>
<hr>
{{/component}}
{{/each}}
{{outlet}}
<p>{{char.name}}?...{{char.title}}</p>
{{yield (action 'hodorSigil')}}
<p>Kind acquaintances, I'm {{char.name}}...some call me {{char.title}}</p>
{{yield (action 'lannisterSigil')}}
<p>Hello, I'm {{char.name}}, {{char.title}}</p>
{{yield (action 'starkSigil')}}
{
"version": "0.4.6",
"dependencies": {
"jquery": "https://cdnjs.cloudflare.com/ajax/libs/jquery/1.11.3/jquery.js",
"ember": "https://cdnjs.cloudflare.com/ajax/libs/ember.js/1.13.5/ember.js",
"ember-data": "https://cdnjs.cloudflare.com/ajax/libs/ember-data.js/1.13.5/ember-data.js",
"ember-template-compiler": "https://cdnjs.cloudflare.com/ajax/libs/ember.js/1.13.5/ember-template-compiler.js"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment