import { Controller, Post, Delete, Route, Security, Tags, Body, Path, Request, Get, Patch, Query, } from "tsoa"; import HttpError from "../interfaces/http-error"; import HttpStatus from "../interfaces/http-status"; import HttpSuccess from "../interfaces/http-success"; import { AppDataSource } from "../database/data-source"; import { CreateProfileEmployeeEdit, EditProfileEmployeeEdit, ProfileEdit, } from "../entities/ProfileEdit"; import { ProfileEmployee } from "../entities/ProfileEmployee"; import { RequestWithUser } from "../middlewares/user"; import { Brackets } from "typeorm"; @Route("api/v1/org/profile-employee/edit") @Tags("ProfileEmployeeEdit") @Security("bearerAuth") export class ProfileEditEmployeeController extends Controller { private profileEmployeeRepo = AppDataSource.getRepository(ProfileEmployee); private profileEditRepository = AppDataSource.getRepository(ProfileEdit); @Get("user") public async detailProfileEditUserEmp( @Request() request: { user: Record }, @Query("page") page: number = 1, @Query("pageSize") pageSize: number = 10, @Query("keyword") keyword: string = "", @Query("status") status: string = "", ) { const profile = await this.profileEmployeeRepo.findOneBy({ keycloak: request.user.sub }); if (!profile) { throw new HttpError(HttpStatus.BAD_REQUEST, "ไม่พบ profile ดังกล่าว"); } let [getProfileEdit, total] = await AppDataSource.getRepository(ProfileEdit) .createQueryBuilder("ProfileEdit") .leftJoinAndSelect("ProfileEdit.profileEmployee", "profileEmployee") .where((qb) => { if (status != "" && status != null) { qb.andWhere("ProfileEdit.status = :status", { status: status }); } qb.andWhere("ProfileEdit.profileEmployeeId = :profileEmployeeId", { profileEmployeeId: profile.id, }); }) .andWhere( new Brackets((qb) => { qb.where(keyword != "" && keyword != null ? "ProfileEdit.topic LIKE :keyword" : "1=1", { keyword: `%${keyword}%`, }).orWhere( keyword != "" && keyword != null ? "ProfileEdit.detail LIKE :keyword" : "1=1", { keyword: `%${keyword}%`, }, ).orWhere( keyword != "" && keyword != null ? "ProfileEdit.remark LIKE :keyword" : "1=1", { keyword: `%${keyword}%`, }, ); }), ) .orderBy("ProfileEdit.createdAt", "DESC") .skip((page - 1) * pageSize) .take(pageSize) .getManyAndCount(); const _data = getProfileEdit.map((item) => ({ id: item.id, topic: item.topic, detail: item.detail, status: item.status, remark: item.remark, createdAt: item.createdAt, createdFullName: item.createdFullName, lastUpdatedAt: item.lastUpdatedAt, lastUpdateFullName: item.lastUpdateFullName, fullname: (item?.profileEmployee?.prefix ?? "") + "" + (item?.profileEmployee?.firstName ?? "") + " " + (item?.profileEmployee?.lastName ?? ""), })); return new HttpSuccess({ data: _data, total: total }); } @Get("admin") public async detailProfileEditAdminEmp( @Request() request: { user: Record }, @Query("page") page: number = 1, @Query("pageSize") pageSize: number = 10, @Query("keyword") keyword: string = "", @Query("status") status: string = "", ) { let [getProfileEdit, total] = await AppDataSource.getRepository(ProfileEdit) .createQueryBuilder("ProfileEdit") .leftJoinAndSelect("ProfileEdit.profileEmployee", "profileEmployee") .where((qb) => { if (status != "" && status != null) { qb.andWhere("ProfileEdit.status = :status", { status: status }); } qb.andWhere("ProfileEdit.profileEmployeeId IS NOT NULL"); }) .andWhere( new Brackets((qb) => { qb.where(keyword != "" && keyword != null ? "ProfileEdit.topic LIKE :keyword" : "1=1", { keyword: `%${keyword}%`, }).orWhere( keyword != "" && keyword != null ? "ProfileEdit.detail LIKE :keyword" : "1=1", { keyword: `%${keyword}%`, }, ).orWhere( keyword != "" && keyword != null ? "ProfileEdit.remark LIKE :keyword" : "1=1", { keyword: `%${keyword}%`, }, ).orWhere( keyword != "" && keyword != null ? "CONCAT(profileEmployee.prefix, profileEmployee.firstName, ' ', profileEmployee.lastName) LIKE :keyword" : "1=1", { keyword: `%${keyword}%`, }, ); }), ) .orderBy("ProfileEdit.createdAt", "DESC") .skip((page - 1) * pageSize) .take(pageSize) .getManyAndCount(); const _data = getProfileEdit.map((item) => ({ id: item.id, idcard: item.profileEmployee.citizenId, profileId: item.profileEmployee.id, topic: item.topic, detail: item.detail, status: item.status, remark: item.remark, createdAt: item.createdAt, createdFullName: item.createdFullName, lastUpdatedAt: item.lastUpdatedAt, lastUpdateFullName: item.lastUpdateFullName, fullname: (item?.profileEmployee?.prefix ?? "") + "" + (item?.profileEmployee?.firstName ?? "") + " " + (item?.profileEmployee?.lastName ?? ""), })); return new HttpSuccess({ data: _data, total: total }); } // @Get("{Id}") // public async detailProfileEmployeeByIdEdit(@Path() Id: string) { // const getProfileEdit = await this.profileEditRepository.findOne({ // where: { id: Id }, // }); // if (!getProfileEdit) { // throw new HttpError(HttpStatus.NOT_FOUND, "ไม่พบข้อมูล"); // } // return new HttpSuccess(getProfileEdit); // } @Get("{id}") public async detailProfileEditEmp(@Path() id: string) { const getProfileEdit = await this.profileEditRepository.findOne({ where: { id: id }, relations: ["profileEmployee"], }); if (!getProfileEdit) { throw new HttpError(HttpStatus.NOT_FOUND, "ไม่พบข้อมูล"); } const _data = { id: getProfileEdit.id, topic: getProfileEdit.topic, detail: getProfileEdit.detail, citizenId: getProfileEdit?.profileEmployee?.citizenId ?? "", status: getProfileEdit.status, remark: getProfileEdit.remark, createdAt: getProfileEdit.createdAt, createdFullName: getProfileEdit.createdFullName, lastUpdatedAt: getProfileEdit.lastUpdatedAt, lastUpdateFullName: getProfileEdit.lastUpdateFullName, fullname: (getProfileEdit?.profileEmployee?.prefix ?? "") + "" + (getProfileEdit?.profileEmployee?.firstName ?? "") + " " + (getProfileEdit?.profileEmployee?.lastName ?? ""), }; return new HttpSuccess(_data); } @Post() public async profileEdit( @Request() req: RequestWithUser, @Body() body: CreateProfileEmployeeEdit, ) { const profile = await this.profileEmployeeRepo.findOneBy({ keycloak: req.user.sub }); if (!profile) { throw new HttpError(HttpStatus.BAD_REQUEST, "ไม่พบ profile ดังกล่าว"); } const data = new ProfileEdit(); const meta = { createdUserId: req.user.sub, createdFullName: req.user.name, lastUpdateUserId: req.user.sub, lastUpdateFullName: req.user.name, createdAt: new Date(), lastUpdatedAt: new Date(), }; Object.assign(data, { ...body, ...meta }); data.status = "PENDING"; await this.profileEditRepository.save(data); return new HttpSuccess(data.id); } @Patch("{editId}") public async editProfileEdit( @Body() requestBody: EditProfileEmployeeEdit, @Request() req: RequestWithUser, @Path() editId: string, ) { // const record = await this.profileEditRepository.findOneBy({ id: editId }); const record = await this.profileEditRepository.findOne({ where: { id: editId }, }); if (!record) throw new HttpError(HttpStatus.NOT_FOUND, "ไม่พบข้อมูล"); Object.assign(record, requestBody); record.lastUpdateFullName = req.user.name; record.lastUpdateUserId = req.user.sub; record.lastUpdatedAt = new Date(); await Promise.all([this.profileEditRepository.save(record)]); return new HttpSuccess(); } @Delete("{editId}") public async deleteProfileEdit(@Path() editId: string) { const result = await this.profileEditRepository.delete({ id: editId }); if (result.affected == undefined || result.affected <= 0) throw new HttpError(HttpStatus.NOT_FOUND, "ไม่พบข้อมูล"); return new HttpSuccess(); } }