Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 | 5x 5x 5x 5x 5x 5x 5x 5x 5x 5x 5x 5x 5x 5x 25x 25x 25x 25x 5x 5x 1x 4x 5x 5x 4x 4x 5x 5x 5x 3x 3x 1x 2x 2x 2x 4x 4x 1x 3x 3x 3x 3x 3x 3x 3x 3x 3x 3x 3x 1x 2x 2x 2x 2x 1x 1x 1x | import { ConflictException, Injectable, NotFoundException } from '@nestjs/common'; import { plainToInstance } from 'class-transformer'; import { BookmarkQueryRepository } from 'src/bookmark/bookmark.query.repository'; import { ApiBookmarkGetDetailResponseDto } from 'src/bookmark/dto/api-bookmark-get-detail-response.dto'; import { ApiBookmarkGetRequestQueryDto } from 'src/bookmark/dto/api-bookmark-get-request-query.dto'; import { ApiBookmarkGetResponseDto } from 'src/bookmark/dto/api-bookmark-get-response.dto'; import { bookmarkCoursePlaceDetailDto } from 'src/bookmark/dto/bookmark-course-place-detail.dto'; import { ERROR } from 'src/commons/constants/error'; import { LastItemIdResponseDto } from 'src/commons/dtos/last-item-id-response.dto'; import { UuidResponseDto } from 'src/commons/dtos/uuid-response.dto'; import { isEmpty, isNotEmpty } from 'src/commons/util/is/is-empty'; import { generateUUID } from 'src/commons/util/uuid'; import { CommunityQueryRepository } from 'src/community/community.query.repository'; import { CourseQueryRepository } from 'src/course/course.query.repository'; import { BookmarkEntity } from 'src/entities/bookmark.entity'; import { UserDto } from 'src/user/dto/user.dto'; import { UserQueryRepository } from 'src/user/user.query.repository'; @Injectable() export class BookmarkService { constructor( private readonly bookmarkQueryRepository: BookmarkQueryRepository, private readonly courseQueryRepository: CourseQueryRepository, private readonly communityQueryRepository: CommunityQueryRepository, private readonly userQueryRepository: UserQueryRepository, ) {} async bookmarkList( dto: ApiBookmarkGetRequestQueryDto, user: UserDto, ): Promise<LastItemIdResponseDto<ApiBookmarkGetResponseDto>> { const courseList = await this.bookmarkQueryRepository.find(dto, user); if (isEmpty(courseList)) { return { items: [], last_item_id: 0 }; } const [userList, postedCourses = []] = await Promise.all([ this.userQueryRepository.findUserList(courseList.map((item) => item.user_uuid)), this.communityQueryRepository.findExistingCourse(courseList.map((item) => item.course_uuid)), ]); const lastItemId = courseList.length === dto.size ? courseList[courseList.length - 1].id : 0; return { items: plainToInstance(ApiBookmarkGetResponseDto, courseList, { excludeExtraneousValues: true, }).map((bookmark) => { const communityMeta = postedCourses.find((c) => c.course_uuid === bookmark.course_uuid); return { ...bookmark, user_profile_image: userList.find((u) => u.uuid === bookmark.user_uuid)?.profile_image ?? null, is_posted: !!communityMeta, community_uuid: communityMeta?.community_uuid ?? null, score: communityMeta?.score ?? '0.0', like_count: communityMeta?.like_count ?? 0, }; }), last_item_id: lastItemId, }; } async myCourseDetail(uuid: string): Promise<ApiBookmarkGetDetailResponseDto> { const course = await this.bookmarkQueryRepository.findOne(uuid); if (isEmpty(course)) { throw new NotFoundException(ERROR.NOT_EXIST_DATA); } const coursePlaces = await this.courseQueryRepository.findPlace(course.course_uuid); return new ApiBookmarkGetDetailResponseDto({ course_uuid: course.course_uuid, my_course_uuid: course.uuid, my_course_name: course.course_name, subway: course.subway, count: coursePlaces.length, place: plainToInstance( bookmarkCoursePlaceDetailDto, coursePlaces.map((coursePlace) => ({ ...coursePlace.place, sort: coursePlace.sort, uuid: coursePlace.place_uuid, })), { excludeExtraneousValues: true, }, ), }); } async bookmarkSave(user: UserDto, uuid: string): Promise<UuidResponseDto> { const course = await this.courseQueryRepository.findCourse(uuid); if (!course) { throw new NotFoundException(ERROR.NOT_EXIST_DATA); } const bookmarkEntity = new BookmarkEntity(); bookmarkEntity.uuid = generateUUID(); bookmarkEntity.course_uuid = uuid; bookmarkEntity.subway = course.subway; bookmarkEntity.line = course.line; bookmarkEntity.course_name = course.course_name; bookmarkEntity.course_image = course.course_image; bookmarkEntity.user_uuid = user.uuid; bookmarkEntity.user_name = user.nickname; const myBookmark = await this.bookmarkQueryRepository.findUserBookmark(user, uuid); if (isNotEmpty(myBookmark) && isEmpty(myBookmark.archived_at)) { throw new ConflictException(ERROR.DUPLICATION); } await (isNotEmpty(myBookmark) ? this.bookmarkQueryRepository.bookmarkUpdate(bookmarkEntity) : this.bookmarkQueryRepository.bookmarkSave(bookmarkEntity)); return { uuid }; } async bookmarkDelete(user: UserDto, uuid: string): Promise<UuidResponseDto> { const myBookmark = await this.bookmarkQueryRepository.findUserBookmark(user, uuid); if (isEmpty(myBookmark)) { throw new NotFoundException(ERROR.NOT_EXIST_DATA); } await this.bookmarkQueryRepository.bookmarkDelete(myBookmark); return { uuid }; } } |