mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-16 12:50:38 +00:00
162 lines
4.4 KiB
TypeScript
162 lines
4.4 KiB
TypeScript
import { Service, Inject } from 'typedi';
|
|
import * as R from 'ramda';
|
|
import {
|
|
IManualJournal,
|
|
IManualJournalEntry,
|
|
ILedgerEntry,
|
|
} from '@/interfaces';
|
|
import { Knex } from 'knex';
|
|
import Ledger from '@/services/Accounting/Ledger';
|
|
import LedgerStorageService from '@/services/Accounting/LedgerStorageService';
|
|
import HasTenancyService from '@/services/Tenancy/TenancyService';
|
|
|
|
@Service()
|
|
export class ManualJournalGLEntries {
|
|
@Inject()
|
|
private ledgerStorage: LedgerStorageService;
|
|
|
|
@Inject()
|
|
private tenancy: HasTenancyService;
|
|
|
|
/**
|
|
* Create manual journal GL entries.
|
|
* @param {number} tenantId
|
|
* @param {number} manualJournalId
|
|
* @param {Knex.Transaction} trx
|
|
*/
|
|
public createManualJournalGLEntries = async (
|
|
tenantId: number,
|
|
manualJournalId: number,
|
|
trx?: Knex.Transaction
|
|
) => {
|
|
const { ManualJournal } = this.tenancy.models(tenantId);
|
|
|
|
// Retrieves the given manual journal with associated entries.
|
|
const manualJournal = await ManualJournal.query(trx)
|
|
.findById(manualJournalId)
|
|
.withGraphFetched('entries.account');
|
|
|
|
// Retrieves the ledger entries of the given manual journal.
|
|
const ledger = this.getManualJournalGLedger(manualJournal);
|
|
|
|
// Commits the given ledger on the storage.
|
|
await this.ledgerStorage.commit(tenantId, ledger, trx);
|
|
};
|
|
|
|
/**
|
|
* Edits manual journal GL entries.
|
|
* @param {number} tenantId
|
|
* @param {number} manualJournalId
|
|
* @param {Knex.Transaction} trx
|
|
*/
|
|
public editManualJournalGLEntries = async (
|
|
tenantId: number,
|
|
manualJournalId: number,
|
|
trx?: Knex.Transaction
|
|
) => {
|
|
// Reverts the manual journal GL entries.
|
|
await this.revertManualJournalGLEntries(tenantId, manualJournalId, trx);
|
|
|
|
// Write the manual journal GL entries.
|
|
await this.createManualJournalGLEntries(tenantId, manualJournalId, trx);
|
|
};
|
|
|
|
/**
|
|
* Deletes the manual journal GL entries.
|
|
* @param {number} tenantId
|
|
* @param {number} manualJournalId
|
|
* @param {Knex.Transaction} trx
|
|
*/
|
|
public revertManualJournalGLEntries = async (
|
|
tenantId: number,
|
|
manualJournalId: number,
|
|
trx?: Knex.Transaction
|
|
): Promise<void> => {
|
|
return this.ledgerStorage.deleteByReference(
|
|
tenantId,
|
|
manualJournalId,
|
|
'Journal',
|
|
trx
|
|
);
|
|
};
|
|
|
|
/**
|
|
* Retrieves the ledger of the given manual journal.
|
|
* @param {IManualJournal} manualJournal
|
|
* @returns {Ledger}
|
|
*/
|
|
private getManualJournalGLedger = (manualJournal: IManualJournal) => {
|
|
const entries = this.getManualJournalGLEntries(manualJournal);
|
|
|
|
return new Ledger(entries);
|
|
};
|
|
|
|
/**
|
|
* Retrieves the common entry details of the manual journal
|
|
* @param {IManualJournal} manualJournal
|
|
* @returns {Partial<ILedgerEntry>}
|
|
*/
|
|
private getManualJournalCommonEntry = (
|
|
manualJournal: IManualJournal
|
|
): Partial<ILedgerEntry> => {
|
|
return {
|
|
transactionNumber: manualJournal.journalNumber,
|
|
referenceNumber: manualJournal.reference,
|
|
createdAt: manualJournal.createdAt,
|
|
date: manualJournal.date,
|
|
currencyCode: manualJournal.currencyCode,
|
|
exchangeRate: manualJournal.exchangeRate,
|
|
|
|
transactionType: 'Journal',
|
|
transactionId: manualJournal.id,
|
|
|
|
userId: manualJournal.userId,
|
|
};
|
|
};
|
|
|
|
/**
|
|
* Retrieves the ledger entry of the given manual journal and
|
|
* its associated entry.
|
|
* @param {IManualJournal} manualJournal -
|
|
* @param {IManualJournalEntry} entry -
|
|
* @returns {ILedgerEntry}
|
|
*/
|
|
private getManualJournalEntry = R.curry(
|
|
(
|
|
manualJournal: IManualJournal,
|
|
entry: IManualJournalEntry
|
|
): ILedgerEntry => {
|
|
const commonEntry = this.getManualJournalCommonEntry(manualJournal);
|
|
|
|
return {
|
|
...commonEntry,
|
|
debit: entry.debit,
|
|
credit: entry.credit,
|
|
accountId: entry.accountId,
|
|
|
|
contactId: entry.contactId,
|
|
note: entry.note,
|
|
|
|
index: entry.index,
|
|
accountNormal: entry.account.accountNormal,
|
|
|
|
branchId: entry.branchId,
|
|
projectId: entry.projectId,
|
|
};
|
|
}
|
|
);
|
|
|
|
/**
|
|
* Retrieves the ledger of the given manual journal.
|
|
* @param {IManualJournal} manualJournal
|
|
* @returns {ILedgerEntry[]}
|
|
*/
|
|
private getManualJournalGLEntries = (
|
|
manualJournal: IManualJournal
|
|
): ILedgerEntry[] => {
|
|
const transformEntry = this.getManualJournalEntry(manualJournal);
|
|
|
|
return manualJournal.entries.map(transformEntry).flat();
|
|
};
|
|
}
|