2
0
mirror of https://github.com/frappe/books.git synced 2025-01-09 17:53:56 +00:00
books/reports/GeneralLedger/GeneralLedger.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

98 lines
2.3 KiB
JavaScript
Raw Normal View History

import { fyo } from 'src/initFyo';
2018-03-26 12:14:27 +00:00
2018-03-27 13:52:59 +00:00
class GeneralLedger {
2018-07-14 14:28:41 +00:00
async run(params) {
const filters = {};
if (params.account) filters.account = params.account;
if (params.party) filters.party = params.party;
if (params.referenceType !== 'All')
filters.referenceType = params.referenceType;
2018-07-14 14:28:41 +00:00
if (params.referenceName) filters.referenceName = params.referenceName;
if (params.toDate || params.fromDate) {
filters.date = [];
if (params.toDate) filters.date.push('<=', params.toDate);
if (params.fromDate) filters.date.push('>=', params.fromDate);
}
let data = (
await fyo.db.getAll({
doctype: 'AccountingLedgerEntry',
fields: [
'date',
'account',
'party',
'referenceType',
'referenceName',
'debit',
'credit',
'reverted',
],
filters: filters,
})
)
.filter((d) => !d.reverted || (d.reverted && params.reverted))
.map((row) => {
row.debit = row.debit.float;
row.credit = row.credit.float;
return row;
});
2018-03-26 12:14:27 +00:00
2019-07-18 06:49:12 +00:00
return this.appendOpeningEntry(data);
}
2019-07-18 06:49:12 +00:00
appendOpeningEntry(data) {
let glEntries = [];
let balance = 0,
debitTotal = 0,
creditTotal = 0;
glEntries.push({
date: '',
account: { template: '<b>Opening</b>' },
2019-07-18 06:49:12 +00:00
party: '',
debit: 0,
credit: 0,
balance: 0,
referenceType: '',
referenceName: '',
2019-07-18 06:49:12 +00:00
});
for (let entry of data) {
balance += entry.debit > 0 ? entry.debit : -entry.credit;
debitTotal += entry.debit;
creditTotal += entry.credit;
entry.balance = balance;
if (entry.debit === 0) {
entry.debit = '';
}
if (entry.credit === 0) {
entry.credit = '';
}
2019-07-18 06:49:12 +00:00
glEntries.push(entry);
}
glEntries.push({
date: '',
account: { template: '<b>Total</b>' },
2019-07-18 06:49:12 +00:00
party: '',
debit: debitTotal,
credit: creditTotal,
balance: balance,
referenceType: '',
referenceName: '',
2019-07-18 06:49:12 +00:00
});
glEntries.push({
date: '',
account: { template: '<b>Closing</b>' },
2019-07-18 06:49:12 +00:00
party: '',
debit: debitTotal,
credit: creditTotal,
balance: balance,
referenceType: '',
referenceName: '',
2019-07-18 06:49:12 +00:00
});
return glEntries;
2018-07-14 14:28:41 +00:00
}
2018-04-18 09:02:05 +00:00
}
export default GeneralLedger;