mirror of
https://github.com/frappe/books.git
synced 2025-01-26 08:38:27 +00:00
73 lines
2.1 KiB
JavaScript
73 lines
2.1 KiB
JavaScript
const frappe = require('frappejs');
|
|
const BaseControl = require('./base');
|
|
const Awesomplete = require('awesomplete');
|
|
|
|
class LinkControl extends BaseControl {
|
|
make() {
|
|
super.make();
|
|
this.input.setAttribute('type', 'text');
|
|
this.setupAwesomplete();
|
|
}
|
|
|
|
setupAwesomplete() {
|
|
this.awesomplete = new Awesomplete(this.input, {
|
|
minChars: 0,
|
|
maxItems: 99,
|
|
filter: () => true,
|
|
sort: (a, b) => {
|
|
if (a.value === '__newitem' || b.value === '__newitem') {
|
|
return -1;
|
|
}
|
|
return a.value > b.value;
|
|
}
|
|
});
|
|
|
|
// rebuild the list on input
|
|
this.input.addEventListener('input', async (event) => {
|
|
let list = await this.getList(this.input.value);
|
|
|
|
// action to add new item
|
|
list.push({
|
|
label: frappe._('+ New {0}', this.label),
|
|
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();
|
|
const newDoc = await frappe.getNewDoc(this.getTarget());
|
|
const formModal = await frappe.desk.showFormModal(this.getTarget(), newDoc.name);
|
|
if (formModal.form.doc.meta.hasField('name')) {
|
|
formModal.form.doc.set('name', this.input.value);
|
|
}
|
|
|
|
formModal.once('save', async () => {
|
|
await this.updateDocValue(formModal.form.doc.name);
|
|
});
|
|
}
|
|
});
|
|
|
|
}
|
|
|
|
async getList(query) {
|
|
return (await frappe.db.getAll({
|
|
doctype: this.getTarget(),
|
|
filters: this.getFilters(query, this),
|
|
limit: 50
|
|
})).map(d => d.name);
|
|
}
|
|
|
|
getFilters(query) {
|
|
return { keywords: ["like", query] }
|
|
}
|
|
|
|
getTarget() {
|
|
return this.target;
|
|
}
|
|
};
|
|
|
|
module.exports = LinkControl; |