mirror of
https://github.com/frappe/books.git
synced 2025-01-11 10:38:14 +00:00
Merge pull request #375 from 4silvertooth/master
fix: #176 erroneous Profit ans Loss reports
This commit is contained in:
commit
54628bb2d1
@ -1,6 +1,6 @@
|
|||||||
import frappe from 'frappe';
|
import frappe from 'frappe';
|
||||||
import { DateTime } from 'luxon';
|
import { DateTime } from 'luxon';
|
||||||
import { getPeriodList } from '../FinancialStatements/FinancialStatements';
|
import { getPeriodList, getFiscalYear } from '../FinancialStatements/FinancialStatements';
|
||||||
|
|
||||||
class Cashflow {
|
class Cashflow {
|
||||||
async run({ fromDate, toDate, periodicity }) {
|
async run({ fromDate, toDate, periodicity }) {
|
||||||
@ -24,7 +24,8 @@ class Cashflow {
|
|||||||
.whereBetween('date', [fromDate, toDate])
|
.whereBetween('date', [fromDate, toDate])
|
||||||
.groupBy(dateAsMonthYear);
|
.groupBy(dateAsMonthYear);
|
||||||
|
|
||||||
let periodList = getPeriodList(fromDate, toDate, periodicity);
|
let fiscalYear = await getFiscalYear();
|
||||||
|
let periodList = getPeriodList(fromDate, toDate, periodicity, fiscalYear);
|
||||||
|
|
||||||
let data = periodList.map((periodKey) => {
|
let data = periodList.map((periodKey) => {
|
||||||
let monthYear = this.getMonthYear(periodKey, 'MMM yyyy');
|
let monthYear = this.getMonthYear(periodKey, 'MMM yyyy');
|
||||||
|
@ -21,7 +21,7 @@ export async function getData({
|
|||||||
);
|
);
|
||||||
|
|
||||||
for (let entry of entries) {
|
for (let entry of entries) {
|
||||||
let periodKey = getPeriodKey(entry.date, periodicity);
|
let periodKey = getPeriodKey(entry.date, periodicity, fiscalYear);
|
||||||
|
|
||||||
if (!account[periodKey]) {
|
if (!account[periodKey]) {
|
||||||
account[periodKey] = frappe.pesa(0.0);
|
account[periodKey] = frappe.pesa(0.0);
|
||||||
@ -167,44 +167,47 @@ export function getPeriodList(fromDate, toDate, periodicity, fiscalYear) {
|
|||||||
let out = [];
|
let out = [];
|
||||||
|
|
||||||
while (curDate <= endDate) {
|
while (curDate <= endDate) {
|
||||||
out.push(getPeriodKey(curDate, periodicity));
|
out.push(getPeriodKey(curDate, periodicity, fiscalYear));
|
||||||
curDate = curDate.plus({ months: monthsToAdd });
|
curDate = curDate.plus({ months: monthsToAdd });
|
||||||
}
|
}
|
||||||
|
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getPeriodKey(date, periodicity) {
|
function getPeriodKey(date, periodicity, fiscalYear) {
|
||||||
let key;
|
let key;
|
||||||
|
let { start, end, quarters, isSplit } = fiscalYear;
|
||||||
let dateObj = DateTime.fromISO(date);
|
let dateObj = DateTime.fromISO(date);
|
||||||
let year = dateObj.year;
|
let { month, quarter, year } = dateObj;
|
||||||
let quarter = dateObj.quarter;
|
let fisacalStart = DateTime.fromISO(start);
|
||||||
let month = dateObj.month;
|
let fisacalEnd = DateTime.fromISO(end);
|
||||||
|
|
||||||
let getKey = {
|
let getKey = {
|
||||||
Monthly: () => `${dateObj.monthShort} ${year}`,
|
Monthly: () => `${dateObj.monthShort} ${year}`,
|
||||||
Quarterly: () => {
|
Quarterly: () => {
|
||||||
|
const key = month < fisacalStart.month ? `${year-1} - ${year}` : `${year} - ${year+1}`;
|
||||||
|
let strYear = isSplit ? key : `${year}`;
|
||||||
return {
|
return {
|
||||||
1: `Jan ${year} - Mar ${year}`,
|
1: `Q1 ${strYear}`,
|
||||||
2: `Apr ${year} - Jun ${year}`,
|
2: `Q2 ${strYear}`,
|
||||||
3: `Jun ${year} - Sep ${year}`,
|
3: `Q3 ${strYear}`,
|
||||||
4: `Oct ${year} - Dec ${year}`,
|
4: `Q4 ${strYear}`,
|
||||||
}[quarter];
|
}[quarters[month-1]];
|
||||||
},
|
},
|
||||||
'Half Yearly': () => {
|
'Half Yearly': () => {
|
||||||
if (month > 3) {
|
const key = month < fisacalStart.month ? `${year-1} - ${year}` : `${year} - ${year+1}`;
|
||||||
|
let strYear = isSplit ? key : `${year}`;
|
||||||
return {
|
return {
|
||||||
1: `Apr ${year} - Sep ${year}`,
|
1: `1st Half ${strYear}`,
|
||||||
2: `Oct ${year} - Mar ${year + 1}`,
|
2: `1st Half ${strYear}`,
|
||||||
}[[2, 3].includes(quarter) ? 1 : 2];
|
3: `2nd Half ${strYear}`,
|
||||||
}
|
4: `2nd Half ${strYear}`,
|
||||||
return `Oct ${year - 1} - Mar ${year}`;
|
}[quarters[month-1]];
|
||||||
},
|
},
|
||||||
Yearly: () => {
|
Yearly: () => {
|
||||||
if (month > 3) {
|
const key = month < fisacalStart.month ? `${year-1} - ${year}` : `${year} - ${year+1}`;
|
||||||
return `${year} - ${year + 1}`;
|
let strYear = isSplit ? key : `${year}`;
|
||||||
}
|
return `FY ${strYear}`;
|
||||||
return `${year - 1} - ${year}`;
|
|
||||||
},
|
},
|
||||||
}[periodicity];
|
}[periodicity];
|
||||||
|
|
||||||
@ -292,13 +295,26 @@ async function getAccounts(rootType) {
|
|||||||
return accounts;
|
return accounts;
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getFiscalYear() {
|
export async function getFiscalYear() {
|
||||||
let { fiscalYearStart, fiscalYearEnd } = await frappe.getSingle(
|
let { fiscalYearStart, fiscalYearEnd } = await frappe.getSingle(
|
||||||
'AccountingSettings'
|
'AccountingSettings'
|
||||||
);
|
);
|
||||||
|
|
||||||
|
//right now quaters received from luxon lib is fixed to Jan as starting quarter
|
||||||
|
//moving the financial quarters, according to of start of fiscal year month
|
||||||
|
let quarters = [1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4];
|
||||||
|
let start = DateTime.fromISO(fiscalYearStart);
|
||||||
|
quarters.unshift(...quarters.splice(13-start.month, 11));
|
||||||
|
|
||||||
|
//check if fiscal year ends in next year
|
||||||
|
let end = DateTime.fromISO(fiscalYearEnd);
|
||||||
|
let isFiscalSplit = start.year - end.year ;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
start: fiscalYearStart,
|
start: fiscalYearStart,
|
||||||
end: fiscalYearEnd,
|
end: fiscalYearEnd,
|
||||||
|
quarters: quarters,
|
||||||
|
isSplit: isFiscalSplit,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user