2018-01-23 17:56:40 +05:30
|
|
|
const frappe = require('frappejs');
|
|
|
|
const BaseControl = require('./base');
|
|
|
|
const Awesomplete = require('awesomplete');
|
|
|
|
|
|
|
|
class LinkControl extends BaseControl {
|
|
|
|
make() {
|
|
|
|
super.make();
|
2018-01-23 18:01:09 +05:30
|
|
|
this.input.setAttribute('type', 'text');
|
2018-02-15 15:23:28 +05:30
|
|
|
this.setupAwesomplete();
|
|
|
|
}
|
|
|
|
|
|
|
|
setupAwesomplete() {
|
2018-01-23 18:01:09 +05:30
|
|
|
this.awesomplete = new Awesomplete(this.input, {
|
|
|
|
minChars: 0,
|
2018-02-13 16:12:44 +05:30
|
|
|
maxItems: 99,
|
2018-02-13 17:24:57 +05:30
|
|
|
filter: () => true,
|
2018-04-19 15:43:55 +05:30
|
|
|
sort: (a, b) => {
|
|
|
|
if (a.value === '__newitem' || b.value === '__newitem') {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
return a.value > b.value;
|
|
|
|
}
|
2018-01-23 18:01:09 +05:30
|
|
|
});
|
2018-01-23 17:56:40 +05:30
|
|
|
|
2018-01-23 18:01:09 +05:30
|
|
|
// rebuild the list on input
|
|
|
|
this.input.addEventListener('input', async (event) => {
|
2018-02-13 16:12:44 +05:30
|
|
|
let list = await this.getList(this.input.value);
|
|
|
|
|
|
|
|
// action to add new item
|
|
|
|
list.push({
|
2018-02-16 18:43:46 +05:30
|
|
|
label: frappe._('+ New {0}', this.label),
|
2018-02-13 16:12:44 +05:30
|
|
|
value: '__newItem',
|
|
|
|
});
|
|
|
|
|
|
|
|
this.awesomplete.list = list;
|
|
|
|
});
|
|
|
|
|
|
|
|
// new item action
|
|
|
|
this.input.addEventListener('awesomplete-select', async (e) => {
|
|
|
|
if (e.text && e.text.value === '__newItem') {
|
|
|
|
e.preventDefault();
|
2018-03-27 19:25:26 +05:30
|
|
|
const newDoc = await frappe.getNewDoc(this.getTarget());
|
|
|
|
const formModal = await frappe.desk.showFormModal(this.getTarget(), newDoc.name);
|
2018-02-19 12:01:07 +05:30
|
|
|
if (formModal.form.doc.meta.hasField('name')) {
|
|
|
|
formModal.form.doc.set('name', this.input.value);
|
|
|
|
}
|
|
|
|
|
2018-02-27 21:59:14 +05:30
|
|
|
formModal.once('save', async () => {
|
2018-02-13 17:24:57 +05:30
|
|
|
await this.updateDocValue(formModal.form.doc.name);
|
2018-02-19 12:01:07 +05:30
|
|
|
});
|
2018-02-13 16:12:44 +05:30
|
|
|
}
|
2018-01-23 18:01:09 +05:30
|
|
|
});
|
2018-02-15 15:23:28 +05:30
|
|
|
|
2018-01-23 17:56:40 +05:30
|
|
|
}
|
2018-01-23 18:18:27 +05:30
|
|
|
|
2018-02-08 15:08:47 +05:30
|
|
|
async getList(query) {
|
2018-02-08 12:16:38 +05:30
|
|
|
return (await frappe.db.getAll({
|
2018-03-27 19:25:26 +05:30
|
|
|
doctype: this.getTarget(),
|
2018-03-08 19:01:22 +05:30
|
|
|
filters: this.getFilters(query, this),
|
2018-01-23 18:18:27 +05:30
|
|
|
limit: 50
|
|
|
|
})).map(d => d.name);
|
|
|
|
}
|
|
|
|
|
2018-02-08 15:08:47 +05:30
|
|
|
getFilters(query) {
|
2018-01-23 18:18:27 +05:30
|
|
|
return { keywords: ["like", query] }
|
|
|
|
}
|
2018-03-27 19:25:26 +05:30
|
|
|
|
|
|
|
getTarget() {
|
|
|
|
return this.target;
|
|
|
|
}
|
2018-01-23 17:56:40 +05:30
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = LinkControl;
|