2
0
mirror of https://github.com/frappe/books.git synced 2025-01-25 16:18:33 +00:00
books/client/view/page.js

100 lines
3.1 KiB
JavaScript
Raw Normal View History

2018-01-16 11:39:17 +05:30
const frappe = require('frappejs');
2018-01-31 15:43:33 +05:30
const Observable = require('frappejs/utils/observable');
2018-02-14 18:20:56 +05:30
const Dropdown = require('frappejs/client/ui/dropdown');
2018-01-12 17:55:07 +05:30
2018-01-31 15:43:33 +05:30
module.exports = class Page extends Observable {
2018-02-22 13:06:28 +05:30
constructor({title, parent, hasRoute=true} = {}) {
2018-01-31 15:43:33 +05:30
super();
2018-02-14 22:14:50 +05:30
Object.assign(this, arguments[0]);
if (!this.parent) {
this.parent = frappe.desk.body;
}
2018-01-12 17:55:07 +05:30
this.make();
2018-02-14 18:20:56 +05:30
this.dropdowns = {};
2018-02-15 15:23:28 +05:30
if(this.title) {
2018-03-27 19:25:26 +05:30
this.wrapper.setAttribute('title', this.title);
2018-02-15 15:23:28 +05:30
this.setTitle(this.title);
}
2018-01-12 17:55:07 +05:30
}
make() {
2018-02-14 22:14:50 +05:30
this.wrapper = frappe.ui.add('div', 'page hide', this.parent);
2018-03-08 19:01:22 +05:30
this.head = frappe.ui.add('div', 'page-nav clearfix hide', this.wrapper);
this.titleElement = frappe.ui.add('h3', 'page-title', this.wrapper);
2018-03-09 18:30:51 +05:30
this.linksElement = frappe.ui.add('div', 'btn-group page-links hide', this.wrapper);
2018-03-08 19:01:22 +05:30
this.body = frappe.ui.add('div', 'page-body', this.wrapper);
2018-02-15 15:23:28 +05:30
}
setTitle(title) {
this.titleElement.textContent = title;
if (this.hasRoute) {
document.title = title;
}
2018-01-12 17:55:07 +05:30
}
addTitleBadge(message, title='', style='secondary') {
this.titleElement.innerHTML += ` <span class='badge badge-${style}' title='${title}'>
${message}</span>`;
}
2018-03-26 14:23:46 +05:30
clearLinks() {
frappe.ui.empty(this.linksElement);
}
2018-01-12 17:55:07 +05:30
hide() {
2018-02-20 12:09:41 +05:30
this.parent.activePage = null;
this.wrapper.classList.add('hide');
2018-01-12 17:55:07 +05:30
this.trigger('hide');
}
addButton(label, className, action) {
2018-02-08 15:08:47 +05:30
this.head.classList.remove('hide');
2018-02-15 15:23:28 +05:30
this.button = frappe.ui.add('button', 'btn btn-sm float-right ' + this.getClassName(className), this.head);
2018-02-08 15:08:47 +05:30
this.button.innerHTML = label;
this.button.addEventListener('click', action);
return this.button;
}
2018-02-14 18:20:56 +05:30
getDropdown(label) {
if (!this.dropdowns[label]) {
2018-02-15 15:23:28 +05:30
this.dropdowns[label] = new Dropdown({parent: this.head, label: label,
right: true, cssClass: 'btn-secondary btn-sm'});
2018-02-14 18:20:56 +05:30
}
return this.dropdowns[label];
}
2018-01-16 11:39:17 +05:30
async show(params) {
2018-02-14 22:14:50 +05:30
if (this.parent.activePage) {
this.parent.activePage.hide();
2018-01-12 17:55:07 +05:30
}
2018-02-14 22:14:50 +05:30
this.wrapper.classList.remove('hide');
this.body.classList.remove('hide');
if (this.page_error) {
this.page_error.classList.add('hide');
}
2018-02-14 22:14:50 +05:30
this.parent.activePage = this;
2018-03-26 17:48:07 +05:30
frappe.desk.toggleCenter(this.fullPage ? false : true);
2018-01-12 17:55:07 +05:30
}
2018-02-08 15:08:47 +05:30
renderError(title, message) {
if (!this.page_error) {
this.page_error = frappe.ui.add('div', 'page-error', this.wrapper);
}
this.body.classList.add('hide');
this.page_error.classList.remove('hide');
2018-01-23 13:30:29 +05:30
this.page_error.innerHTML = `<h3 class="text-extra-muted">${title ? title : ""}</h3><p class="text-muted">${message ? message : ""}</p>`;
}
getClassName(className) {
const newName = {
'primary': 'btn-primary',
'secondary': 'btn-outline-secondary'
}[className];
return newName || className;
}
}