2018-01-12 17:55:07 +05:30
|
|
|
const BaseControl = require('./base');
|
2018-02-08 17:15:32 +05:30
|
|
|
const frappe = require('frappejs');
|
2018-01-12 17:55:07 +05:30
|
|
|
|
|
|
|
class SelectControl extends BaseControl {
|
2018-02-08 17:15:32 +05:30
|
|
|
makeInput() {
|
2018-03-08 19:01:22 +05:30
|
|
|
this.input = frappe.ui.add('select', 'form-control', this.getInputParent());
|
|
|
|
this.addOptions();
|
|
|
|
}
|
|
|
|
|
|
|
|
refresh() {
|
|
|
|
this.addOptions();
|
|
|
|
super.refresh();
|
|
|
|
}
|
2018-01-12 17:55:07 +05:30
|
|
|
|
2018-03-08 19:01:22 +05:30
|
|
|
addOptions() {
|
|
|
|
const options = this.getOptions();
|
|
|
|
if (this.areOptionsSame(options)) return;
|
|
|
|
|
|
|
|
frappe.ui.empty(this.input);
|
|
|
|
for (let value of options) {
|
|
|
|
let option = frappe.ui.add('option', null, this.input, value.label || value);
|
|
|
|
option.setAttribute('value', value.value || value);
|
|
|
|
}
|
|
|
|
this.lastOptions = options;
|
|
|
|
}
|
|
|
|
|
|
|
|
getOptions() {
|
2018-01-12 17:55:07 +05:30
|
|
|
let options = this.options;
|
|
|
|
if (typeof options==='string') {
|
|
|
|
options = options.split('\n');
|
|
|
|
}
|
2018-03-08 19:01:22 +05:30
|
|
|
return options;
|
|
|
|
}
|
2018-01-12 17:55:07 +05:30
|
|
|
|
2018-03-08 19:01:22 +05:30
|
|
|
areOptionsSame(options) {
|
|
|
|
let same = false;
|
|
|
|
if (this.lastOptions && options.length===this.lastOptions.length) {
|
|
|
|
same = options.every((v ,i) => {
|
|
|
|
const v1 = this.lastOptions[i];
|
|
|
|
return (v.value || v) === (v1.value || v1)
|
|
|
|
});
|
2018-01-12 17:55:07 +05:30
|
|
|
}
|
2018-03-08 19:01:22 +05:30
|
|
|
return same;
|
2018-01-12 17:55:07 +05:30
|
|
|
}
|
2018-03-08 19:01:22 +05:30
|
|
|
|
2018-01-12 17:55:07 +05:30
|
|
|
make() {
|
|
|
|
super.make();
|
|
|
|
this.input.setAttribute('row', '3');
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = SelectControl;
|