2
0
mirror of https://github.com/frappe/books.git synced 2025-01-26 08:38:27 +00:00
books/reports/BankReconciliation/BankReconciliationImport.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

90 lines
2.8 KiB
JavaScript
Raw Normal View History

import csv2json from 'csvjson-csv2json';
import { fyo } from 'src/initFyo';
import ReconciliationValidation from '../../src/components/ReconciliationValidation';
2019-09-03 15:13:16 +05:30
export const fileImportHandler = (file, report) => {
const reader = new FileReader();
reader.onload = () => {
const csv = reader.result;
const json = csvToJsonHandler(csv);
findMatchingReferences(json, report);
};
reader.readAsBinaryString(file);
};
export const csvToJsonHandler = (csv) => {
2019-09-03 15:13:16 +05:30
const json = csv2json(csv, { parseNumbers: true });
return json;
};
export const findMatchingReferences = async (json, report) => {
const referenceField = Object.keys(json[0]).filter((field) => {
2019-09-03 15:13:16 +05:30
return field.toLowerCase().indexOf('ref') > -1 ? true : false;
});
const clearanceDateField = Object.keys(json[0]).filter((field) => {
2019-09-03 15:13:16 +05:30
return field.toLowerCase().indexOf('date') > -1 ? true : false;
});
const debitField = Object.keys(json[0]).filter((field) => {
2019-09-03 15:13:16 +05:30
return field.toLowerCase().indexOf('debit') > -1 ||
field.toLowerCase().indexOf('deposit') > -1
? true
: false;
});
const creditField = Object.keys(json[0]).filter((field) => {
2019-09-03 15:13:16 +05:30
return field.toLowerCase().indexOf('credit') > -1 ||
field.toLowerCase().indexOf('withdraw') > -1
? true
: false;
});
const balanceField = Object.keys(json[0]).filter((field) => {
2019-09-03 15:13:16 +05:30
return field.toLowerCase().indexOf('balance') > -1 ? true : false;
});
const references = json.map((row) => {
2019-09-03 15:13:16 +05:30
return row[referenceField];
});
const payments = await fyo.db.getAll({
2019-09-03 15:13:16 +05:30
doctype: 'Payment',
fields: ['*'],
filters: {
referenceId: ['in', references],
paymentAccount: report.currentFilters.paymentAccount,
clearanceDate: ['in', [null, undefined, '']],
},
2019-09-03 15:13:16 +05:30
});
if (payments.length) {
const entries = payments.map((payment) => {
const jsonEntry = json.filter((row) => {
2019-09-03 15:13:16 +05:30
return row[referenceField] === payment.referenceId;
});
return Object.assign(payment, jsonEntry[0]);
});
const normalizedEntries = entries.map((entry) => {
2019-09-03 15:13:16 +05:30
return {
'Posting Date': fyo.format(entry.date, 'Date'),
2019-09-03 15:13:16 +05:30
'Payment Entry': entry.name,
'Ref/Cheq. ID': entry[referenceField],
'Cr/Dr':
fyo.parseNumber(entry[debitField]) > 0
2019-09-03 15:13:16 +05:30
? entry[debitField] + ' Dr.'
: entry[creditField] + ' Cr.',
'Clearance Date': entry[clearanceDateField],
2019-09-03 15:13:16 +05:30
};
});
report.$modal.show({
modalProps: {
title: `Validate Matching Entries`,
noFooter: true,
2019-09-03 15:13:16 +05:30
},
component: ReconciliationValidation,
2019-09-03 15:13:16 +05:30
props: {
entries: normalizedEntries,
afterReconcile: async () => {
await report.getReportData(report.currentFilters);
},
},
2019-09-03 15:13:16 +05:30
});
} else {
2022-03-22 13:51:00 +05:30
// 'No entries found with matching Ref / Cheque ID'
2019-09-03 15:13:16 +05:30
}
};