mirror of
https://github.com/frappe/books.git
synced 2025-01-11 10:38:14 +00:00
54 lines
1.7 KiB
JavaScript
54 lines
1.7 KiB
JavaScript
const frappe = require('frappejs');
|
|
const bootstrap = require('bootstrap');
|
|
const $ = require('jquery');
|
|
|
|
class Dropdown {
|
|
constructor({parent, label, items = [], right, cssClass='btn-secondary'}) {
|
|
Object.assign(this, arguments[0]);
|
|
Dropdown.instances += 1;
|
|
this.id = 'dropdownMenuButton-' + Dropdown.instances;
|
|
|
|
this.make();
|
|
|
|
// init items
|
|
if (this.items) {
|
|
for (let item of this.items) {
|
|
this.addItem(item.label, item.action);
|
|
}
|
|
}
|
|
}
|
|
|
|
make() {
|
|
this.$dropdown = $(`<div class="dropdown ${this.right ? 'float-right' : ''}">
|
|
<button class="btn ${this.cssClass} dropdown-toggle"
|
|
type="button" id="${this.id}" data-toggle="dropdown"
|
|
aria-haspopup="true" aria-expanded="false">${this.label}
|
|
</button>
|
|
<div class="dropdown-menu ${this.right ? 'dropdown-menu-right' : ''}" aria-labelledby="${this.id}"></div>
|
|
</div>`).appendTo(this.parent)
|
|
this.dropdown = this.$dropdown.get(0);
|
|
this.dropdownMenu = this.dropdown.querySelector('.dropdown-menu');
|
|
}
|
|
|
|
addItem(label, action) {
|
|
let item = frappe.ui.add('button', 'dropdown-item', this.dropdownMenu, label);
|
|
item.setAttribute('type', 'button');
|
|
if (typeof action === 'string') {
|
|
item.addEventListener('click', async () => {
|
|
await frappe.router.setRoute(action);
|
|
});
|
|
} else {
|
|
item.addEventListener('click', async () => {
|
|
await action();
|
|
});
|
|
}
|
|
}
|
|
|
|
floatRight() {
|
|
frappe.ui.addClass(this.dropdown, 'float-right');
|
|
}
|
|
}
|
|
|
|
Dropdown.instances = 0;
|
|
|
|
module.exports = Dropdown; |