2015-06-13 09:34:09 -05:00
|
|
|
import Ember from 'ember';
|
|
|
|
|
2015-10-28 11:36:45 +00:00
|
|
|
const {Component, computed} = Ember;
|
|
|
|
const {reads} = computed;
|
|
|
|
|
|
|
|
function K() {
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
export default Component.extend({
|
2015-06-13 09:34:09 -05:00
|
|
|
content: null,
|
|
|
|
prompt: null,
|
|
|
|
optionValuePath: 'id',
|
|
|
|
optionLabelPath: 'title',
|
|
|
|
selection: null,
|
2015-10-28 11:36:45 +00:00
|
|
|
action: K, // action to fire on change
|
2015-06-13 09:34:09 -05:00
|
|
|
|
|
|
|
// shadow the passed-in `selection` to avoid
|
|
|
|
// leaking changes to it via a 2-way binding
|
2015-10-28 11:36:45 +00:00
|
|
|
_selection: reads('selection'),
|
2015-06-13 09:34:09 -05:00
|
|
|
|
|
|
|
actions: {
|
2015-10-28 11:36:45 +00:00
|
|
|
change() {
|
|
|
|
let [selectEl] = this.$('select');
|
|
|
|
let {selectedIndex} = selectEl;
|
2015-06-13 09:34:09 -05:00
|
|
|
|
2015-10-28 11:36:45 +00:00
|
|
|
// decrement index by 1 if we have a prompt
|
|
|
|
let hasPrompt = !!this.get('prompt');
|
|
|
|
let contentIndex = hasPrompt ? selectedIndex - 1 : selectedIndex;
|
2015-06-13 09:34:09 -05:00
|
|
|
|
2015-10-28 11:36:45 +00:00
|
|
|
let selection = this.get('content').objectAt(contentIndex);
|
2015-06-13 09:34:09 -05:00
|
|
|
|
|
|
|
// set the local, shadowed selection to avoid leaking
|
|
|
|
// changes to `selection` out via 2-way binding
|
|
|
|
this.set('_selection', selection);
|
|
|
|
|
|
|
|
this.sendAction('action', selection);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|