add: create supplier
This commit is contained in:
@@ -1,4 +1,10 @@
|
||||
import { forwardRef, HttpException, HttpStatus, Inject, Injectable } from '@nestjs/common';
|
||||
import {
|
||||
forwardRef,
|
||||
HttpException,
|
||||
HttpStatus,
|
||||
Inject,
|
||||
Injectable,
|
||||
} from '@nestjs/common';
|
||||
import { EntityNotFoundError, Repository } from 'typeorm';
|
||||
import { InjectRepository } from '@nestjs/typeorm';
|
||||
import { COA } from './entities/coa.entity';
|
||||
@@ -10,24 +16,40 @@ export class CoaService {
|
||||
constructor(
|
||||
@InjectRepository(COA)
|
||||
private coaRepository: Repository<COA>,
|
||||
@Inject(forwardRef(() => UsersService))
|
||||
@Inject(
|
||||
forwardRef(() => {
|
||||
return UsersService;
|
||||
}),
|
||||
)
|
||||
private userService: UsersService,
|
||||
) {}
|
||||
|
||||
async create(inputCoaDto: InputCoaDto) {
|
||||
const user = inputCoaDto.user
|
||||
let coaData = new COA();
|
||||
coaData.user = user.id;
|
||||
coaData.name = coaType[inputCoaDto.type] + '-' + user.username;
|
||||
const coaData = new COA();
|
||||
let name = '';
|
||||
if (inputCoaDto.user) {
|
||||
coaData.user = inputCoaDto.user.id;
|
||||
name = inputCoaDto.user.username;
|
||||
}
|
||||
|
||||
if (inputCoaDto.supplier) {
|
||||
coaData.supplier = inputCoaDto.supplier.id;
|
||||
name = inputCoaDto.supplier.code;
|
||||
}
|
||||
|
||||
coaData.name = `${coaType[inputCoaDto.type]}-${name}`;
|
||||
coaData.balanceType = inputCoaDto.balanceType;
|
||||
coaData.type = inputCoaDto.type;
|
||||
coaData.amount = 0;
|
||||
|
||||
const result = await inputCoaDto.coaEntityManager.insert(COA,coaData);
|
||||
const result = await inputCoaDto.coaEntityManager.insert(COA, coaData);
|
||||
|
||||
if(inputCoaDto.type == coaType.ACCOUNT_RECEIVABLE || inputCoaDto.type == coaType.ACCOUNT_PAYABLE){
|
||||
if (
|
||||
inputCoaDto.type == coaType.ACCOUNT_RECEIVABLE ||
|
||||
inputCoaDto.type == coaType.ACCOUNT_PAYABLE
|
||||
) {
|
||||
coaData.relatedUser = inputCoaDto.relatedUserId;
|
||||
await inputCoaDto.coaEntityManager.save(coaData)
|
||||
await inputCoaDto.coaEntityManager.save(coaData);
|
||||
}
|
||||
|
||||
return coaData;
|
||||
@@ -35,7 +57,10 @@ export class CoaService {
|
||||
|
||||
async findByUser(id: string, typeOfCoa: coaType) {
|
||||
try {
|
||||
return await this.coaRepository.findOneOrFail({ user: id, type: typeOfCoa });
|
||||
return await this.coaRepository.findOneOrFail({
|
||||
user: id,
|
||||
type: typeOfCoa,
|
||||
});
|
||||
} catch (e) {
|
||||
if (e instanceof EntityNotFoundError) {
|
||||
throw new HttpException(
|
||||
@@ -51,9 +76,17 @@ export class CoaService {
|
||||
}
|
||||
}
|
||||
|
||||
async findByUserWithRelated(id: string, relatedId: string, typeOfCoa: coaType) {
|
||||
async findByUserWithRelated(
|
||||
id: string,
|
||||
relatedId: string,
|
||||
typeOfCoa: coaType,
|
||||
) {
|
||||
try {
|
||||
return await this.coaRepository.findOneOrFail({ user: id, type: typeOfCoa, relatedUser:relatedId });
|
||||
return await this.coaRepository.findOneOrFail({
|
||||
user: id,
|
||||
type: typeOfCoa,
|
||||
relatedUser: relatedId,
|
||||
});
|
||||
} catch (e) {
|
||||
if (e instanceof EntityNotFoundError) {
|
||||
throw new HttpException(
|
||||
|
||||
Reference in New Issue
Block a user