add: create supplier
This commit is contained in:
parent
d332935e85
commit
14a00988d9
|
@ -25,6 +25,8 @@ export enum coaType {
|
||||||
EXPENSE,
|
EXPENSE,
|
||||||
ACCOUNT_RECEIVABLE,
|
ACCOUNT_RECEIVABLE,
|
||||||
ACCOUNT_PAYABLE,
|
ACCOUNT_PAYABLE,
|
||||||
|
BUDGET,
|
||||||
|
CONTRA_BUDGET,
|
||||||
}
|
}
|
||||||
|
|
||||||
export enum balanceType {
|
export enum balanceType {
|
||||||
|
|
|
@ -18,4 +18,7 @@ export class CreateProductDto {
|
||||||
|
|
||||||
@IsUUID()
|
@IsUUID()
|
||||||
subCategoriesId: string;
|
subCategoriesId: string;
|
||||||
|
|
||||||
|
@IsUUID()
|
||||||
|
supplierId: string;
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ import { Entity, Column, PrimaryGeneratedColumn, ManyToOne } from 'typeorm';
|
||||||
import { Product } from './product.entity';
|
import { Product } from './product.entity';
|
||||||
import { BaseModel } from '../../config/basemodel.entity';
|
import { BaseModel } from '../../config/basemodel.entity';
|
||||||
import { productType } from '../../helper/enum-list';
|
import { productType } from '../../helper/enum-list';
|
||||||
|
import { User } from '../../users/entities/user.entity';
|
||||||
|
|
||||||
@Entity()
|
@Entity()
|
||||||
export class ProductHistoryPrice extends BaseModel {
|
export class ProductHistoryPrice extends BaseModel {
|
||||||
|
@ -11,6 +12,9 @@ export class ProductHistoryPrice extends BaseModel {
|
||||||
@ManyToOne(() => Product, (product) => product.id)
|
@ManyToOne(() => Product, (product) => product.id)
|
||||||
product: Product;
|
product: Product;
|
||||||
|
|
||||||
|
@ManyToOne(() => User, (user) => user.id)
|
||||||
|
user: User;
|
||||||
|
|
||||||
@Column()
|
@Column()
|
||||||
price: number;
|
price: number;
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,7 @@ import {
|
||||||
} from 'typeorm';
|
} from 'typeorm';
|
||||||
import { ProductSubCategories } from './product-sub-category.entity';
|
import { ProductSubCategories } from './product-sub-category.entity';
|
||||||
import { BaseModel } from '../../config/basemodel.entity';
|
import { BaseModel } from '../../config/basemodel.entity';
|
||||||
|
import { Supplier } from '../../users/entities/supplier.entity';
|
||||||
|
|
||||||
@Entity()
|
@Entity()
|
||||||
export class Product extends BaseModel {
|
export class Product extends BaseModel {
|
||||||
|
@ -43,4 +44,14 @@ export class Product extends BaseModel {
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
sub_categories: ProductSubCategories;
|
sub_categories: ProductSubCategories;
|
||||||
|
|
||||||
|
@ManyToOne(
|
||||||
|
() => {
|
||||||
|
return Supplier;
|
||||||
|
},
|
||||||
|
(partner) => {
|
||||||
|
return partner.id;
|
||||||
|
},
|
||||||
|
)
|
||||||
|
supplier: Supplier;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 { EntityNotFoundError, Repository } from 'typeorm';
|
||||||
import { InjectRepository } from '@nestjs/typeorm';
|
import { InjectRepository } from '@nestjs/typeorm';
|
||||||
import { COA } from './entities/coa.entity';
|
import { COA } from './entities/coa.entity';
|
||||||
|
@ -10,24 +16,40 @@ export class CoaService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectRepository(COA)
|
@InjectRepository(COA)
|
||||||
private coaRepository: Repository<COA>,
|
private coaRepository: Repository<COA>,
|
||||||
@Inject(forwardRef(() => UsersService))
|
@Inject(
|
||||||
|
forwardRef(() => {
|
||||||
|
return UsersService;
|
||||||
|
}),
|
||||||
|
)
|
||||||
private userService: UsersService,
|
private userService: UsersService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
async create(inputCoaDto: InputCoaDto) {
|
async create(inputCoaDto: InputCoaDto) {
|
||||||
const user = inputCoaDto.user
|
const coaData = new COA();
|
||||||
let coaData = new COA();
|
let name = '';
|
||||||
coaData.user = user.id;
|
if (inputCoaDto.user) {
|
||||||
coaData.name = coaType[inputCoaDto.type] + '-' + user.username;
|
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.balanceType = inputCoaDto.balanceType;
|
||||||
coaData.type = inputCoaDto.type;
|
coaData.type = inputCoaDto.type;
|
||||||
coaData.amount = 0;
|
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;
|
coaData.relatedUser = inputCoaDto.relatedUserId;
|
||||||
await inputCoaDto.coaEntityManager.save(coaData)
|
await inputCoaDto.coaEntityManager.save(coaData);
|
||||||
}
|
}
|
||||||
|
|
||||||
return coaData;
|
return coaData;
|
||||||
|
@ -35,7 +57,10 @@ export class CoaService {
|
||||||
|
|
||||||
async findByUser(id: string, typeOfCoa: coaType) {
|
async findByUser(id: string, typeOfCoa: coaType) {
|
||||||
try {
|
try {
|
||||||
return await this.coaRepository.findOneOrFail({ user: id, type: typeOfCoa });
|
return await this.coaRepository.findOneOrFail({
|
||||||
|
user: id,
|
||||||
|
type: typeOfCoa,
|
||||||
|
});
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if (e instanceof EntityNotFoundError) {
|
if (e instanceof EntityNotFoundError) {
|
||||||
throw new HttpException(
|
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 {
|
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) {
|
} catch (e) {
|
||||||
if (e instanceof EntityNotFoundError) {
|
if (e instanceof EntityNotFoundError) {
|
||||||
throw new HttpException(
|
throw new HttpException(
|
||||||
|
|
|
@ -2,6 +2,7 @@ import { IsNotEmpty, IsUUID } from 'class-validator';
|
||||||
import { balanceType, coaType } from 'src/helper/enum-list';
|
import { balanceType, coaType } from 'src/helper/enum-list';
|
||||||
import { User } from 'src/users/entities/user.entity';
|
import { User } from 'src/users/entities/user.entity';
|
||||||
import { EntityManager } from 'typeorm';
|
import { EntityManager } from 'typeorm';
|
||||||
|
import { Supplier } from '../../users/entities/supplier.entity';
|
||||||
|
|
||||||
export class InputCoaDto {
|
export class InputCoaDto {
|
||||||
@IsUUID()
|
@IsUUID()
|
||||||
|
@ -16,6 +17,9 @@ export class InputCoaDto {
|
||||||
@IsUUID()
|
@IsUUID()
|
||||||
relatedUserId: string;
|
relatedUserId: string;
|
||||||
|
|
||||||
|
@IsUUID()
|
||||||
|
supplier: Supplier;
|
||||||
|
|
||||||
@IsNotEmpty()
|
@IsNotEmpty()
|
||||||
coaEntityManager: EntityManager;
|
coaEntityManager: EntityManager;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,4 @@
|
||||||
import {
|
import { Entity, Column } from 'typeorm';
|
||||||
Entity,
|
|
||||||
Column,
|
|
||||||
} from 'typeorm';
|
|
||||||
import { BaseModel } from '../../config/basemodel.entity';
|
import { BaseModel } from '../../config/basemodel.entity';
|
||||||
import { coaType, balanceType } from '../../helper/enum-list';
|
import { coaType, balanceType } from '../../helper/enum-list';
|
||||||
|
|
||||||
|
@ -19,11 +16,18 @@ export class COA extends BaseModel {
|
||||||
@Column()
|
@Column()
|
||||||
amount: number;
|
amount: number;
|
||||||
|
|
||||||
@Column()
|
@Column({
|
||||||
|
nullable: true,
|
||||||
|
})
|
||||||
user: string;
|
user: string;
|
||||||
|
|
||||||
@Column({
|
@Column({
|
||||||
nullable:true
|
nullable: true,
|
||||||
})
|
})
|
||||||
relatedUser: string;
|
relatedUser: string;
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
nullable: true,
|
||||||
|
})
|
||||||
|
supplier: string;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,6 @@ import {
|
||||||
import { BaseModel } from '../../config/basemodel.entity';
|
import { BaseModel } from '../../config/basemodel.entity';
|
||||||
import { COA } from './coa.entity';
|
import { COA } from './coa.entity';
|
||||||
import { Transactions } from './transactions.entity';
|
import { Transactions } from './transactions.entity';
|
||||||
import { TransactionType } from './transaction-type.entity';
|
|
||||||
import { balanceType } from '../../helper/enum-list';
|
import { balanceType } from '../../helper/enum-list';
|
||||||
|
|
||||||
@Entity()
|
@Entity()
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
import {
|
|
||||||
Entity,
|
|
||||||
Column,
|
|
||||||
} from 'typeorm';
|
|
||||||
import { BaseModel } from '../../config/basemodel.entity';
|
|
||||||
|
|
||||||
@Entity()
|
|
||||||
export class TransactionType extends BaseModel {
|
|
||||||
@Column()
|
|
||||||
name: string;
|
|
||||||
}
|
|
|
@ -4,7 +4,6 @@ import { TransactionController } from './transaction.controller';
|
||||||
import { PpobCallbackController } from './ppob_callback.controller';
|
import { PpobCallbackController } from './ppob_callback.controller';
|
||||||
import { TypeOrmModule } from '@nestjs/typeorm';
|
import { TypeOrmModule } from '@nestjs/typeorm';
|
||||||
import { COA } from './entities/coa.entity';
|
import { COA } from './entities/coa.entity';
|
||||||
import { TransactionType } from './entities/transaction-type.entity';
|
|
||||||
import { TransactionJournal } from './entities/transaction-journal.entity';
|
import { TransactionJournal } from './entities/transaction-journal.entity';
|
||||||
import { Transactions } from './entities/transactions.entity';
|
import { Transactions } from './entities/transactions.entity';
|
||||||
import { CoaService } from './coa.service';
|
import { CoaService } from './coa.service';
|
||||||
|
@ -13,17 +12,12 @@ import { UsersModule } from 'src/users/users.module';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
TypeOrmModule.forFeature([
|
TypeOrmModule.forFeature([COA, TransactionJournal, Transactions]),
|
||||||
TransactionType,
|
|
||||||
COA,
|
|
||||||
TransactionJournal,
|
|
||||||
Transactions,
|
|
||||||
]),
|
|
||||||
ProductModule,
|
ProductModule,
|
||||||
forwardRef(() => UsersModule),
|
forwardRef(() => UsersModule),
|
||||||
],
|
],
|
||||||
controllers: [TransactionController, PpobCallbackController],
|
controllers: [TransactionController, PpobCallbackController],
|
||||||
providers: [TransactionService, CoaService],
|
providers: [TransactionService, CoaService],
|
||||||
exports:[CoaService]
|
exports: [CoaService],
|
||||||
})
|
})
|
||||||
export class TransactionModule {}
|
export class TransactionModule {}
|
||||||
|
|
|
@ -5,7 +5,6 @@ import { InjectRepository } from '@nestjs/typeorm';
|
||||||
import { Transactions } from './entities/transactions.entity';
|
import { Transactions } from './entities/transactions.entity';
|
||||||
import { Connection, EntityManager, Repository } from 'typeorm';
|
import { Connection, EntityManager, Repository } from 'typeorm';
|
||||||
import { COA } from './entities/coa.entity';
|
import { COA } from './entities/coa.entity';
|
||||||
import { TransactionType } from './entities/transaction-type.entity';
|
|
||||||
import { TransactionJournal } from './entities/transaction-journal.entity';
|
import { TransactionJournal } from './entities/transaction-journal.entity';
|
||||||
import { CoaService } from './coa.service';
|
import { CoaService } from './coa.service';
|
||||||
import * as uuid from 'uuid';
|
import * as uuid from 'uuid';
|
||||||
|
@ -34,8 +33,6 @@ export class TransactionService {
|
||||||
constructor(
|
constructor(
|
||||||
@InjectRepository(Transactions)
|
@InjectRepository(Transactions)
|
||||||
private transactionRepository: Repository<Transactions>,
|
private transactionRepository: Repository<Transactions>,
|
||||||
@InjectRepository(TransactionType)
|
|
||||||
private transactionTypeRepository: Repository<TransactionType>,
|
|
||||||
@InjectRepository(TransactionJournal)
|
@InjectRepository(TransactionJournal)
|
||||||
private transactionJournalRepository: Repository<TransactionJournal>,
|
private transactionJournalRepository: Repository<TransactionJournal>,
|
||||||
@InjectRepository(COA)
|
@InjectRepository(COA)
|
||||||
|
|
15
src/users/dto/create-partner.dto.ts
Normal file
15
src/users/dto/create-partner.dto.ts
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
import { IsNotEmpty } from 'class-validator';
|
||||||
|
|
||||||
|
export class CreatePartnerDto {
|
||||||
|
@IsNotEmpty()
|
||||||
|
name: string;
|
||||||
|
|
||||||
|
@IsNotEmpty()
|
||||||
|
address: string;
|
||||||
|
|
||||||
|
@IsNotEmpty()
|
||||||
|
owner: string;
|
||||||
|
|
||||||
|
@IsNotEmpty()
|
||||||
|
npwp: string;
|
||||||
|
}
|
9
src/users/dto/create-supplier.dto.ts
Normal file
9
src/users/dto/create-supplier.dto.ts
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
import { IsNotEmpty } from 'class-validator';
|
||||||
|
|
||||||
|
export class CreateSupplierDto {
|
||||||
|
@IsNotEmpty()
|
||||||
|
name: string;
|
||||||
|
|
||||||
|
@IsNotEmpty()
|
||||||
|
code: string;
|
||||||
|
}
|
|
@ -4,10 +4,16 @@ import { BaseModel } from '../../config/basemodel.entity';
|
||||||
import { hashPassword } from '../../helper/hash_password';
|
import { hashPassword } from '../../helper/hash_password';
|
||||||
|
|
||||||
@Entity()
|
@Entity()
|
||||||
export class User extends BaseModel {
|
export class Supplier extends BaseModel {
|
||||||
@PrimaryGeneratedColumn('uuid')
|
@PrimaryGeneratedColumn('uuid')
|
||||||
id: string;
|
id: string;
|
||||||
|
|
||||||
@Column()
|
@Column()
|
||||||
name: string;
|
name: string;
|
||||||
|
|
||||||
|
@Column()
|
||||||
|
code: string;
|
||||||
|
|
||||||
|
@Column()
|
||||||
|
status: boolean;
|
||||||
}
|
}
|
18
src/users/supplier.service.spec.ts
Normal file
18
src/users/supplier.service.spec.ts
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
import { Test, TestingModule } from '@nestjs/testing';
|
||||||
|
import { SupplierService } from './supplier.service';
|
||||||
|
|
||||||
|
describe('PartnerService', () => {
|
||||||
|
let service: SupplierService;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
const module: TestingModule = await Test.createTestingModule({
|
||||||
|
providers: [SupplierService],
|
||||||
|
}).compile();
|
||||||
|
|
||||||
|
service = module.get<SupplierService>(SupplierService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be defined', () => {
|
||||||
|
expect(service).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
114
src/users/supplier.service.ts
Normal file
114
src/users/supplier.service.ts
Normal file
|
@ -0,0 +1,114 @@
|
||||||
|
import {
|
||||||
|
forwardRef,
|
||||||
|
HttpException,
|
||||||
|
HttpStatus,
|
||||||
|
Inject,
|
||||||
|
Injectable,
|
||||||
|
} from '@nestjs/common';
|
||||||
|
import { InjectRepository } from '@nestjs/typeorm';
|
||||||
|
import { Connection, EntityNotFoundError, Repository } from 'typeorm';
|
||||||
|
import { Supplier } from './entities/supplier.entity';
|
||||||
|
import { InputCoaDto } from '../transaction/dto/input-coa.dto';
|
||||||
|
import { balanceType, coaType } from '../helper/enum-list';
|
||||||
|
import { CreateSupplierDto } from './dto/create-supplier.dto';
|
||||||
|
import { CoaService } from '../transaction/coa.service';
|
||||||
|
import * as uuid from 'uuid';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class SupplierService {
|
||||||
|
constructor(
|
||||||
|
@InjectRepository(Supplier)
|
||||||
|
private supplierRepository: Repository<Supplier>,
|
||||||
|
@Inject(
|
||||||
|
forwardRef(() => {
|
||||||
|
return CoaService;
|
||||||
|
}),
|
||||||
|
)
|
||||||
|
private coaService: CoaService,
|
||||||
|
private connection: Connection,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
async create(createSupplierDto: CreateSupplierDto) {
|
||||||
|
const check = await this.supplierRepository.findOne({
|
||||||
|
code: createSupplierDto.code,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (check) {
|
||||||
|
throw new HttpException(
|
||||||
|
{
|
||||||
|
statusCode: HttpStatus.NOT_ACCEPTABLE,
|
||||||
|
error: 'Supplier Already Exist',
|
||||||
|
},
|
||||||
|
HttpStatus.NOT_FOUND,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
const supplierData = new Supplier();
|
||||||
|
supplierData.id = uuid.v4();
|
||||||
|
supplierData.name = createSupplierDto.name;
|
||||||
|
supplierData.code = createSupplierDto.code;
|
||||||
|
supplierData.status = true;
|
||||||
|
|
||||||
|
await this.connection.transaction(async (manager) => {
|
||||||
|
const result = await manager.insert(Supplier, supplierData);
|
||||||
|
|
||||||
|
const dataCoaInventory = new InputCoaDto();
|
||||||
|
dataCoaInventory.supplier = supplierData;
|
||||||
|
dataCoaInventory.balanceType = balanceType.DEBIT;
|
||||||
|
dataCoaInventory.type = coaType.INVENTORY;
|
||||||
|
dataCoaInventory.coaEntityManager = manager;
|
||||||
|
await this.coaService.create(dataCoaInventory);
|
||||||
|
|
||||||
|
const dataCoaCostOfSales = new InputCoaDto();
|
||||||
|
dataCoaCostOfSales.supplier = supplierData;
|
||||||
|
dataCoaCostOfSales.balanceType = balanceType.DEBIT;
|
||||||
|
dataCoaCostOfSales.type = coaType.COST_OF_SALES;
|
||||||
|
dataCoaCostOfSales.coaEntityManager = manager;
|
||||||
|
await this.coaService.create(dataCoaCostOfSales);
|
||||||
|
|
||||||
|
const dataCoaBudget = new InputCoaDto();
|
||||||
|
dataCoaBudget.supplier = supplierData;
|
||||||
|
dataCoaBudget.balanceType = balanceType.DEBIT;
|
||||||
|
dataCoaBudget.type = coaType.BUDGET;
|
||||||
|
dataCoaBudget.coaEntityManager = manager;
|
||||||
|
await this.coaService.create(dataCoaBudget);
|
||||||
|
|
||||||
|
const dataCoaContraBudget = new InputCoaDto();
|
||||||
|
dataCoaContraBudget.supplier = supplierData;
|
||||||
|
dataCoaContraBudget.balanceType = balanceType.CREDIT;
|
||||||
|
dataCoaContraBudget.type = coaType.CONTRA_BUDGET;
|
||||||
|
dataCoaContraBudget.coaEntityManager = manager;
|
||||||
|
await this.coaService.create(dataCoaContraBudget);
|
||||||
|
});
|
||||||
|
|
||||||
|
return supplierData;
|
||||||
|
}
|
||||||
|
|
||||||
|
findAllSupplier(page) {
|
||||||
|
return this.supplierRepository.findAndCount({
|
||||||
|
skip: page * 10,
|
||||||
|
take: 10,
|
||||||
|
order: {
|
||||||
|
version: 'DESC',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async findOne(id: string) {
|
||||||
|
try {
|
||||||
|
return await this.supplierRepository.findOneOrFail(id);
|
||||||
|
} catch (e) {
|
||||||
|
if (e instanceof EntityNotFoundError) {
|
||||||
|
throw new HttpException(
|
||||||
|
{
|
||||||
|
statusCode: HttpStatus.NOT_FOUND,
|
||||||
|
error: 'Data not found',
|
||||||
|
},
|
||||||
|
HttpStatus.NOT_FOUND,
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -15,13 +15,18 @@ import { UsersService } from './users.service';
|
||||||
import { CreateUserDto } from './dto/create-user.dto';
|
import { CreateUserDto } from './dto/create-user.dto';
|
||||||
import { UpdateUserDto } from './dto/update-user.dto';
|
import { UpdateUserDto } from './dto/update-user.dto';
|
||||||
import { Public } from '../auth/public.decorator';
|
import { Public } from '../auth/public.decorator';
|
||||||
|
import { CreateSupplierDto } from './dto/create-supplier.dto';
|
||||||
|
import { SupplierService } from './supplier.service';
|
||||||
|
|
||||||
@Controller({
|
@Controller({
|
||||||
path: 'users',
|
path: 'users',
|
||||||
version: '1',
|
version: '1',
|
||||||
})
|
})
|
||||||
export class UsersController {
|
export class UsersController {
|
||||||
constructor(private readonly usersService: UsersService) {}
|
constructor(
|
||||||
|
private readonly usersService: UsersService,
|
||||||
|
private readonly supplierService: SupplierService,
|
||||||
|
) {}
|
||||||
|
|
||||||
@Post()
|
@Post()
|
||||||
async create(@Request() req, @Body() createUserDto: CreateUserDto) {
|
async create(@Request() req, @Body() createUserDto: CreateUserDto) {
|
||||||
|
@ -32,6 +37,15 @@ export class UsersController {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Post('supplier')
|
||||||
|
async createPartner(@Body() createPartnerDto: CreateSupplierDto) {
|
||||||
|
return {
|
||||||
|
data: await this.supplierService.create(createPartnerDto),
|
||||||
|
statusCode: HttpStatus.CREATED,
|
||||||
|
message: 'success',
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
@Public()
|
@Public()
|
||||||
@Get()
|
@Get()
|
||||||
async findAll(@Query('page') page: number) {
|
async findAll(@Query('page') page: number) {
|
||||||
|
|
|
@ -5,11 +5,17 @@ import { UsersController } from './users.controller';
|
||||||
import { User } from './entities/user.entity';
|
import { User } from './entities/user.entity';
|
||||||
import { TransactionModule } from 'src/transaction/transaction.module';
|
import { TransactionModule } from 'src/transaction/transaction.module';
|
||||||
import { ConfigurableModule } from 'src/configurable/configurable.module';
|
import { ConfigurableModule } from 'src/configurable/configurable.module';
|
||||||
|
import { SupplierService } from './supplier.service';
|
||||||
|
import { Supplier } from './entities/supplier.entity';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [TypeOrmModule.forFeature([User]), forwardRef(() => TransactionModule), ConfigurableModule],
|
imports: [
|
||||||
|
TypeOrmModule.forFeature([User, Supplier]),
|
||||||
|
forwardRef(() => TransactionModule),
|
||||||
|
ConfigurableModule,
|
||||||
|
],
|
||||||
controllers: [UsersController],
|
controllers: [UsersController],
|
||||||
providers: [UsersService],
|
providers: [UsersService, SupplierService],
|
||||||
exports: [UsersService],
|
exports: [UsersService],
|
||||||
})
|
})
|
||||||
export class UsersModule {}
|
export class UsersModule {}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user