2022-02-16 11:49:16 +05:30
|
|
|
import frappe, { t } from 'frappe';
|
2021-12-21 14:51:13 +05:30
|
|
|
import getCommonExportActions from '../commonExporter';
|
2019-11-20 00:44:15 +05:30
|
|
|
|
2022-03-30 16:27:45 +05:30
|
|
|
const title = t`Profit and Loss`;
|
2021-11-04 16:01:26 +05:30
|
|
|
|
2022-03-30 16:27:45 +05:30
|
|
|
const periodicityMap = {
|
|
|
|
Monthly: t`Monthly`,
|
|
|
|
Quarterly: t`Quarterly`,
|
|
|
|
'Half Yearly': t`Half Yearly`,
|
|
|
|
Yearly: t`Yearly`,
|
|
|
|
};
|
2021-11-04 16:01:26 +05:30
|
|
|
export default {
|
2018-10-26 02:27:34 +05:30
|
|
|
title: title,
|
|
|
|
method: 'profit-and-loss',
|
2019-08-20 14:27:27 +05:30
|
|
|
treeView: true,
|
2018-10-26 02:27:34 +05:30
|
|
|
filterFields: [
|
|
|
|
{
|
2019-08-20 14:27:27 +05:30
|
|
|
fieldtype: 'Date',
|
|
|
|
fieldname: 'fromDate',
|
|
|
|
size: 'small',
|
2022-03-30 16:27:45 +05:30
|
|
|
placeholder: t`From Date`,
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`From Date`,
|
2019-11-20 00:44:15 +05:30
|
|
|
required: 1,
|
|
|
|
default: async () => {
|
|
|
|
return (await frappe.getSingle('AccountingSettings')).fiscalYearStart;
|
2021-12-16 16:45:31 +05:30
|
|
|
},
|
2019-08-20 14:27:27 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldtype: 'Date',
|
|
|
|
fieldname: 'toDate',
|
|
|
|
size: 'small',
|
2022-03-30 16:27:45 +05:30
|
|
|
placeholder: t`To Date`,
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`To Date`,
|
2019-11-20 00:44:15 +05:30
|
|
|
required: 1,
|
|
|
|
default: async () => {
|
|
|
|
return (await frappe.getSingle('AccountingSettings')).fiscalYearEnd;
|
2021-12-16 16:45:31 +05:30
|
|
|
},
|
2019-08-20 14:27:27 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldtype: 'Select',
|
|
|
|
size: 'small',
|
2022-03-30 16:27:45 +05:30
|
|
|
options: Object.keys(periodicityMap),
|
|
|
|
map: periodicityMap,
|
2019-11-20 00:44:15 +05:30
|
|
|
default: 'Monthly',
|
2022-02-16 11:49:16 +05:30
|
|
|
label: t`Periodicity`,
|
2022-03-30 16:27:45 +05:30
|
|
|
placeholder: t`Select Period...`,
|
2021-12-16 16:45:31 +05:30
|
|
|
fieldname: 'periodicity',
|
|
|
|
},
|
2018-10-26 02:27:34 +05:30
|
|
|
],
|
2021-12-21 14:51:13 +05:30
|
|
|
actions: getCommonExportActions('profit-and-loss'),
|
2021-12-29 10:52:31 +05:30
|
|
|
getColumns({ data }) {
|
2018-10-26 02:27:34 +05:30
|
|
|
const columns = [
|
2022-02-16 11:49:16 +05:30
|
|
|
{ label: t`Account`, fieldtype: 'Data', fieldname: 'account', width: 2 },
|
2018-10-26 02:27:34 +05:30
|
|
|
];
|
|
|
|
|
|
|
|
if (data && data.columns) {
|
|
|
|
const currencyColumns = data.columns;
|
2021-12-16 16:45:31 +05:30
|
|
|
const columnDefs = currencyColumns.map((name) => ({
|
2018-10-26 02:27:34 +05:30
|
|
|
label: name,
|
|
|
|
fieldname: name,
|
2021-12-16 16:45:31 +05:30
|
|
|
fieldtype: 'Currency',
|
2022-01-21 02:27:29 +05:30
|
|
|
width: 1,
|
2018-10-26 02:27:34 +05:30
|
|
|
}));
|
|
|
|
|
|
|
|
columns.push(...columnDefs);
|
|
|
|
}
|
|
|
|
|
|
|
|
return columns;
|
2021-12-16 16:45:31 +05:30
|
|
|
},
|
2018-10-26 02:27:34 +05:30
|
|
|
};
|