2019-12-04 22:53:28 +05:30
|
|
|
const { getPeriodList } = require('../FinancialStatements/FinancialStatements');
|
2019-11-22 23:13:32 +05:30
|
|
|
const { DateTime } = require('luxon');
|
|
|
|
|
|
|
|
class Cashflow {
|
|
|
|
async run({ fromDate, toDate, periodicity }) {
|
2019-12-10 01:50:32 +05:30
|
|
|
let cashAndBankAccounts = frappe.db
|
|
|
|
.knex('Account')
|
|
|
|
.select('name')
|
|
|
|
.where('accountType', 'in', ['Cash', 'Bank'])
|
|
|
|
.andWhere('isGroup', 0);
|
|
|
|
let dateAsMonthYear = frappe.db.knex.raw('strftime("%m-%Y", ??)', 'date');
|
|
|
|
let res = await frappe.db
|
|
|
|
.knex('AccountingLedgerEntry')
|
|
|
|
.sum({
|
|
|
|
inflow: 'debit',
|
|
|
|
outflow: 'credit'
|
|
|
|
})
|
|
|
|
.select({
|
|
|
|
'month-year': dateAsMonthYear
|
|
|
|
})
|
|
|
|
.where('account', 'in', cashAndBankAccounts)
|
|
|
|
.whereBetween('date', [fromDate, toDate])
|
|
|
|
.groupBy(dateAsMonthYear);
|
2019-11-22 23:13:32 +05:30
|
|
|
|
2019-12-04 22:53:28 +05:30
|
|
|
let periodList = getPeriodList(fromDate, toDate, periodicity);
|
2019-11-22 23:13:32 +05:30
|
|
|
|
|
|
|
let data = periodList.map(periodKey => {
|
|
|
|
let monthYear = this.getMonthYear(periodKey, 'MMM yyyy');
|
2019-12-04 22:53:28 +05:30
|
|
|
let cashflowForPeriod = res.find(d => d['month-year'] === monthYear);
|
2019-11-22 23:13:32 +05:30
|
|
|
if (cashflowForPeriod) {
|
|
|
|
cashflowForPeriod.periodKey = periodKey;
|
|
|
|
return cashflowForPeriod;
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
inflow: 0,
|
|
|
|
outflow: 0,
|
|
|
|
periodKey,
|
|
|
|
'month-year': monthYear
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
return {
|
|
|
|
data,
|
|
|
|
periodList
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
getMonthYear(periodKey, format) {
|
|
|
|
return DateTime.fromFormat(periodKey, format).toFormat('MM-yyyy');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = Cashflow;
|