2
0
mirror of https://github.com/frappe/books.git synced 2025-01-10 18:24:40 +00:00

template for taxes

This commit is contained in:
Rushabh Mehta 2018-02-19 12:01:22 +05:30
parent 34b72f2297
commit d09de107d9
3 changed files with 421 additions and 309 deletions

612
dist/js/bundle.js vendored
View File

@ -689,6 +689,10 @@ var meta = class BaseMeta extends document$1 {
} }
} }
hasField(fieldname) {
return this.getField(fieldname) ? true : false;
}
getField(fieldname) { getField(fieldname) {
if (!this._field_map) { if (!this._field_map) {
this._field_map = {}; this._field_map = {};
@ -18479,20 +18483,37 @@ class BaseControl {
if (this.setup) { if (this.setup) {
this.setup(); this.setup();
} }
this.make(); if (this.template) {
this.wrapper = frappejs.ui.add('div', 'field-template', this.parent);
this.renderTemplate();
} else {
this.make();
}
} }
bind(doc) { bind(doc) {
this.doc = doc; this.doc = doc;
this.setDocValue(); this.refresh();
} }
refresh() { refresh() {
this.setDocValue(); if (this.template) {
this.renderTemplate();
} else {
this.setDocValue();
}
}
renderTemplate() {
if (this.form.doc) {
this.wrapper.innerHTML = this.template(this.form.doc, this.doc);
} else {
this.wrapper.innerHTML = '';
}
} }
setDocValue() { setDocValue() {
if (this.doc) { if (this.doc && !this.template) {
this.setInputValue(this.doc.get(this.fieldname)); this.setInputValue(this.doc.get(this.fieldname));
} }
} }
@ -21309,7 +21330,11 @@ class LinkControl extends base {
if (e.text && e.text.value === '__newItem') { if (e.text && e.text.value === '__newItem') {
e.preventDefault(); e.preventDefault();
const newDoc = await frappejs.getNewDoc(this.target); const newDoc = await frappejs.getNewDoc(this.target);
const formModal = frappejs.desk.showFormModal(this.target, newDoc.name); const formModal = await frappejs.desk.showFormModal(this.target, newDoc.name);
if (formModal.form.doc.meta.hasField('name')) {
formModal.form.doc.set('name', this.input.value);
}
formModal.once('submit', async () => { formModal.once('submit', async () => {
await this.updateDocValue(formModal.form.doc.name); await this.updateDocValue(formModal.form.doc.name);
}); });
@ -23529,6 +23554,7 @@ exports.isNumeric = isNumeric;
exports.throttle = throttle; exports.throttle = throttle;
exports.promisify = promisify; exports.promisify = promisify;
exports.chainPromises = chainPromises; exports.chainPromises = chainPromises;
exports.linkProperties = linkProperties;
function camelCaseToDash(str) { function camelCaseToDash(str) {
return str.replace(/([A-Z])/g, function (g) { return str.replace(/([A-Z])/g, function (g) {
return '-' + g[0].toLowerCase(); return '-' + g[0].toLowerCase();
@ -23743,6 +23769,18 @@ function chainPromises(promises) {
}, Promise.resolve()); }, Promise.resolve());
} }
function linkProperties(target, source, properties) {
var props = properties.reduce(function (acc, prop) {
acc[prop] = {
get: function get() {
return source[prop];
}
};
return acc;
}, {});
Object.defineProperties(target, props);
}
/***/ }), /***/ }),
/* 2 */ /* 2 */
/***/ (function(module, exports, __webpack_require__) { /***/ (function(module, exports, __webpack_require__) {
@ -23773,14 +23811,8 @@ var ColumnManager = function () {
_classCallCheck(this, ColumnManager); _classCallCheck(this, ColumnManager);
this.instance = instance; this.instance = instance;
this.options = this.instance.options;
this.fireEvent = this.instance.fireEvent; (0, _utils.linkProperties)(this, this.instance, ['options', 'fireEvent', 'header', 'datamanager', 'style', 'wrapper', 'rowmanager', 'bodyScrollable']);
this.header = this.instance.header;
this.datamanager = this.instance.datamanager;
this.style = this.instance.style;
this.wrapper = this.instance.wrapper;
this.rowmanager = this.instance.rowmanager;
this.bodyScrollable = this.instance.bodyScrollable;
this.bindEvents(); this.bindEvents();
exports.getDropdownHTML = getDropdownHTML = getDropdownHTML.bind(this, this.options.dropdownButton); exports.getDropdownHTML = getDropdownHTML = getDropdownHTML.bind(this, this.options.dropdownButton);
@ -23918,7 +23950,7 @@ var ColumnManager = function () {
colIndex = _$$data4.colIndex; colIndex = _$$data4.colIndex;
_this3.setColumnWidth(colIndex); _this3.setColumnWidth(colIndex);
_this3.instance.setBodyWidth(); _this3.style.setBodyStyle();
$resizingCell = null; $resizingCell = null;
}); });
@ -24072,154 +24104,6 @@ var ColumnManager = function () {
_this8.fireEvent('onSwitchColumn', _this8.getColumn(oldIndex), _this8.getColumn(newIndex)); _this8.fireEvent('onSwitchColumn', _this8.getColumn(oldIndex), _this8.getColumn(newIndex));
}); });
} }
}, {
key: 'setDimensions',
value: function setDimensions() {
this.setHeaderStyle();
this.setupMinWidth();
this.setupNaturalColumnWidth();
this.distributeRemainingWidth();
this.setColumnStyle();
this.setDefaultCellHeight();
}
}, {
key: 'setHeaderStyle',
value: function setHeaderStyle() {
if (!this.options.takeAvailableSpace) {
// setting width as 0 will ensure that the
// header doesn't take the available space
_dom2.default.style(this.header, {
width: 0
});
}
_dom2.default.style(this.header, {
margin: 0
});
// don't show resize cursor on nonResizable columns
var nonResizableColumnsSelector = this.datamanager.getColumns().filter(function (col) {
return col.resizable === false;
}).map(function (col) {
return col.colIndex;
}).map(function (i) {
return '.data-table-header [data-col-index="' + i + '"]';
}).join();
this.style.setStyle(nonResizableColumnsSelector, {
cursor: 'pointer'
});
}
}, {
key: 'setupMinWidth',
value: function setupMinWidth() {
var _this9 = this;
_dom2.default.each('.data-table-col', this.header).map(function (col) {
var width = _dom2.default.style((0, _dom2.default)('.content', col), 'width');
var _$$data8 = _dom2.default.data(col),
colIndex = _$$data8.colIndex;
var column = _this9.getColumn(colIndex);
if (!column.minWidth) {
// only set this once
_this9.datamanager.updateColumn(colIndex, { minWidth: width });
}
});
}
}, {
key: 'setupNaturalColumnWidth',
value: function setupNaturalColumnWidth() {
var _this10 = this;
// set initial width as naturally calculated by table's first row
_dom2.default.each('.data-table-row[data-row-index="0"] .data-table-col', this.bodyScrollable).map(function ($cell) {
var _$$data9 = _dom2.default.data($cell),
colIndex = _$$data9.colIndex;
if (_this10.getColumn(colIndex).width > 0) {
// already set
return;
}
var width = _dom2.default.style((0, _dom2.default)('.content', $cell), 'width');
var minWidth = _this10.getColumnMinWidth(colIndex);
if (width < minWidth) {
width = minWidth;
}
_this10.datamanager.updateColumn(colIndex, { width: width });
});
}
}, {
key: 'distributeRemainingWidth',
value: function distributeRemainingWidth() {
var _this11 = this;
if (!this.options.takeAvailableSpace) return;
var wrapperWidth = _dom2.default.style(this.instance.datatableWrapper, 'width');
var headerWidth = _dom2.default.style(this.header, 'width');
if (headerWidth >= wrapperWidth) {
// don't resize, horizontal scroll takes place
return;
}
var resizableColumns = this.datamanager.getColumns().filter(function (col) {
return col.resizable === undefined || col.resizable;
});
var deltaWidth = (wrapperWidth - headerWidth) / resizableColumns.length;
resizableColumns.map(function (col) {
var width = _dom2.default.style(_this11.getColumnHeaderElement(col.colIndex), 'width');
var finalWidth = Math.min(width + deltaWidth) - 2;
_this11.datamanager.updateColumn(col.colIndex, { width: finalWidth });
});
}
}, {
key: 'setDefaultCellHeight',
value: function setDefaultCellHeight() {
if (this.__cellHeightSet) return;
var height = _dom2.default.style((0, _dom2.default)('.data-table-col', this.instance.datatableWrapper), 'height');
if (height) {
this.setCellHeight(height);
this.__cellHeightSet = true;
}
}
}, {
key: 'setCellHeight',
value: function setCellHeight(height) {
this.style.setStyle('.data-table-col .content', {
height: height + 'px'
});
this.style.setStyle('.data-table-col .edit-cell', {
height: height + 'px'
});
}
}, {
key: 'setColumnStyle',
value: function setColumnStyle() {
var _this12 = this;
// align columns
this.getColumns().map(function (column) {
// alignment
if (['left', 'center', 'right'].includes(column.align)) {
_this12.style.setStyle('[data-col-index="' + column.colIndex + '"]', {
'text-align': column.align
});
}
// width
_this12.setColumnHeaderWidth(column.colIndex);
_this12.setColumnWidth(column.colIndex);
});
this.instance.setBodyWidth();
}
}, { }, {
key: 'sortRows', key: 'sortRows',
value: function sortRows(colIndex, sortOrder) { value: function sortRows(colIndex, sortOrder) {
@ -24300,13 +24184,6 @@ var ColumnManager = function () {
value: function getLastColumnIndex() { value: function getLastColumnIndex() {
return this.datamanager.getColumnCount() - 1; return this.datamanager.getColumnCount() - 1;
} }
}, {
key: 'getColumnHeaderElement',
value: function getColumnHeaderElement(colIndex) {
colIndex = +colIndex;
if (colIndex < 0) return null;
return (0, _dom2.default)('.data-table-col[data-is-header][data-col-index="' + colIndex + '"]', this.wrapper);
}
}, { }, {
key: 'getSerialColumnIndex', key: 'getSerialColumnIndex',
value: function getSerialColumnIndex() { value: function getSerialColumnIndex() {
@ -24508,30 +24385,23 @@ var DataTable = function () {
}, { }, {
key: 'setDimensions', key: 'setDimensions',
value: function setDimensions() { value: function setDimensions() {
this.columnmanager.setDimensions(); this.style.setDimensions();
this.setBodyWidth();
_dom2.default.style(this.bodyScrollable, {
marginTop: _dom2.default.style(this.header, 'height') + 'px'
});
_dom2.default.style((0, _dom2.default)('table', this.bodyScrollable), {
margin: 0
});
}
}, {
key: 'setBodyWidth',
value: function setBodyWidth() {
var width = _dom2.default.style(this.header, 'width');
_dom2.default.style(this.bodyScrollable, { width: width + 'px' });
} }
}, { }, {
key: 'getColumn', key: 'getColumn',
value: function getColumn(colIndex) { value: function getColumn(colIndex) {
return this.datamanager.getColumn(colIndex); return this.datamanager.getColumn(colIndex);
} }
}, {
key: 'getColumns',
value: function getColumns() {
return this.datamanager.getColumns();
}
}, {
key: 'getRows',
value: function getRows() {
return this.datamanager.getRows();
}
}, { }, {
key: 'getCell', key: 'getCell',
value: function getCell(colIndex, rowIndex) { value: function getCell(colIndex, rowIndex) {
@ -24751,6 +24621,7 @@ var DataManager = function () {
resizable: true, resizable: true,
focusable: true, focusable: true,
dropdown: true, dropdown: true,
width: null,
format: function format(value) { format: function format(value) {
if (value === null || value === undefined) { if (value === null || value === undefined) {
return ''; return '';
@ -24776,8 +24647,7 @@ var DataManager = function () {
align: 'left', align: 'left',
sortOrder: 'none', sortOrder: 'none',
colIndex: i, colIndex: i,
column: this.columns[i], column: this.columns[i]
width: 0
}; };
if (content !== null && (typeof content === 'undefined' ? 'undefined' : _typeof(content)) === 'object') { if (content !== null && (typeof content === 'undefined' ? 'undefined' : _typeof(content)) === 'object') {
@ -24825,6 +24695,10 @@ var DataManager = function () {
row.push(index + 1 + ''); row.push(index + 1 + '');
} }
row = row.concat(d); row = row.concat(d);
while (row.length < _this3.columns.length) {
row.push('');
}
} else { } else {
// row is a dict // row is a dict
var _iteratorNormalCompletion = true; var _iteratorNormalCompletion = true;
@ -25323,7 +25197,7 @@ var CellManager = function () {
var $cell = _this2.$focusedCell; var $cell = _this2.$focusedCell;
if (direction === 'left') { if (direction === 'left' || direction === 'shift+tab') {
$cell = _this2.getLeftCell$($cell); $cell = _this2.getLeftCell$($cell);
} else if (direction === 'right' || direction === 'tab') { } else if (direction === 'right' || direction === 'tab') {
$cell = _this2.getRightCell$($cell); $cell = _this2.getRightCell$($cell);
@ -25362,7 +25236,7 @@ var CellManager = function () {
return true; return true;
}; };
['left', 'right', 'up', 'down', 'tab'].map(function (direction) { ['left', 'right', 'up', 'down', 'tab', 'shift+tab'].map(function (direction) {
return _this2.keyboard.on(direction, function () { return _this2.keyboard.on(direction, function () {
return focusCell(direction); return focusCell(direction);
}); });
@ -26317,7 +26191,7 @@ var BodyRenderer = function () {
} }
}, },
/* eslint-disable */ /* eslint-disable */
no_data_text: this.options.loadingText, no_data_text: this.options.noDataMessage,
no_data_class: 'empty-state' no_data_class: 'empty-state'
/* eslint-enable */ /* eslint-enable */
}); });
@ -26385,25 +26259,49 @@ Object.defineProperty(exports, "__esModule", {
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _dom = __webpack_require__(0);
var _dom2 = _interopRequireDefault(_dom);
var _utils = __webpack_require__(1); var _utils = __webpack_require__(1);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var Style = function () { var Style = function () {
function Style(datatable) { function Style(instance) {
_classCallCheck(this, Style); _classCallCheck(this, Style);
this.datatable = datatable; this.instance = instance;
this.scopeClass = 'datatable-instance-' + datatable.constructor.instances;
datatable.datatableWrapper.classList.add(this.scopeClass); (0, _utils.linkProperties)(this, this.instance, ['options', 'datamanager', 'columnmanager', 'header', 'bodyScrollable', 'getColumn']);
this.scopeClass = 'datatable-instance-' + instance.constructor.instances;
instance.datatableWrapper.classList.add(this.scopeClass);
var styleEl = document.createElement('style'); var styleEl = document.createElement('style');
datatable.wrapper.insertBefore(styleEl, datatable.datatableWrapper); instance.wrapper.insertBefore(styleEl, instance.datatableWrapper);
this.styleEl = styleEl; this.styleEl = styleEl;
this.styleSheet = styleEl.sheet; this.styleSheet = styleEl.sheet;
this.bindResizeWindow();
} }
_createClass(Style, [{ _createClass(Style, [{
key: 'bindResizeWindow',
value: function bindResizeWindow() {
var _this = this;
if (this.options.layout === 'fluid') {
_dom2.default.on(window, 'resize', (0, _utils.throttle)(function () {
_this.distributeRemainingWidth();
_this.refreshColumnWidth();
_this.setBodyStyle();
}, 300));
}
}
}, {
key: 'destroy', key: 'destroy',
value: function destroy() { value: function destroy() {
this.styleEl.remove(); this.styleEl.remove();
@ -26430,6 +26328,193 @@ var Style = function () {
this.styleSheet.insertRule(ruleString, _index); this.styleSheet.insertRule(ruleString, _index);
return _index; return _index;
} }
}, {
key: 'setDimensions',
value: function setDimensions() {
this.setHeaderStyle();
this.setupMinWidth();
this.setupNaturalColumnWidth();
this.setupColumnWidth();
this.distributeRemainingWidth();
this.setColumnStyle();
this.setDefaultCellHeight();
this.setBodyStyle();
}
}, {
key: 'setHeaderStyle',
value: function setHeaderStyle() {
if (this.options.layout === 'fluid') {
// setting width as 0 will ensure that the
// header doesn't take the available space
_dom2.default.style(this.header, {
width: 0
});
}
_dom2.default.style(this.header, {
margin: 0
});
// don't show resize cursor on nonResizable columns
var nonResizableColumnsSelector = this.datamanager.getColumns().filter(function (col) {
return col.resizable === false;
}).map(function (col) {
return col.colIndex;
}).map(function (i) {
return '.data-table-header [data-col-index="' + i + '"]';
}).join();
this.setStyle(nonResizableColumnsSelector, {
cursor: 'pointer'
});
}
}, {
key: 'setupMinWidth',
value: function setupMinWidth() {
var _this2 = this;
_dom2.default.each('.data-table-col', this.header).map(function (col) {
var width = _dom2.default.style((0, _dom2.default)('.content', col), 'width');
var _$$data = _dom2.default.data(col),
colIndex = _$$data.colIndex;
var column = _this2.getColumn(colIndex);
if (!column.minWidth) {
// only set this once
column.minWidth = width;
}
});
}
}, {
key: 'setupNaturalColumnWidth',
value: function setupNaturalColumnWidth() {
var _this3 = this;
if (!(0, _dom2.default)('.data-table-row')) return;
// set initial width as naturally calculated by table's first row
_dom2.default.each('.data-table-row[data-row-index="0"] .data-table-col', this.bodyScrollable).map(function ($cell) {
var _$$data2 = _dom2.default.data($cell),
colIndex = _$$data2.colIndex;
var column = _this3.datamanager.getColumn(colIndex);
var naturalWidth = _dom2.default.style((0, _dom2.default)('.content', $cell), 'width');
column.naturalWidth = naturalWidth;
});
}
}, {
key: 'setupColumnWidth',
value: function setupColumnWidth() {
this.datamanager.getColumns().map(function (column) {
if (column.width === null) {
column.width = column.naturalWidth;
}
if (column.width < column.minWidth) {
column.width = column.minWidth;
}
});
}
}, {
key: 'distributeRemainingWidth',
value: function distributeRemainingWidth() {
var _this4 = this;
if (this.options.layout !== 'fluid') return;
var wrapperWidth = _dom2.default.style(this.instance.datatableWrapper, 'width');
var headerWidth = _dom2.default.style(this.header, 'width');
var resizableColumns = this.datamanager.getColumns().filter(function (col) {
return col.resizable;
});
var deltaWidth = (wrapperWidth - headerWidth) / resizableColumns.length;
resizableColumns.map(function (col) {
var width = _dom2.default.style(_this4.getColumnHeaderElement(col.colIndex), 'width');
var finalWidth = Math.floor(width + deltaWidth) - 2;
_this4.datamanager.updateColumn(col.colIndex, {
width: finalWidth
});
});
}
}, {
key: 'setDefaultCellHeight',
value: function setDefaultCellHeight() {
if (this.__cellHeightSet) return;
var height = _dom2.default.style((0, _dom2.default)('.data-table-col', this.instance.datatableWrapper), 'height');
if (height) {
this.setCellHeight(height);
this.__cellHeightSet = true;
}
}
}, {
key: 'setCellHeight',
value: function setCellHeight(height) {
this.setStyle('.data-table-col .content', {
height: height + 'px'
});
this.setStyle('.data-table-col .edit-cell', {
height: height + 'px'
});
}
}, {
key: 'setColumnStyle',
value: function setColumnStyle() {
var _this5 = this;
// align columns
this.datamanager.getColumns().map(function (column) {
// alignment
if (['left', 'center', 'right'].includes(column.align)) {
_this5.setStyle('[data-col-index="' + column.colIndex + '"]', {
'text-align': column.align
});
}
// width
_this5.columnmanager.setColumnHeaderWidth(column.colIndex);
_this5.columnmanager.setColumnWidth(column.colIndex);
});
this.setBodyStyle();
}
}, {
key: 'refreshColumnWidth',
value: function refreshColumnWidth() {
var _this6 = this;
this.datamanager.getColumns().map(function (column) {
_this6.columnmanager.setColumnHeaderWidth(column.colIndex);
_this6.columnmanager.setColumnWidth(column.colIndex);
});
}
}, {
key: 'setBodyStyle',
value: function setBodyStyle() {
var width = _dom2.default.style(this.header, 'width');
_dom2.default.style(this.bodyScrollable, {
width: width + 'px'
});
_dom2.default.style(this.bodyScrollable, {
marginTop: _dom2.default.style(this.header, 'height') + 'px'
});
_dom2.default.style((0, _dom2.default)('table', this.bodyScrollable), {
margin: 0
});
}
}, {
key: 'getColumnHeaderElement',
value: function getColumnHeaderElement(colIndex) {
colIndex = +colIndex;
if (colIndex < 0) return null;
return (0, _dom2.default)('.data-table-col[data-col-index="' + colIndex + '"]', this.header);
}
}]); }]);
return Style; return Style;
@ -26594,8 +26679,8 @@ exports.default = {
addCheckboxColumn: false, addCheckboxColumn: false,
enableClusterize: true, enableClusterize: true,
enableLogs: false, enableLogs: false,
takeAvailableSpace: false, layout: 'fixed', // fixed, fluid
loadingText: '' noDataMessage: 'No Data'
}; };
module.exports = exports['default']; module.exports = exports['default'];
@ -27282,7 +27367,7 @@ class TableControl extends base {
this.datatable = new frappeDatatable(this.wrapper.querySelector('.datatable-wrapper'), { this.datatable = new frappeDatatable(this.wrapper.querySelector('.datatable-wrapper'), {
columns: this.getColumns(), columns: this.getColumns(),
data: this.getTableData(), data: this.getTableData(),
takeAvailableSpace: true, layout: 'fluid',
addCheckboxColumn: true, addCheckboxColumn: true,
getEditor: this.getTableInput.bind(this), getEditor: this.getTableInput.bind(this),
}); });
@ -27382,7 +27467,6 @@ class TableControl extends base {
id: field.fieldname, id: field.fieldname,
field: field, field: field,
content: field.label, content: field.label,
width: 120,
editable: (this.disabled || field.disabled) ? false : true, editable: (this.disabled || field.disabled) ? false : true,
sortable: false, sortable: false,
resizable: true, resizable: true,
@ -27636,7 +27720,7 @@ var form = class BaseForm extends observable {
// only single value changed // only single value changed
let control = this.controls[params.fieldname]; let control = this.controls[params.fieldname];
if (control && control.getInputValue() !== control.format(params.fieldname)) { if (control && control.getInputValue() !== control.format(params.fieldname)) {
control.setDocValue(); control.refresh();
} }
} else { } else {
// multiple values changed // multiple values changed
@ -27978,11 +28062,11 @@ var desk = class Desk {
return this.pages.forms[doctype]; return this.pages.forms[doctype];
} }
showFormModal(doctype, name) { async showFormModal(doctype, name) {
if (!this.pages.formModals[doctype]) { if (!this.pages.formModals[doctype]) {
this.pages.formModals[doctype] = new formmodal(doctype); this.pages.formModals[doctype] = new formmodal(doctype);
} }
this.pages.formModals[doctype].showWith(doctype, name); await this.pages.formModals[doctype].showWith(doctype, name);
return this.pages.formModals[doctype]; return this.pages.formModals[doctype];
} }
@ -28429,59 +28513,73 @@ var InvoiceDocument = class Invoice extends document$1 {
} }
}; };
var Invoice = { var Invoice = createCommonjsModule(function (module) {
"name": "Invoice", module.exports = {
"doctype": "DocType", "name": "Invoice",
"documentClass": InvoiceDocument, "doctype": "DocType",
"isSingle": 0, "documentClass": InvoiceDocument,
"istable": 0, "isSingle": 0,
"keywordFields": ["name", "customer"], "istable": 0,
"settings": "InvoiceSettings", "keywordFields": ["name", "customer"],
"showTitle": true, "settings": "InvoiceSettings",
"fields": [ "showTitle": true,
{ "fields": [
"fieldname": "date", {
"label": "Date", "fieldname": "date",
"fieldtype": "Date" "label": "Date",
}, "fieldtype": "Date"
{ },
"fieldname": "customer", {
"label": "Customer", "fieldname": "customer",
"fieldtype": "Link", "label": "Customer",
"target": "Customer", "fieldtype": "Link",
"required": 1 "target": "Customer",
}, "required": 1
{ },
"fieldname": "items", {
"label": "Items", "fieldname": "items",
"fieldtype": "Table", "label": "Items",
"childtype": "InvoiceItem", "fieldtype": "Table",
"required": true "childtype": "InvoiceItem",
}, "required": true
{ },
"fieldname": "netTotal", {
"label": "Total", "fieldname": "netTotal",
"fieldtype": "Currency", "label": "Total",
formula: (doc) => doc.getSum('items', 'amount'), "fieldtype": "Currency",
"disabled": true formula: (doc) => doc.getSum('items', 'amount'),
}, "disabled": true
{ },
"fieldname": "taxes", {
"label": "Taxes", "fieldname": "taxes",
"fieldtype": "Table", "label": "Taxes",
"childtype": "TaxSummary", "fieldtype": "Table",
"disabled": true, "childtype": "TaxSummary",
"template": `<div></div>` "disabled": true,
}, template: (doc, row) => {
{ return `<div class='row'>
"fieldname": "grandTotal", <div class='col-6'><!-- empty left side --></div>
"label": "Total", <div class='col-6'>${(doc.taxes || []).map(row => {
"fieldtype": "Currency", return `<div class='row'>
formula: (doc) => doc.getGrandTotal(), <div class='col-6'>${row.account} (${row.rate}%)</div>
"disabled": true <div class='col-6 text-right'>
} ${frappejs.format(row.amount, {fieldtype:'Currency'})}
] </div>
</div>`
}).join('')}
</div></div>`;
}
},
{
"fieldname": "grandTotal",
"label": "Total",
"fieldtype": "Currency",
formula: (doc) => doc.getGrandTotal(),
"disabled": true
}
]
}; };
});
var InvoiceItem = { var InvoiceItem = {
"name": "InvoiceItem", "name": "InvoiceItem",
@ -28515,7 +28613,7 @@ var InvoiceItem = {
"label": "Rate", "label": "Rate",
"fieldtype": "Currency", "fieldtype": "Currency",
"required": 1, "required": 1,
formula: (row, doc) => doc.getFrom('Item', row.item, 'rate') formula: (row, doc) => row.rate || doc.getFrom('Item', row.item, 'rate')
}, },
{ {
"fieldname": "tax", "fieldname": "tax",

View File

@ -30,7 +30,7 @@ module.exports = {
"label": "Rate", "label": "Rate",
"fieldtype": "Currency", "fieldtype": "Currency",
"required": 1, "required": 1,
formula: (row, doc) => doc.getFrom('Item', row.item, 'rate') formula: (row, doc) => row.rate || doc.getFrom('Item', row.item, 'rate')
}, },
{ {
"fieldname": "tax", "fieldname": "tax",

View File

@ -1,53 +1,67 @@
const frappe = require('frappejs');
module.exports = { module.exports = {
"name": "Invoice", "name": "Invoice",
"doctype": "DocType", "doctype": "DocType",
"documentClass": require("./InvoiceDocument.js"), "documentClass": require("./InvoiceDocument.js"),
"isSingle": 0, "isSingle": 0,
"istable": 0, "istable": 0,
"keywordFields": ["name", "customer"], "keywordFields": ["name", "customer"],
"settings": "InvoiceSettings", "settings": "InvoiceSettings",
"showTitle": true, "showTitle": true,
"fields": [ "fields": [
{ {
"fieldname": "date", "fieldname": "date",
"label": "Date", "label": "Date",
"fieldtype": "Date" "fieldtype": "Date"
}, },
{ {
"fieldname": "customer", "fieldname": "customer",
"label": "Customer", "label": "Customer",
"fieldtype": "Link", "fieldtype": "Link",
"target": "Customer", "target": "Customer",
"required": 1 "required": 1
}, },
{ {
"fieldname": "items", "fieldname": "items",
"label": "Items", "label": "Items",
"fieldtype": "Table", "fieldtype": "Table",
"childtype": "InvoiceItem", "childtype": "InvoiceItem",
"required": true "required": true
}, },
{ {
"fieldname": "netTotal", "fieldname": "netTotal",
"label": "Total", "label": "Total",
"fieldtype": "Currency", "fieldtype": "Currency",
formula: (doc) => doc.getSum('items', 'amount'), formula: (doc) => doc.getSum('items', 'amount'),
"disabled": true "disabled": true
}, },
{ {
"fieldname": "taxes", "fieldname": "taxes",
"label": "Taxes", "label": "Taxes",
"fieldtype": "Table", "fieldtype": "Table",
"childtype": "TaxSummary", "childtype": "TaxSummary",
"disabled": true, "disabled": true,
"template": `<div></div>` template: (doc, row) => {
}, return `<div class='row'>
{ <div class='col-6'><!-- empty left side --></div>
"fieldname": "grandTotal", <div class='col-6'>${(doc.taxes || []).map(row => {
"label": "Total", return `<div class='row'>
"fieldtype": "Currency", <div class='col-6'>${row.account} (${row.rate}%)</div>
formula: (doc) => doc.getGrandTotal(), <div class='col-6 text-right'>
"disabled": true ${frappe.format(row.amount, {fieldtype:'Currency'})}
} </div>
] </div>`
}).join('')}
</div></div>`;
}
},
{
"fieldname": "grandTotal",
"label": "Total",
"fieldtype": "Currency",
formula: (doc) => doc.getGrandTotal(),
"disabled": true
}
]
} }