mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-04 08:54:36 +03:00
fb239054a0
follow up from #95 - converts components to use ember-cli-shims
41 lines
1.2 KiB
JavaScript
41 lines
1.2 KiB
JavaScript
import Component from 'ember-component';
|
|
import {reads} from 'ember-computed';
|
|
|
|
function K() {
|
|
return this;
|
|
}
|
|
|
|
export default Component.extend({
|
|
content: null,
|
|
prompt: null,
|
|
optionValuePath: 'id',
|
|
optionLabelPath: 'title',
|
|
selection: null,
|
|
action: K, // action to fire on change
|
|
|
|
// shadow the passed-in `selection` to avoid
|
|
// leaking changes to it via a 2-way binding
|
|
_selection: reads('selection'),
|
|
|
|
actions: {
|
|
change() {
|
|
// jscs:disable requireArrayDestructuring
|
|
let selectEl = this.$('select')[0];
|
|
// jscs:enable requireArrayDestructuring
|
|
let {selectedIndex} = selectEl;
|
|
|
|
// decrement index by 1 if we have a prompt
|
|
let hasPrompt = !!this.get('prompt');
|
|
let contentIndex = hasPrompt ? selectedIndex - 1 : selectedIndex;
|
|
|
|
let selection = this.get('content').objectAt(contentIndex);
|
|
|
|
// set the local, shadowed selection to avoid leaking
|
|
// changes to `selection` out via 2-way binding
|
|
this.set('_selection', selection);
|
|
|
|
this.sendAction('action', selection);
|
|
}
|
|
}
|
|
});
|