From 05dc6758959e1b8d320904b63dd8478cafa3139c Mon Sep 17 00:00:00 2001 From: Maksim Mrug <80621719+kruzhambus@users.noreply.github.com> Date: Fri, 6 Oct 2023 12:04:18 -0400 Subject: [PATCH] (feature) project search (#193) --- .../src/project/project.controller.ts | 61 ++++++++++++++++--- 1 file changed, 53 insertions(+), 8 deletions(-) diff --git a/apps/production/src/project/project.controller.ts b/apps/production/src/project/project.controller.ts index 27513ee60..6f4e268b2 100644 --- a/apps/production/src/project/project.controller.ts +++ b/apps/production/src/project/project.controller.ts @@ -22,6 +22,7 @@ import { } from '@nestjs/common' import { Response } from 'express' import { ApiTags, ApiQuery, ApiResponse } from '@nestjs/swagger' +import { ILike } from 'typeorm' import * as _isEmpty from 'lodash/isEmpty' import * as _map from 'lodash/map' import * as _trim from 'lodash/trim' @@ -111,6 +112,7 @@ export class ProjectController { @ApiQuery({ name: 'skip', required: false }) @ApiQuery({ name: 'isCaptcha', required: false, type: Boolean }) @ApiQuery({ name: 'relatedonly', required: false, type: Boolean }) + @ApiQuery({ name: 'search', required: false, type: String }) @ApiResponse({ status: 200, type: [Project] }) @Auth([UserType.CUSTOMER, UserType.ADMIN], true) async get( @@ -118,17 +120,40 @@ export class ProjectController { @Query('take') take: number | undefined, @Query('skip') skip: number | undefined, @Query('isCaptcha') isCaptchaStr: string | undefined, + @Query('search') search: string | undefined, ): Promise | Project[] | object> { this.logger.log({ userId, take, skip }, 'GET /project') const isCaptcha = isCaptchaStr === 'true' - const where = Object() - where.admin = userId + let where: any - if (isCaptcha) { - where.isCaptchaProject = true + if (search) { + where = [ + { + admin: userId, + isCaptchaProject: isCaptcha, + isAnalyticsProject: !isCaptcha, + name: ILike(`%${search}%`), + // name: ILike(`%${mysql.escape(search).slice(1, 0).slice(0, -1)}%`), + }, + { + admin: userId, + isCaptchaProject: isCaptcha, + isAnalyticsProject: !isCaptcha, + id: ILike(`%${search}%`), + // id: ILike(`%${mysql.escape(search).slice(1, 0).slice(0, -1)}%`), + }, + ] } else { - where.isAnalyticsProject = true + where = { + admin: userId, + } + + if (isCaptcha) { + where.isCaptchaProject = true + } else { + where.isAnalyticsProject = true + } } const paginated = await this.projectService.paginate({ take, skip }, where) @@ -168,17 +193,37 @@ export class ProjectController { @ApiQuery({ name: 'take', required: false }) @ApiQuery({ name: 'skip', required: false }) @ApiQuery({ name: 'relatedonly', required: false, type: Boolean }) + @ApiQuery({ name: 'search', required: false, type: String }) @ApiResponse({ status: 200, type: [Project] }) @Auth([UserType.CUSTOMER, UserType.ADMIN], true) async getShared( @CurrentUserId() userId: string, @Query('take') take: number | undefined, @Query('skip') skip: number | undefined, + @Query('search') search: string | undefined, ): Promise | ProjectShare[] | object> { - this.logger.log({ userId, take, skip }, 'GET /project/shared') + this.logger.log({ userId, take, skip, search }, 'GET /project/shared') - const where = Object() - where.user = userId + let where = Object() + + if (search) { + where = [ + { + user: userId, + project: { + name: ILike(`%${search}%`), + }, + }, + { + user: userId, + project: { + id: ILike(`%${search}%`), + }, + }, + ] + } else { + where.user = userId + } const paginated = await this.projectService.paginateShared( { take, skip },