mirror of
https://github.com/frappe/books.git
synced 2025-01-12 02:59:11 +00:00
71 lines
2.3 KiB
JavaScript
71 lines
2.3 KiB
JavaScript
const Page = require('frappejs/client/view/page');
|
|
const frappe = require('frappejs');
|
|
const ModelTable = require('frappejs/client/ui/modelTable');
|
|
|
|
module.exports = class TablePage extends Page {
|
|
constructor(doctype) {
|
|
let meta = frappe.getMeta(doctype);
|
|
super({title: `${meta.label || meta.name}`, hasRoute: true});
|
|
this.filterWrapper = frappe.ui.add('div', 'filter-toolbar', this.body);
|
|
this.fitlerButton = frappe.ui.add('button', 'btn btn-sm btn-outline-secondary', this.filterWrapper, 'Set Filters');
|
|
this.tableWrapper = frappe.ui.add('div', 'table-page-wrapper', this.body);
|
|
this.doctype = doctype;
|
|
this.fullPage = true;
|
|
|
|
this.fitlerButton.addEventListener('click', async () => {
|
|
const formModal = await frappe.desk.showFormModal('FilterSelector');
|
|
formModal.form.once('apply-filters', () => {
|
|
formModal.hide();
|
|
this.run();
|
|
})
|
|
});
|
|
|
|
}
|
|
|
|
async show(params) {
|
|
super.show();
|
|
|
|
if (!this.filterSelector) {
|
|
this.filterSelector = await frappe.getSingle('FilterSelector');
|
|
this.filterSelector.reset(this.doctype);
|
|
}
|
|
|
|
if (frappe.params && frappe.params.filters) {
|
|
this.filterSelector.setFilters(frappe.params.filters);
|
|
}
|
|
frappe.params = null;
|
|
|
|
if (!this.modelTable) {
|
|
this.modelTable = new ModelTable({
|
|
doctype: this.doctype,
|
|
parent: this.tableWrapper,
|
|
layout: 'fluid',
|
|
getRowData: async (rowIndex) => {
|
|
return await frappe.getDoc(this.doctype, this.data[rowIndex].name);
|
|
},
|
|
setValue: async (control) => {
|
|
await control.handleChange();
|
|
await control.doc.update();
|
|
}
|
|
});
|
|
}
|
|
|
|
this.run();
|
|
}
|
|
|
|
async run() {
|
|
this.displayFilters();
|
|
this.data = await frappe.db.getAll({
|
|
doctype: this.doctype,
|
|
fields: ['*'],
|
|
filters: this.filterSelector.getFilters(),
|
|
start: this.start,
|
|
limit: 500
|
|
});
|
|
this.modelTable.refresh(this.data);
|
|
}
|
|
|
|
displayFilters() {
|
|
this.fitlerButton.textContent = this.filterSelector.getText();
|
|
}
|
|
} |