Checkin.
From what I can tell, the bottleneck is in selectize itself. Will drop this and work on select2.
This commit is contained in:
parent
6f15bc940d
commit
f0167c858d
3 changed files with 14 additions and 24 deletions
|
@ -17,41 +17,34 @@ export default Component.extend({
|
||||||
],
|
],
|
||||||
|
|
||||||
change: function() {
|
change: function() {
|
||||||
this.attrs["update"](this.get('selectize').getValue());
|
this.attrs["update"](this.$()[0].selectize.getValue());
|
||||||
},
|
},
|
||||||
|
|
||||||
didReceiveAttrs: function() {
|
didReceiveAttrs: function() {
|
||||||
this._super(...arguments);
|
this._super(...arguments);
|
||||||
|
console.log('didReceiveAttrs');
|
||||||
|
|
||||||
if (!this.attrs.update) {
|
if (!this.attrs.update) {
|
||||||
throw new Error(`You must provide an \`update\` action.`);
|
throw new Error(`You must provide an \`update\` action.`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Ember.run.schedule('actions', this, () => {
|
||||||
|
console.log('before adding');
|
||||||
|
this.$()[0].selectize.setValue(this.get('selected'), true);
|
||||||
|
console.log('after adding')
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
didInsertElement: function() {
|
didInsertElement: function() {
|
||||||
this._super(...arguments);
|
console.log('didInsertElement');
|
||||||
|
const options = {
|
||||||
this.$().selectize({
|
|
||||||
closeAfterSelect: true,
|
closeAfterSelect: true,
|
||||||
selectOnTab: true,
|
selectOnTab: true,
|
||||||
plugins: ['drag_drop'],
|
plugins: ['drag_drop'],
|
||||||
items: this.get('selected'),
|
items: this.get('selected'),
|
||||||
});
|
|
||||||
|
|
||||||
this.set('selectize', this.$()[0].selectize);
|
|
||||||
},
|
|
||||||
|
|
||||||
didRender: function() {
|
|
||||||
this._super(...arguments);
|
|
||||||
|
|
||||||
const selected = this.get('selected');
|
|
||||||
if (!isEmpty(selected)) {
|
|
||||||
this.get('selected').forEach((item) => {
|
|
||||||
this.get('selectize').addItem(item, true);
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
this.get('selectize').clear(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.$().selectize(options);
|
||||||
},
|
},
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
|
@ -12,10 +12,12 @@ export default Controller.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
updateStrainSelection: function(selection) {
|
updateStrainSelection: function(selection) {
|
||||||
|
console.log(selection);
|
||||||
this.set('selectedStrains', selection);
|
this.set('selectedStrains', selection);
|
||||||
},
|
},
|
||||||
|
|
||||||
updateCharacteristicSelection: function(selection) {
|
updateCharacteristicSelection: function(selection) {
|
||||||
|
console.log(selection);
|
||||||
this.set('selectedCharacteristics', selection);
|
this.set('selectedCharacteristics', selection);
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,16 +10,11 @@ export default Component.extend({
|
||||||
"update-strains": null,
|
"update-strains": null,
|
||||||
"update-characteristics": null,
|
"update-characteristics": null,
|
||||||
|
|
||||||
selectedStrains: null,
|
|
||||||
selectedCharacteristics: null,
|
|
||||||
|
|
||||||
updateStrains: function(selection) {
|
updateStrains: function(selection) {
|
||||||
this.set('selectedStrains', selection);
|
|
||||||
this.attrs["update-strains"](selection);
|
this.attrs["update-strains"](selection);
|
||||||
},
|
},
|
||||||
|
|
||||||
updateCharacteristics: function(selection) {
|
updateCharacteristics: function(selection) {
|
||||||
this.set('selectedCharacteristics', selection);
|
|
||||||
this.attrs['update-characteristics'](selection);
|
this.attrs['update-characteristics'](selection);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
Reference in a new issue