refactor: split the services to multiple service classes (#202)

This commit is contained in:
Ahmed Bouhuolia
2023-08-10 20:29:39 +02:00
committed by GitHub
parent ffef627dc3
commit 26c6ca9e36
150 changed files with 7188 additions and 5007 deletions

View File

@@ -1,12 +1,12 @@
import { Service, Inject } from 'typedi';
import events from '@/subscribers/events';
import SalesReceiptService from '@/services/Sales/SalesReceipts';
import { SaleReceiptIncrement } from '@/services/Sales/Receipts/SaleReceiptIncrement';
import { ISaleReceiptCreatedPayload } from '@/interfaces';
@Service()
export default class SaleReceiptAutoSerialSubscriber {
@Inject()
saleReceiptsService: SalesReceiptService;
private saleReceiptsService: SaleReceiptIncrement;
/**
*

View File

@@ -1,13 +1,13 @@
import { Inject, Service } from 'typedi';
import events from '@/subscribers/events';
import SaleReceiptNotifyBySms from '@/services/Sales/SaleReceiptNotifyBySms';
import { SaleReceiptNotifyBySms } from '@/services/Sales/Receipts/SaleReceiptNotifyBySms';
import { ISaleReceiptCreatedPayload } from '@/interfaces';
import { runAfterTransaction } from '@/services/UnitOfWork/TransactionsHooks';
@Service()
export default class SendSmsNotificationSaleReceipt {
@Inject()
saleReceiptNotifyBySms: SaleReceiptNotifyBySms;
private saleReceiptNotifyBySms: SaleReceiptNotifyBySms;
/**
* Attaches events with handlers.

View File

@@ -1,26 +1,22 @@
import { Inject } from 'typedi';
import { EventSubscriber } from 'event-dispatch';
import events from '@/subscribers/events';
import TenancyService from '@/services/Tenancy/TenancyService';
import SalesReceiptService from '@/services/Sales/SalesReceipts';
import {
ISaleReceiptCreatedPayload,
ISaleReceiptEditedPayload,
ISaleReceiptEventDeletedPayload,
} from '@/interfaces';
import { SaleReceiptInventoryTransactions } from '@/services/Sales/Receipts/SaleReceiptInventoryTransactions';
@EventSubscriber()
export default class SaleReceiptInventoryTransactionsSubscriber {
@Inject()
tenancy: TenancyService;
@Inject()
saleReceiptsService: SalesReceiptService;
private saleReceiptInventory: SaleReceiptInventoryTransactions;
/**
* Subscribe events to handles.
*/
attach(bus) {
public attach(bus) {
bus.subscribe(
events.saleReceipt.onCreated,
this.handleWritingInventoryTransactions
@@ -44,7 +40,7 @@ export default class SaleReceiptInventoryTransactionsSubscriber {
saleReceipt,
trx,
}: ISaleReceiptCreatedPayload) => {
await this.saleReceiptsService.recordInventoryTransactions(
await this.saleReceiptInventory.recordInventoryTransactions(
tenantId,
saleReceipt,
false,
@@ -61,7 +57,7 @@ export default class SaleReceiptInventoryTransactionsSubscriber {
saleReceipt,
trx,
}: ISaleReceiptEditedPayload) => {
await this.saleReceiptsService.recordInventoryTransactions(
await this.saleReceiptInventory.recordInventoryTransactions(
tenantId,
saleReceipt,
true,
@@ -78,7 +74,7 @@ export default class SaleReceiptInventoryTransactionsSubscriber {
saleReceiptId,
trx,
}: ISaleReceiptEventDeletedPayload) => {
await this.saleReceiptsService.revertInventoryTransactions(
await this.saleReceiptInventory.revertInventoryTransactions(
tenantId,
saleReceiptId,
trx

View File

@@ -1,21 +1,17 @@
import { Service, Inject } from 'typedi';
import events from '@/subscribers/events';
import TenancyService from '@/services/Tenancy/TenancyService';
import SalesReceiptService from '@/services/Sales/SalesReceipts';
import {
ISaleReceiptCreatedPayload,
ISaleReceiptEditedPayload,
ISaleReceiptEventDeletedPayload,
} from '@/interfaces';
import { SaleReceiptGLEntries } from '@/services/Sales/SaleReceiptGLEntries';
import { SaleReceiptGLEntries } from '@/services/Sales/Receipts/SaleReceiptGLEntries';
@Service()
export default class SaleReceiptWriteGLEntriesSubscriber {
@Inject()
tenancy: TenancyService;
@Inject()
saleReceiptGLEntries: SaleReceiptGLEntries;
private saleReceiptGLEntries: SaleReceiptGLEntries;
/**
* Attaches events with handlers.