mirror of
https://github.com/frappe/books.git
synced 2025-01-25 16:18:33 +00:00
added payment
This commit is contained in:
parent
bfe679d48f
commit
66cdea78a5
@ -1,4 +1,4 @@
|
|||||||
const GeneralLedgerView = require('../reports/GeneralLedgerView');
|
const GeneralLedgerView = require('../reports/generalLedger/GeneralLedgerView');
|
||||||
const frappe = require('frappejs');
|
const frappe = require('frappejs');
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
@ -9,10 +9,6 @@ module.exports = {
|
|||||||
frappe.registerView('List', 'ToDo', require('frappejs/models/doctype/ToDo/ToDoList.js'));
|
frappe.registerView('List', 'ToDo', require('frappejs/models/doctype/ToDo/ToDoList.js'));
|
||||||
frappe.registerView('Form', 'FilterSelector', require('frappejs/models/doctype/FilterSelector/FilterSelectorForm.js'));
|
frappe.registerView('Form', 'FilterSelector', require('frappejs/models/doctype/FilterSelector/FilterSelectorForm.js'));
|
||||||
|
|
||||||
frappe.registerView('List', 'Account', require('../models/doctype/Account/AccountList.js'));
|
|
||||||
frappe.registerView('Form', 'Account', require('../models/doctype/Account/AccountForm.js'));
|
|
||||||
|
|
||||||
frappe.registerView('List', 'Invoice', require('../models/doctype/Invoice/InvoiceList.js'));
|
|
||||||
frappe.registerView('List', 'Customer', require('../models/doctype/Party/CustomerList.js'));
|
frappe.registerView('List', 'Customer', require('../models/doctype/Party/CustomerList.js'));
|
||||||
|
|
||||||
frappe.router.add('report/general-ledger', async (params) => {
|
frappe.router.add('report/general-ledger', async (params) => {
|
||||||
|
@ -18,7 +18,13 @@ module.exports = {
|
|||||||
"fieldname": "parent_account",
|
"fieldname": "parent_account",
|
||||||
"label": "Parent Account",
|
"label": "Parent Account",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
"target": "Account"
|
"target": "Account",
|
||||||
|
getFilters: (query, control) => {
|
||||||
|
return {
|
||||||
|
keywords: ["like", query],
|
||||||
|
name: ["!=", control.doc.name]
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"fieldname": "account_type",
|
"fieldname": "account_type",
|
||||||
@ -38,5 +44,14 @@ module.exports = {
|
|||||||
validate: (doc) => {
|
validate: (doc) => {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
listSettings: {
|
||||||
|
getFields(list) {
|
||||||
|
return ['name', 'account_type'];
|
||||||
|
},
|
||||||
|
getRowHTML(list, data) {
|
||||||
|
return `<div class="col-11">${list.getNameHTML(data)} (${data.account_type})</div>`;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,15 +0,0 @@
|
|||||||
const BaseForm = require('frappejs/client/view/form');
|
|
||||||
|
|
||||||
module.exports = class AccountForm extends BaseForm {
|
|
||||||
make() {
|
|
||||||
super.make();
|
|
||||||
|
|
||||||
// override controller event
|
|
||||||
this.controls['parent_account'].getFilters = (query) => {
|
|
||||||
return {
|
|
||||||
keywords: ["like", query],
|
|
||||||
name: ["!=", this.doc.name]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,10 +0,0 @@
|
|||||||
const BaseList = require('frappejs/client/view/list');
|
|
||||||
|
|
||||||
module.exports = class AccountList extends BaseList {
|
|
||||||
getFields() {
|
|
||||||
return ['name', 'account_type'];
|
|
||||||
}
|
|
||||||
getRowHTML(data) {
|
|
||||||
return `<div class="col-11">${this.getNameHTML(data)} (${data.account_type})</div>`;
|
|
||||||
}
|
|
||||||
}
|
|
@ -59,7 +59,7 @@ module.exports = {
|
|||||||
{
|
{
|
||||||
fieldname: "referenceName",
|
fieldname: "referenceName",
|
||||||
label: "Reference Name",
|
label: "Reference Name",
|
||||||
fieldtype: "Dynamic Link",
|
fieldtype: "DynamicLink",
|
||||||
references: "referenceType"
|
references: "referenceType"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -102,8 +102,8 @@ module.exports = {
|
|||||||
links: [
|
links: [
|
||||||
{
|
{
|
||||||
label: 'Ledger Entries',
|
label: 'Ledger Entries',
|
||||||
condition: (form) => form.doc.submitted,
|
condition: form => form.doc.submitted,
|
||||||
action:(form) => {
|
action: form => {
|
||||||
return {
|
return {
|
||||||
route: ['table', 'AccountingLedgerEntry'],
|
route: ['table', 'AccountingLedgerEntry'],
|
||||||
params: {
|
params: {
|
||||||
@ -114,6 +114,29 @@ module.exports = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Make Payment',
|
||||||
|
condition: form => form.doc.submitted,
|
||||||
|
action: async form => {
|
||||||
|
const payment = await frappe.getNewDoc('Payment');
|
||||||
|
payment.party = form.doc.customer,
|
||||||
|
payment.account = form.doc.account,
|
||||||
|
payment.for = [{referenceType: form.doc.doctype, referenceName: form.doc.name, amount: form.doc.grandTotal}]
|
||||||
|
const formModal = await frappe.desk.showFormModal('Payment', payment.name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
|
||||||
|
listSettings: {
|
||||||
|
getFields(list) {
|
||||||
|
return ['name', 'customer', 'grandTotal', 'submitted'];
|
||||||
|
},
|
||||||
|
|
||||||
|
getRowHTML(list, data) {
|
||||||
|
return `<div class="col-3">${list.getNameHTML(data)}</div>
|
||||||
|
<div class="col-4 text-muted">${data.customer}</div>
|
||||||
|
<div class="col-4 text-muted text-right">${frappe.format(data.grandTotal, "Currency")}</div>`;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
@ -1,13 +0,0 @@
|
|||||||
const BaseList = require('frappejs/client/view/list');
|
|
||||||
const frappe = require('frappejs');
|
|
||||||
|
|
||||||
module.exports = class InvoiceList extends BaseList {
|
|
||||||
getFields() {
|
|
||||||
return ['name', 'customer', 'grandTotal', 'submitted'];
|
|
||||||
}
|
|
||||||
getRowHTML(data) {
|
|
||||||
return `<div class="col-3">${this.getNameHTML(data)}</div>
|
|
||||||
<div class="col-4 text-muted">${data.customer}</div>
|
|
||||||
<div class="col-4 text-muted text-right">${frappe.format(data.grandTotal, "Currency")}</div>`;
|
|
||||||
}
|
|
||||||
}
|
|
71
models/doctype/Payment/Payment.js
Normal file
71
models/doctype/Payment/Payment.js
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
module.exports = {
|
||||||
|
name: "Payment",
|
||||||
|
label: "Payment",
|
||||||
|
naming: "name", // {random|autoincrement}
|
||||||
|
isSingle: 0,
|
||||||
|
isChild: 0,
|
||||||
|
keywordFields: [],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
"fieldname": "date",
|
||||||
|
"label": "Date",
|
||||||
|
"fieldtype": "Date"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "party",
|
||||||
|
label: "Party",
|
||||||
|
fieldtype: "Link",
|
||||||
|
target: "Party",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "account",
|
||||||
|
label: "Account",
|
||||||
|
fieldtype: "Link",
|
||||||
|
target: "Account",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "paymentAccount",
|
||||||
|
label: "Payment Account",
|
||||||
|
fieldtype: "Link",
|
||||||
|
target: "Account",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "amount",
|
||||||
|
label: "Amount",
|
||||||
|
fieldtype: "Currency",
|
||||||
|
required: 1,
|
||||||
|
disabled: true,
|
||||||
|
formula: (doc) => doc.getSum('for', 'amount')
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "writeoff",
|
||||||
|
label: "Write Off / Refund",
|
||||||
|
fieldtype: "Currency",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "for",
|
||||||
|
label: "Payment For",
|
||||||
|
fieldtype: "Table",
|
||||||
|
childtype: "PaymentFor",
|
||||||
|
required: 1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
|
||||||
|
layout: [
|
||||||
|
{
|
||||||
|
columns: [
|
||||||
|
{ fields: ['date', 'party'] },
|
||||||
|
{ fields: ['account', 'paymentAccount'] },
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fields: ['for']
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fields: ['amount', 'writeoff']
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
28
models/doctype/PaymentFor/PaymentFor.js
Normal file
28
models/doctype/PaymentFor/PaymentFor.js
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
module.exports = {
|
||||||
|
name: "PaymentFor",
|
||||||
|
label: "Payment For",
|
||||||
|
isSingle: 0,
|
||||||
|
isChild: 1,
|
||||||
|
keywordFields: [],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
fieldname: "referenceType",
|
||||||
|
label: "Reference Type",
|
||||||
|
fieldtype: "Data",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "referenceName",
|
||||||
|
label: "Reference Name",
|
||||||
|
fieldtype: "DynamicLink",
|
||||||
|
references: "referenceType",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "amount",
|
||||||
|
label: "Amount",
|
||||||
|
fieldtype: "Currency",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
]
|
||||||
|
}
|
@ -3,6 +3,8 @@ module.exports = {
|
|||||||
Account: require('./doctype/Account/Account.js'),
|
Account: require('./doctype/Account/Account.js'),
|
||||||
AccountingLedgerEntry: require('./doctype/AccountingLedgerEntry/AccountingLedgerEntry.js'),
|
AccountingLedgerEntry: require('./doctype/AccountingLedgerEntry/AccountingLedgerEntry.js'),
|
||||||
Party: require('./doctype/Party/Party.js'),
|
Party: require('./doctype/Party/Party.js'),
|
||||||
|
Payment: require('./doctype/Payment/Payment.js'),
|
||||||
|
PaymentFor: require('./doctype/PaymentFor/PaymentFor.js'),
|
||||||
Item: require('./doctype/Item/Item.js'),
|
Item: require('./doctype/Item/Item.js'),
|
||||||
Invoice: require('./doctype/Invoice/Invoice.js'),
|
Invoice: require('./doctype/Invoice/Invoice.js'),
|
||||||
InvoiceItem: require('./doctype/InvoiceItem/InvoiceItem.js'),
|
InvoiceItem: require('./doctype/InvoiceItem/InvoiceItem.js'),
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
const server = require('frappejs/server');
|
const server = require('frappejs/server');
|
||||||
const frappe = require('frappejs');
|
const frappe = require('frappejs');
|
||||||
const GeneralLedger = require('../reports/GeneralLedger')
|
const GeneralLedger = require('../reports/generalLedger/GeneralLedger')
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
async start() {
|
async start() {
|
||||||
|
263
www/dist/js/bundle.js
vendored
263
www/dist/js/bundle.js
vendored
@ -4575,7 +4575,7 @@ if (typeof undefined === 'function' && undefined.amd) {
|
|||||||
}
|
}
|
||||||
}).call(commonjsGlobal);
|
}).call(commonjsGlobal);
|
||||||
|
|
||||||
|
//# sourceMappingURL=showdown.js.map
|
||||||
});
|
});
|
||||||
|
|
||||||
var moment = createCommonjsModule(function (module, exports) {
|
var moment = createCommonjsModule(function (module, exports) {
|
||||||
@ -10230,7 +10230,7 @@ var http = class HTTPClient extends observable {
|
|||||||
, 'Text': true
|
, 'Text': true
|
||||||
, 'Data': true
|
, 'Data': true
|
||||||
, 'Link': true
|
, 'Link': true
|
||||||
, 'Dynamic Link': true
|
, 'DynamicLink': true
|
||||||
, 'Password': true
|
, 'Password': true
|
||||||
, 'Select': true
|
, 'Select': true
|
||||||
, 'Read Only': true
|
, 'Read Only': true
|
||||||
@ -23046,7 +23046,7 @@ Popper.placements = placements;
|
|||||||
Popper.Defaults = Defaults;
|
Popper.Defaults = Defaults;
|
||||||
|
|
||||||
|
|
||||||
|
//# sourceMappingURL=popper.js.map
|
||||||
|
|
||||||
|
|
||||||
var popper = Object.freeze({
|
var popper = Object.freeze({
|
||||||
@ -26945,7 +26945,7 @@ exports.Tooltip = Tooltip;
|
|||||||
Object.defineProperty(exports, '__esModule', { value: true });
|
Object.defineProperty(exports, '__esModule', { value: true });
|
||||||
|
|
||||||
})));
|
})));
|
||||||
|
//# sourceMappingURL=bootstrap.js.map
|
||||||
});
|
});
|
||||||
|
|
||||||
unwrapExports(bootstrap);
|
unwrapExports(bootstrap);
|
||||||
@ -27346,7 +27346,7 @@ var keyboard = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
var list = class BaseList extends observable {
|
var list = class BaseList extends observable {
|
||||||
constructor({doctype, parent, fields, page}) {
|
constructor({doctype, parent, fields=[], page}) {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
Object.assign(this, arguments[0]);
|
Object.assign(this, arguments[0]);
|
||||||
@ -27360,11 +27360,29 @@ var list = class BaseList extends observable {
|
|||||||
this.rows = [];
|
this.rows = [];
|
||||||
this.data = [];
|
this.data = [];
|
||||||
|
|
||||||
|
this.setupListSettings();
|
||||||
|
|
||||||
frappejs.db.on(`change:${this.doctype}`, (params) => {
|
frappejs.db.on(`change:${this.doctype}`, (params) => {
|
||||||
this.refresh();
|
this.refresh();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setupListSettings() {
|
||||||
|
// list settings that can be overridden by meta
|
||||||
|
this.listSettings = {
|
||||||
|
getFields: list => list.fields,
|
||||||
|
getRowHTML: (list, data) => {
|
||||||
|
return `<div class="col-11">
|
||||||
|
${list.getNameHTML(data)}
|
||||||
|
</div>`;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
if (this.meta.listSettings) {
|
||||||
|
Object.assign(this.listSettings, this.meta.listSettings);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
makeBody() {
|
makeBody() {
|
||||||
if (!this.body) {
|
if (!this.body) {
|
||||||
this.makeToolbar();
|
this.makeToolbar();
|
||||||
@ -27405,7 +27423,7 @@ var list = class BaseList extends observable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async getData() {
|
async getData() {
|
||||||
let fields = this.getFields();
|
let fields = this.listSettings.getFields(this) || [];
|
||||||
this.updateStandardFields(fields);
|
this.updateStandardFields(fields);
|
||||||
return await frappejs.db.getAll({
|
return await frappejs.db.getAll({
|
||||||
doctype: this.doctype,
|
doctype: this.doctype,
|
||||||
@ -27416,10 +27434,6 @@ var list = class BaseList extends observable {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
getFields() {
|
|
||||||
return [];
|
|
||||||
}
|
|
||||||
|
|
||||||
updateStandardFields(fields) {
|
updateStandardFields(fields) {
|
||||||
if (!fields.includes('name')) fields.push('name');
|
if (!fields.includes('name')) fields.push('name');
|
||||||
if (!fields.includes('modified')) fields.push('modified');
|
if (!fields.includes('modified')) fields.push('modified');
|
||||||
@ -27448,14 +27462,9 @@ var list = class BaseList extends observable {
|
|||||||
getRowBodyHTML(data) {
|
getRowBodyHTML(data) {
|
||||||
return `<div class="col-1">
|
return `<div class="col-1">
|
||||||
<input class="checkbox" type="checkbox" data-name="${data.name}">
|
<input class="checkbox" type="checkbox" data-name="${data.name}">
|
||||||
</div>` + this.getRowHTML(data);
|
</div>` + this.listSettings.getRowHTML(this, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
getRowHTML(data) {
|
|
||||||
return `<div class="col-11">
|
|
||||||
${this.getNameHTML(data)}
|
|
||||||
</div>`;
|
|
||||||
}
|
|
||||||
|
|
||||||
getNameHTML(data) {
|
getNameHTML(data) {
|
||||||
return `<span class="indicator ${this.meta.getIndicatorColor(data)}">${data[this.meta.titleField]}</span>`;
|
return `<span class="indicator ${this.meta.getIndicatorColor(data)}">${data[this.meta.titleField]}</span>`;
|
||||||
@ -27691,7 +27700,7 @@ class BaseControl {
|
|||||||
}
|
}
|
||||||
|
|
||||||
renderTemplate() {
|
renderTemplate() {
|
||||||
if (this.form.doc) {
|
if (this.form && this.form.doc) {
|
||||||
this.wrapper.innerHTML = this.template(this.form.doc, this.doc);
|
this.wrapper.innerHTML = this.template(this.form.doc, this.doc);
|
||||||
} else {
|
} else {
|
||||||
this.wrapper.innerHTML = '';
|
this.wrapper.innerHTML = '';
|
||||||
@ -27823,6 +27832,7 @@ class BaseControl {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async updateDocValue(value) {
|
async updateDocValue(value) {
|
||||||
|
if (!this.doc) return;
|
||||||
if (this.doc[this.fieldname] !== value) {
|
if (this.doc[this.fieldname] !== value) {
|
||||||
if (this.parentControl) {
|
if (this.parentControl) {
|
||||||
// its a child
|
// its a child
|
||||||
@ -39796,11 +39806,6 @@ var htmlmixed = createCommonjsModule(function (module, exports) {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
// const frappe = require('frappejs');
|
|
||||||
|
|
||||||
// eslint-disable-line
|
|
||||||
// eslint-disable-line
|
|
||||||
|
|
||||||
class CodeControl extends base {
|
class CodeControl extends base {
|
||||||
makeInput() {
|
makeInput() {
|
||||||
if (!this.options) {
|
if (!this.options) {
|
||||||
@ -48118,9 +48123,6 @@ DataTable.__version__ = packageJson.version;
|
|||||||
module.exports = DataTable;
|
module.exports = DataTable;
|
||||||
});
|
});
|
||||||
|
|
||||||
// eslint-disable-line
|
|
||||||
|
|
||||||
|
|
||||||
var modal = class Modal extends observable {
|
var modal = class Modal extends observable {
|
||||||
constructor({ title, body, primary, secondary }) {
|
constructor({ title, body, primary, secondary }) {
|
||||||
super();
|
super();
|
||||||
@ -56645,7 +56647,7 @@ module.exports = installCompat;
|
|||||||
/***/ })
|
/***/ })
|
||||||
/******/ ]);
|
/******/ ]);
|
||||||
});
|
});
|
||||||
|
//# sourceMappingURL=nunjucks.js.map
|
||||||
});
|
});
|
||||||
|
|
||||||
unwrapExports(nunjucks);
|
unwrapExports(nunjucks);
|
||||||
@ -56846,10 +56848,6 @@ var menu = class DeskMenu {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// const Search = require('./search');
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const views = {};
|
const views = {};
|
||||||
views.Form = formpage;
|
views.Form = formpage;
|
||||||
views.List = listpage;
|
views.List = listpage;
|
||||||
@ -57587,10 +57585,6 @@ var client = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// baseclass for report
|
|
||||||
// `url` url for report
|
|
||||||
// `getColumns` return columns
|
|
||||||
|
|
||||||
var reportpage = class ReportPage extends page {
|
var reportpage = class ReportPage extends page {
|
||||||
constructor({title, }) {
|
constructor({title, }) {
|
||||||
super({title: title, hasRoute: true});
|
super({title: title, hasRoute: true});
|
||||||
@ -57612,7 +57606,7 @@ var reportpage = class ReportPage extends page {
|
|||||||
}
|
}
|
||||||
|
|
||||||
addFilter(field) {
|
addFilter(field) {
|
||||||
if (field.fieldname) {
|
if (!field.fieldname) {
|
||||||
field.fieldname = frappejs.slug(field.label);
|
field.fieldname = frappejs.slug(field.label);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57633,6 +57627,7 @@ var reportpage = class ReportPage extends page {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
console.log(values);
|
||||||
return values;
|
return values;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57699,7 +57694,8 @@ var AccountDocument = class Account extends document$1 {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
var Account = {
|
var Account = createCommonjsModule(function (module) {
|
||||||
|
module.exports = {
|
||||||
"name": "Account",
|
"name": "Account",
|
||||||
"doctype": "DocType",
|
"doctype": "DocType",
|
||||||
"documentClass": AccountDocument,
|
"documentClass": AccountDocument,
|
||||||
@ -57719,7 +57715,13 @@ var Account = {
|
|||||||
"fieldname": "parent_account",
|
"fieldname": "parent_account",
|
||||||
"label": "Parent Account",
|
"label": "Parent Account",
|
||||||
"fieldtype": "Link",
|
"fieldtype": "Link",
|
||||||
"target": "Account"
|
"target": "Account",
|
||||||
|
getFilters: (query, control) => {
|
||||||
|
return {
|
||||||
|
keywords: ["like", query],
|
||||||
|
name: ["!=", control.doc.name]
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"fieldname": "account_type",
|
"fieldname": "account_type",
|
||||||
@ -57739,8 +57741,21 @@ var Account = {
|
|||||||
validate: (doc) => {
|
validate: (doc) => {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
listSettings: {
|
||||||
|
getFields(list) {
|
||||||
|
return ['name', 'account_type'];
|
||||||
|
},
|
||||||
|
getRowHTML(list, data) {
|
||||||
|
return `<div class="col-11">${list.getNameHTML(data)} (${data.account_type})</div>`;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
var Account_1 = Account.events;
|
||||||
|
var Account_2 = Account.listSettings;
|
||||||
|
|
||||||
var AccountingLedgerEntry = {
|
var AccountingLedgerEntry = {
|
||||||
name: "AccountingLedgerEntry",
|
name: "AccountingLedgerEntry",
|
||||||
@ -57803,7 +57818,7 @@ var AccountingLedgerEntry = {
|
|||||||
{
|
{
|
||||||
fieldname: "referenceName",
|
fieldname: "referenceName",
|
||||||
label: "Reference Name",
|
label: "Reference Name",
|
||||||
fieldtype: "Dynamic Link",
|
fieldtype: "DynamicLink",
|
||||||
references: "referenceType"
|
references: "referenceType"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@ -57864,6 +57879,107 @@ module.exports = {
|
|||||||
|
|
||||||
var Party_1 = Party.links;
|
var Party_1 = Party.links;
|
||||||
|
|
||||||
|
var Payment = {
|
||||||
|
name: "Payment",
|
||||||
|
label: "Payment",
|
||||||
|
naming: "name", // {random|autoincrement}
|
||||||
|
isSingle: 0,
|
||||||
|
isChild: 0,
|
||||||
|
keywordFields: [],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
"fieldname": "date",
|
||||||
|
"label": "Date",
|
||||||
|
"fieldtype": "Date"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "party",
|
||||||
|
label: "Party",
|
||||||
|
fieldtype: "Link",
|
||||||
|
target: "Party",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "account",
|
||||||
|
label: "Account",
|
||||||
|
fieldtype: "Link",
|
||||||
|
target: "Account",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "paymentAccount",
|
||||||
|
label: "Payment Account",
|
||||||
|
fieldtype: "Link",
|
||||||
|
target: "Account",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "amount",
|
||||||
|
label: "Amount",
|
||||||
|
fieldtype: "Currency",
|
||||||
|
required: 1,
|
||||||
|
disabled: true,
|
||||||
|
formula: (doc) => doc.getSum('for', 'amount')
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "writeoff",
|
||||||
|
label: "Write Off / Refund",
|
||||||
|
fieldtype: "Currency",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "for",
|
||||||
|
label: "Payment For",
|
||||||
|
fieldtype: "Table",
|
||||||
|
childtype: "PaymentFor",
|
||||||
|
required: 1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
|
||||||
|
layout: [
|
||||||
|
{
|
||||||
|
columns: [
|
||||||
|
{ fields: ['date', 'party'] },
|
||||||
|
{ fields: ['account', 'paymentAccount'] },
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fields: ['for']
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fields: ['amount', 'writeoff']
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
var PaymentFor = {
|
||||||
|
name: "PaymentFor",
|
||||||
|
label: "Payment For",
|
||||||
|
isSingle: 0,
|
||||||
|
isChild: 1,
|
||||||
|
keywordFields: [],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
fieldname: "referenceType",
|
||||||
|
label: "Reference Type",
|
||||||
|
fieldtype: "Data",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "referenceName",
|
||||||
|
label: "Reference Name",
|
||||||
|
fieldtype: "DynamicLink",
|
||||||
|
references: "referenceType",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
fieldname: "amount",
|
||||||
|
label: "Amount",
|
||||||
|
fieldtype: "Currency",
|
||||||
|
required: 1
|
||||||
|
},
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
var Item = {
|
var Item = {
|
||||||
name: "Item",
|
name: "Item",
|
||||||
doctype: "DocType",
|
doctype: "DocType",
|
||||||
@ -58117,8 +58233,8 @@ module.exports = {
|
|||||||
links: [
|
links: [
|
||||||
{
|
{
|
||||||
label: 'Ledger Entries',
|
label: 'Ledger Entries',
|
||||||
condition: (form) => form.doc.submitted,
|
condition: form => form.doc.submitted,
|
||||||
action:(form) => {
|
action: form => {
|
||||||
return {
|
return {
|
||||||
route: ['table', 'AccountingLedgerEntry'],
|
route: ['table', 'AccountingLedgerEntry'],
|
||||||
params: {
|
params: {
|
||||||
@ -58129,13 +58245,35 @@ module.exports = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Make Payment',
|
||||||
|
condition: form => form.doc.submitted,
|
||||||
|
action: async form => {
|
||||||
|
const payment = await frappejs.getNewDoc('Payment');
|
||||||
|
payment.party = form.doc.customer, payment.account = form.doc.account, payment.for = [{referenceType: form.doc.doctype, referenceName: form.doc.name, amount: form.doc.grandTotal}];
|
||||||
|
const formModal = await frappejs.desk.showFormModal('Payment', payment.name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
|
||||||
|
listSettings: {
|
||||||
|
getFields(list) {
|
||||||
|
return ['name', 'customer', 'grandTotal', 'submitted'];
|
||||||
|
},
|
||||||
|
|
||||||
|
getRowHTML(list, data) {
|
||||||
|
return `<div class="col-3">${list.getNameHTML(data)}</div>
|
||||||
|
<div class="col-4 text-muted">${data.customer}</div>
|
||||||
|
<div class="col-4 text-muted text-right">${frappejs.format(data.grandTotal, "Currency")}</div>`;
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
||||||
var Invoice_1 = Invoice.layout;
|
var Invoice_1 = Invoice.layout;
|
||||||
var Invoice_2 = Invoice.links;
|
var Invoice_2 = Invoice.links;
|
||||||
|
var Invoice_3 = Invoice.listSettings;
|
||||||
|
|
||||||
var InvoiceItem = {
|
var InvoiceItem = {
|
||||||
name: "InvoiceItem",
|
name: "InvoiceItem",
|
||||||
@ -58304,6 +58442,8 @@ var models$2 = {
|
|||||||
Account: Account,
|
Account: Account,
|
||||||
AccountingLedgerEntry: AccountingLedgerEntry,
|
AccountingLedgerEntry: AccountingLedgerEntry,
|
||||||
Party: Party,
|
Party: Party,
|
||||||
|
Payment: Payment,
|
||||||
|
PaymentFor: PaymentFor,
|
||||||
Item: Item,
|
Item: Item,
|
||||||
Invoice: Invoice,
|
Invoice: Invoice,
|
||||||
InvoiceItem: InvoiceItem,
|
InvoiceItem: InvoiceItem,
|
||||||
@ -58315,7 +58455,7 @@ var models$2 = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
var ToDoList_1 = class ToDoList extends list {
|
var ToDoList_1 = class ToDoList extends list {
|
||||||
getFields() {
|
getFields(list$$1) {
|
||||||
return ['name', 'subject', 'status'];
|
return ['name', 'subject', 'status'];
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -58332,40 +58472,6 @@ var FilterSelectorForm_1 = class FilterSelectorForm extends form {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
var AccountList_1 = class AccountList extends list {
|
|
||||||
getFields() {
|
|
||||||
return ['name', 'account_type'];
|
|
||||||
}
|
|
||||||
getRowHTML(data) {
|
|
||||||
return `<div class="col-11">${this.getNameHTML(data)} (${data.account_type})</div>`;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var AccountForm_1 = class AccountForm extends form {
|
|
||||||
make() {
|
|
||||||
super.make();
|
|
||||||
|
|
||||||
// override controller event
|
|
||||||
this.controls['parent_account'].getFilters = (query) => {
|
|
||||||
return {
|
|
||||||
keywords: ["like", query],
|
|
||||||
name: ["!=", this.doc.name]
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var InvoiceList_1 = class InvoiceList extends list {
|
|
||||||
getFields() {
|
|
||||||
return ['name', 'customer', 'grandTotal', 'submitted'];
|
|
||||||
}
|
|
||||||
getRowHTML(data) {
|
|
||||||
return `<div class="col-3">${this.getNameHTML(data)}</div>
|
|
||||||
<div class="col-4 text-muted">${data.customer}</div>
|
|
||||||
<div class="col-4 text-muted text-right">${frappejs.format(data.grandTotal, "Currency")}</div>`;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var CustomerList_1 = class CustomerList extends list {
|
var CustomerList_1 = class CustomerList extends list {
|
||||||
constructor({doctype, parent, fields, page}) {
|
constructor({doctype, parent, fields, page}) {
|
||||||
super({doctype: 'Party', parent: parent, fields: fields, page: page});
|
super({doctype: 'Party', parent: parent, fields: fields, page: page});
|
||||||
@ -58385,10 +58491,6 @@ var client$2 = {
|
|||||||
frappejs.registerView('List', 'ToDo', ToDoList_1);
|
frappejs.registerView('List', 'ToDo', ToDoList_1);
|
||||||
frappejs.registerView('Form', 'FilterSelector', FilterSelectorForm_1);
|
frappejs.registerView('Form', 'FilterSelector', FilterSelectorForm_1);
|
||||||
|
|
||||||
frappejs.registerView('List', 'Account', AccountList_1);
|
|
||||||
frappejs.registerView('Form', 'Account', AccountForm_1);
|
|
||||||
|
|
||||||
frappejs.registerView('List', 'Invoice', InvoiceList_1);
|
|
||||||
frappejs.registerView('List', 'Customer', CustomerList_1);
|
frappejs.registerView('List', 'Customer', CustomerList_1);
|
||||||
|
|
||||||
frappejs.router.add('report/general-ledger', async (params) => {
|
frappejs.router.add('report/general-ledger', async (params) => {
|
||||||
@ -58412,7 +58514,6 @@ var client$2 = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// start server
|
|
||||||
client.start({
|
client.start({
|
||||||
columns: 3,
|
columns: 3,
|
||||||
server: 'localhost:8000'
|
server: 'localhost:8000'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user