File

packages/server/src/modules/productCategory/category.service.ts

Index

Methods

Constructor

constructor(repo: Repository, request)
Parameters :
Name Type Optional
repo Repository<ProductCategoryEntity> No
request No

Methods

Async all
all(query: ProductCategoryQuery, user?: ActiveUserData)
Parameters :
Name Type Optional
query ProductCategoryQuery No
user ActiveUserData Yes
Returns : Promise<literal type>
Async create
create(body: ProductCategoryRequest, user?: ActiveUserData)
Parameters :
Name Type Optional
body ProductCategoryRequest No
user ActiveUserData Yes
Returns : Promise<ProductCategoryEntity>
Async getById
getById(id?: number)
Parameters :
Name Type Optional
id number Yes
Returns : Promise<ProductCategoryEntity | null>
Async getByIdWithError
getByIdWithError(id?: number)
Parameters :
Name Type Optional
id number Yes
Returns : Promise<ProductCategoryEntity>
Async remove
remove(id: number)
Parameters :
Name Type Optional
id number No
Returns : unknown
Async update
update(id: number, body: ProductCategoryRequest)
Parameters :
Name Type Optional
id number No
body ProductCategoryRequest No
Returns : Promise<ProductCategoryEntity>
import { EntityManager, ILike, Like, Repository } from "typeorm";
import { ApiStatusCode } from "@bill/database";
import { ProductCategoryEntity, UserEntity } from "@bill/database/dist/entities";
import { HttpStatus, Inject, Injectable } from "@nestjs/common";
import { REQUEST } from "@nestjs/core";
import { InjectRepository } from "@nestjs/typeorm";

import { ApiException } from "@/common/exception/api.exception";
import { ActiveUserData } from "@/common/interfaces/active-user-data.interface";
import dataFilter from "@/common/utils/dataFilter";
import { Log4jsService } from "@/modules/log4js";

import {
  ProductCategoryQuery,
  ProductCategoryRequest,
} from "./category.interface";

@Injectable()
export class ProductCategoryService {
  constructor(
    @InjectRepository(ProductCategoryEntity)
    private repo: Repository<ProductCategoryEntity>,
    @Inject(REQUEST) private request: Request & { userEntity: UserEntity }

  ) {}

  async all(
    query: ProductCategoryQuery,
    user?: ActiveUserData
  ): Promise<{ rows: ProductCategoryEntity[]; count: number }> {
    const { name, ...rest } = query.where || {};
    const [rows, count] = await this.repo.findAndCount({
      skip: query.skip,
      take: query.take,
      where: {
        ...rest,
        ...(name ? { name: ILike(`%${name}%`) } : {}),
        ...dataFilter(this.request.userEntity),
      },
    });

    return {
      rows,
      count,
    };
  }

  async getById(id?: number): Promise<ProductCategoryEntity | null> {
    if (!id) {
      return null;
    }

    const data = await this.repo.findOneBy({
      id,
    });

    return data || null;
  }

  async getByIdWithError(
    id?: number
  ): Promise<ProductCategoryEntity> {
    const category = await this.getById(id);

    if (!category) {
      throw new ApiException(
        "can not find recoed",
        ApiStatusCode.KEY_NOT_EXIST,
        HttpStatus.OK,
        {
          id: id,
          type: "ProductCategoryEntity",
        }
      );
    }

    return category;
  }

  async create(
    body: ProductCategoryRequest,
    user?: ActiveUserData
  ): Promise<ProductCategoryEntity> {
    const { ...rest } = body;
    const category = new ProductCategoryEntity().extend({
      ...rest,
      companyId: user?.companyId,
      userId: user?.id,
    });

    return await this.repo.save(category);
  }

  async update(
    id: number,
    body: ProductCategoryRequest
  ): Promise<ProductCategoryEntity> {
    const category = await this.getByIdWithError(id);

    category.extend({
      ...body,
    });

    return this.repo.save(category);
  }

  async remove(id: number) {
    const data = await this.getByIdWithError(id);

    return this.repo.remove(data);
  }
}

results matching ""

    No results matching ""