2022-04-21 18:38:36 +05:30
|
|
|
import { Fyo } from 'fyo';
|
2022-04-19 11:29:36 +05:30
|
|
|
import { unique } from 'fyo/utils';
|
2022-04-21 18:38:36 +05:30
|
|
|
import { FinancialStatements } from 'reports/FinancialStatements/financialStatements';
|
|
|
|
import { FinancialStatementOptions } from 'reports/types';
|
2018-04-24 13:28:57 +05:30
|
|
|
|
|
|
|
class BalanceSheet {
|
2022-04-21 18:38:36 +05:30
|
|
|
async run(options: FinancialStatementOptions, fyo: Fyo) {
|
|
|
|
const { fromDate, toDate, periodicity } = options;
|
|
|
|
const fs = new FinancialStatements(fyo);
|
|
|
|
const asset = await fs.getData({
|
2022-01-21 02:27:29 +05:30
|
|
|
rootType: 'Asset',
|
|
|
|
balanceMustBe: 'Debit',
|
|
|
|
fromDate,
|
|
|
|
toDate,
|
|
|
|
periodicity,
|
|
|
|
accumulateValues: true,
|
|
|
|
});
|
|
|
|
|
2022-04-21 18:38:36 +05:30
|
|
|
const liability = await fs.getData({
|
2022-01-21 02:27:29 +05:30
|
|
|
rootType: 'Liability',
|
|
|
|
balanceMustBe: 'Credit',
|
|
|
|
fromDate,
|
|
|
|
toDate,
|
|
|
|
periodicity,
|
|
|
|
accumulateValues: true,
|
|
|
|
});
|
|
|
|
|
2022-04-21 18:38:36 +05:30
|
|
|
const equity = await fs.getData({
|
2022-01-21 02:27:29 +05:30
|
|
|
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 };
|
|
|
|
}
|
2018-04-24 13:28:57 +05:30
|
|
|
}
|
|
|
|
|
2021-11-04 16:01:26 +05:30
|
|
|
export default BalanceSheet;
|