Files
bigcapital/packages/server/src/modules/BankingTransactionsExclude/queries/GetExcludedBankTransactions.ts
2025-06-30 16:30:55 +02:00

68 lines
2.1 KiB
TypeScript

import { Inject, Injectable } from '@nestjs/common';
import { TransformerInjectable } from '@/modules/Transformer/TransformerInjectable.service';
import { ExcludedBankTransactionsQuery } from '../types/BankTransactionsExclude.types';
import { UncategorizedBankTransaction } from '@/modules/BankingTransactions/models/UncategorizedBankTransaction';
import { TenantModelProxy } from '@/modules/System/models/TenantBaseModel';
import { ExcludedBankTransactionTransformer } from './ExcludedBankTransaction.transformer';
@Injectable()
export class GetExcludedBankTransactionsService {
/**
* @param {TransformerInjectable} transformer
* @param {TenantModelProxy<typeof UncategorizedBankTransaction>} uncategorizedBankTransaction
*/
constructor(
private readonly transformer: TransformerInjectable,
@Inject(UncategorizedBankTransaction.name)
private readonly uncategorizedBankTransaction: TenantModelProxy<
typeof UncategorizedBankTransaction
>,
) {}
/**
* Retrieves the excluded uncategorized bank transactions.
* @param {ExcludedBankTransactionsQuery} filter
* @returns
*/
public async getExcludedBankTransactions(
filter: ExcludedBankTransactionsQuery,
) {
// Parsed query with default values.
const _query = {
page: 1,
pageSize: 20,
...filter,
};
const { results, pagination } = await this.uncategorizedBankTransaction()
.query()
.onBuild((q) => {
q.modify('excluded');
q.orderBy('date', 'DESC');
if (_query.accountId) {
q.where('account_id', _query.accountId);
}
if (_query.minDate) {
q.modify('fromDate', _query.minDate);
}
if (_query.maxDate) {
q.modify('toDate', _query.maxDate);
}
if (_query.minAmount) {
q.modify('minAmount', _query.minAmount);
}
if (_query.maxAmount) {
q.modify('maxAmount', _query.maxAmount);
}
})
.pagination(_query.page - 1, _query.pageSize);
const data = await this.transformer.transform(
results,
new ExcludedBankTransactionTransformer(),
);
return { data, pagination };
}
}