Dropping ember-select2 for custom component

Fixes #53
This commit is contained in:
Matthew Dillon 2015-11-13 15:13:46 -07:00
parent 024836cab0
commit d05c31cc94
8 changed files with 75 additions and 28 deletions

View file

@ -0,0 +1,35 @@
import Ember from 'ember';
const { Component } = Ember;
export default Component.extend({
tagName: 'select',
attributeBindings: [
'multiple',
],
options: null,
selected: null,
nameAttr: null,
change: function() {
this.attrs.update(this.$().select2('val'));
},
didInsertElement: function() {
if (this.get('placeholder')) {
this.$().select2({
placeholder: this.get('placeholder'),
});
} else {
this.$().select2();
}
},
didRender: function() {
Ember.run.schedule('afterRender', this, function() {
this.$().select2('val', this.get('selected'));
});
},
});

View file

@ -0,0 +1,3 @@
{{#each options as |option|}}
<option value={{option.id}}>{{get-property option nameAttr}}</option>
{{/each}}

View file

@ -3,8 +3,8 @@ import Ember from 'ember';
const { Controller } = Ember;
export default Controller.extend({
selectedStrains: null,
selectedCharacteristics: null,
selectedStrains: [],
selectedCharacteristics: [],
actions: {
search: function(query) {

View file

@ -30,8 +30,8 @@ export default Route.extend({
}
const compare = this.controllerFor('protected.compare');
compare.set('selectedStrains', params.strain_ids);
compare.set('selectedCharacteristics', params.characteristic_ids);
compare.set('selectedStrains', params.strain_ids.split(","));
compare.set('selectedCharacteristics', params.characteristic_ids.split(","));
return this.get('ajax').request('/compare', { data: params });
},
@ -45,14 +45,14 @@ export default Route.extend({
const compare = this.controllerFor('protected.compare');
const strains = [];
const strain_ids = compare.get('selectedStrains').split(',');
const strain_ids = compare.get('selectedStrains');
strain_ids.forEach((id) => {
strains.push(this.store.peekRecord('strain', id));
});
controller.set('strains', strains);
const characteristics = [];
const characteristic_ids = compare.get('selectedCharacteristics').split(',');
const characteristic_ids = compare.get('selectedCharacteristics');
characteristic_ids.forEach((id) => {
characteristics.push(this.store.peekRecord('characteristic', id));
});

View file

@ -10,8 +10,8 @@ export default Component.extend({
"update-strains": null,
"update-characteristics": null,
selectedStrains: null,
selectedCharacteristics: null,
selectedStrains: [],
selectedCharacteristics: [],
updateStrains: function(selection) {
this.set('selectedStrains', selection);
@ -38,11 +38,11 @@ export default Component.extend({
strains.forEach((strain) => {
strain_ids.push(strain.get('id'));
});
this.updateStrains(strain_ids.join(","));
this.updateStrains(strain_ids);
},
deselectAllStrains: function() {
this.updateStrains("");
this.updateStrains([]);
},
selectAllCharacteristics: function() {
@ -51,11 +51,19 @@ export default Component.extend({
chars.forEach((char) => {
char_ids.push(char.get('id'));
});
this.updateCharacteristics(char_ids.join(","));
this.updateCharacteristics(char_ids);
},
deselectAllCharacteristics: function() {
this.updateCharacteristics("");
this.updateCharacteristics([]);
},
updateStrainSelection: function(selection) {
this.updateStrains(selection);
},
updateCharacteristicsSelection: function(selection) {
this.updateCharacteristics(selection);
},
},
});

View file

@ -5,12 +5,12 @@
<li>
<label>Strains</label>
{{
select-2
x-select
options=strains
nameAttr='fullNameMU'
multiple=true
content=strains
value=selectedStrains
optionValuePath="id"
optionLabelPath="fullNameMU"
selected=selectedStrains
update=(action "updateStrainSelection")
placeholder="Select one or more strains"
}}
</li>
@ -25,12 +25,12 @@
<li>
<label>Characteristics</label>
{{
select-2
x-select
options=characteristics
nameAttr='characteristicName'
multiple=true
content=characteristics
value=selectedCharacteristics
optionValuePath="id"
optionLabelPath="characteristicName"
selected=selectedCharacteristics
update=(action "updateCharacteristicsSelection")
placeholder="Select one or more characteristics"
}}
</li>

View file

@ -15,11 +15,13 @@
<div data-row-span="2">
<div data-field-span="2">
<label>Species</label>
<select onchange={{action "speciesDidChange" value="target.value"}}>
{{#each speciesList as |speciesChoice|}}
<option value={{speciesChoice.id}} selected={{equal species.id speciesChoice.id}}>{{speciesChoice.speciesName}}</option>
{{/each}}
</select>
{{
x-select
options=speciesList
nameAttr='speciesName'
selected=species.id
update=(action "speciesDidChange")
}}
</div>
</div>
<div data-row-span="2">

View file

@ -39,7 +39,6 @@
"ember-disable-proxy-controllers": "^1.0.1",
"ember-export-application-global": "^1.0.4",
"ember-one-way-input": "0.1.3",
"ember-select-2": "1.3.0",
"ember-simple-auth": "1.0.0"
}
}