@accounter/server
Version:
50 lines (44 loc) • 1.63 kB
text/typescript
import DataLoader from 'dataloader';
import { Injectable, Scope } from 'graphql-modules';
import { DBProvider } from '@modules/app-providers/db.provider.js';
import { sql } from '@pgtyped/runtime';
import type { IGetBalanceCancellationByChargesIdsQuery } from '../types.js';
export type ChargeRequiredWrapper<
T extends {
id: unknown;
owner_id: unknown;
is_conversion: unknown;
is_property: unknown;
accountant_reviewed: unknown;
},
> = Omit<T, 'id' | 'owner_id' | 'is_conversion' | 'is_property' | 'accountant_reviewed'> & {
id: NonNullable<T['id']>;
owner_id: NonNullable<T['owner_id']>;
is_conversion: NonNullable<T['is_conversion']>;
is_property: NonNullable<T['is_property']>;
accountant_reviewed: NonNullable<T['accountant_reviewed']>;
};
const getBalanceCancellationByChargesIds = sql<IGetBalanceCancellationByChargesIdsQuery>`
SELECT *
FROM accounter_schema.charge_balance_cancellation
WHERE charge_id IN $$chargeIds;`;
({
scope: Scope.Singleton,
global: true,
})
export class BalanceCancellationProvider {
constructor(private dbProvider: DBProvider) {}
private async batchBalanceCancellationByChargesIds(ids: readonly string[]) {
const ballanceCancellations = await getBalanceCancellationByChargesIds.run(
{
chargeIds: ids,
},
this.dbProvider,
);
return ids.map(id => ballanceCancellations.filter(record => record.charge_id === id));
}
public getBalanceCancellationByChargesIdLoader = new DataLoader(
(keys: readonly string[]) => this.batchBalanceCancellationByChargesIds(keys),
{ cache: false },
);
}