mirror of
https://github.com/frappe/books.git
synced 2024-12-26 12:28:12 +00:00
231b36a51b
* making the datatable fields non editable and making the field selectable that uses formula * Revised the datatable selectable property * Update index.vue
62 lines
1.9 KiB
JavaScript
62 lines
1.9 KiB
JavaScript
const frappe = require('frappejs');
|
|
|
|
module.exports = {
|
|
convertFieldsToDatatableColumns(fields, layout = 'fixed') {
|
|
return fields.map(field => {
|
|
if (!field.width) {
|
|
if (layout==='ratio') {
|
|
field.width = 1;
|
|
} else if (layout==='fixed') {
|
|
field.width = 120;
|
|
}
|
|
}
|
|
return {
|
|
id: field.fieldname || frappe.slug(field.label),
|
|
field: field,
|
|
content: field.label,
|
|
editable: true,
|
|
sortable: false,
|
|
resizable: true,
|
|
dropdown: false,
|
|
width: field.width,
|
|
align: ['Int', 'Float', 'Currency'].includes(field.fieldtype) ? 'right' : 'left',
|
|
format: (value) => frappe.format(value, field)
|
|
}
|
|
});
|
|
|
|
},
|
|
|
|
addButton(label, parent, action, unhide = true) {
|
|
const link = frappe.ui.add('button', 'btn btn-sm btn-outline-secondary', parent, label);
|
|
link.type = 'button';
|
|
link.addEventListener('click', action);
|
|
if (unhide) {
|
|
parent.classList.remove('hide');
|
|
}
|
|
return link;
|
|
},
|
|
|
|
// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/
|
|
forEachNode(nodeList, callback, scope) {
|
|
if(!nodeList) return;
|
|
for (var i = 0; i < nodeList.length; i++) {
|
|
callback.call(scope, nodeList[i], i);
|
|
}
|
|
},
|
|
|
|
activate($parent, $child, commonSelector, activeClass='active', index = -1) {
|
|
let $children = $parent.querySelectorAll(`${commonSelector}.${activeClass}`);
|
|
|
|
if (typeof $child === 'string') {
|
|
$child = $parent.querySelector($child);
|
|
}
|
|
|
|
this.forEachNode($children, (node, i) => {
|
|
if(index >= 0 && i <= index) return;
|
|
node.classList.remove(activeClass);
|
|
})
|
|
|
|
$child.classList.add(activeClass);
|
|
}
|
|
}
|