mirror of
https://github.com/frappe/books.git
synced 2025-01-23 15:18:24 +00:00
17e5187c51
- Models - Bill - Quotation (extended from Invoice) - Journal Entry - Reports - Sales Register - Purchase Register
52 lines
1.3 KiB
JavaScript
52 lines
1.3 KiB
JavaScript
const frappe = require('frappejs');
|
|
const { unique } = require('frappejs/utils');
|
|
const { getData } = require('../FinancialStatements/FinancialStatements');
|
|
|
|
class BalanceSheet {
|
|
async run({ fromDate, toDate, periodicity }) {
|
|
|
|
let asset = await getData({
|
|
rootType: 'Asset',
|
|
balanceMustBe: 'Debit',
|
|
fromDate,
|
|
toDate,
|
|
periodicity,
|
|
accumulateValues: true
|
|
});
|
|
|
|
let liability = await getData({
|
|
rootType: 'Liability',
|
|
balanceMustBe: 'Credit',
|
|
fromDate,
|
|
toDate,
|
|
periodicity,
|
|
accumulateValues: true
|
|
});
|
|
|
|
let equity = await getData({
|
|
rootType: 'Equity',
|
|
balanceMustBe: 'Credit',
|
|
fromDate,
|
|
toDate,
|
|
periodicity,
|
|
accumulateValues: true
|
|
});
|
|
|
|
const rows = [
|
|
...asset.accounts, asset.totalRow, [],
|
|
...liability.accounts, liability.totalRow, [],
|
|
...equity.accounts, equity.totalRow, []
|
|
];
|
|
|
|
const columns = unique([
|
|
...asset.periodList,
|
|
...liability.periodList,
|
|
...equity.periodList
|
|
]);
|
|
|
|
return { rows, columns };
|
|
}
|
|
}
|
|
|
|
module.exports = BalanceSheet;
|