diff --git a/adapters/in-web/src/main/kotlin/com/pokit/content/dto/response/ContentsResponse.kt b/adapters/in-web/src/main/kotlin/com/pokit/content/dto/response/ContentsResponse.kt index 5ccb8afa..2c965558 100644 --- a/adapters/in-web/src/main/kotlin/com/pokit/content/dto/response/ContentsResponse.kt +++ b/adapters/in-web/src/main/kotlin/com/pokit/content/dto/response/ContentsResponse.kt @@ -15,6 +15,7 @@ data class ContentsResponse( val createdAt: String, val isRead: Boolean, val thumbNail: String, + val isFavorite: Boolean ) fun ContentsResult.toResponse(): ContentsResponse { @@ -30,6 +31,7 @@ fun ContentsResult.toResponse(): ContentsResponse { alertYn = this.alertYn, createdAt = this.createdAt.format(formatter), isRead = this.isRead, - thumbNail = this.thumbNail + thumbNail = this.thumbNail, + isFavorite = this.isFavorite ) } diff --git a/adapters/out-persistence/src/main/kotlin/com/pokit/out/persistence/content/impl/ContentAdapter.kt b/adapters/out-persistence/src/main/kotlin/com/pokit/out/persistence/content/impl/ContentAdapter.kt index d2ab7a3f..b4691db3 100644 --- a/adapters/out-persistence/src/main/kotlin/com/pokit/out/persistence/content/impl/ContentAdapter.kt +++ b/adapters/out-persistence/src/main/kotlin/com/pokit/out/persistence/content/impl/ContentAdapter.kt @@ -61,10 +61,11 @@ class ContentAdapter( condition: ContentSearchCondition, pageable: Pageable, ): Slice { - val query = queryFactory.select(contentEntity, categoryEntity.name, userLogEntity.count()) + val query = queryFactory.select(contentEntity, categoryEntity.name, userLogEntity.count(), bookmarkEntity.count()) .from(contentEntity) .leftJoin(userLogEntity).on(userLogEntity.contentId.eq(contentEntity.id)) .join(categoryEntity).on(categoryEntity.id.eq(contentEntity.categoryId)) + .leftJoin(bookmarkEntity).on(bookmarkEntity.contentId.eq(contentEntity.id)) FavoriteOrNot(condition.favorites, query) // 북마크 조인 여부 @@ -90,7 +91,8 @@ class ContentAdapter( ContentsResult.of( it[contentEntity]!!.toDomain(), it[categoryEntity.name]!!, - it[userLogEntity.count()]!! + it[userLogEntity.count()]!!, + it[bookmarkEntity.count()]!! ) } @@ -98,10 +100,11 @@ class ContentAdapter( } override fun loadByUserIdAndCategoryName(userId: Long, categoryName: String, pageable: Pageable): Slice { - val contents = queryFactory.select(contentEntity, categoryEntity.name, userLogEntity.count()) + val contents = queryFactory.select(contentEntity, categoryEntity.name, userLogEntity.count(), bookmarkEntity.count()) .from(contentEntity) .leftJoin(userLogEntity).on(userLogEntity.contentId.eq(contentEntity.id)) .join(categoryEntity).on(categoryEntity.id.eq(contentEntity.categoryId)) + .leftJoin(bookmarkEntity).on(bookmarkEntity.contentId.eq(contentEntity.id)) .where( categoryEntity.userId.eq(userId), categoryEntity.name.eq(categoryName), @@ -119,7 +122,8 @@ class ContentAdapter( ContentsResult.of( it[contentEntity]!!.toDomain(), it[categoryEntity.name]!!, - it[userLogEntity.count()]!! + it[userLogEntity.count()]!!, + it[bookmarkEntity.count()]!! ) } @@ -127,11 +131,11 @@ class ContentAdapter( } override fun loadBookmarkedContentsByUserId(userId: Long, pageable: Pageable): Slice { - val contents = queryFactory.select(contentEntity, categoryEntity.name, userLogEntity.count()) + val contents = queryFactory.select(contentEntity, categoryEntity.name, userLogEntity.count(), bookmarkEntity.count()) .from(contentEntity) .leftJoin(userLogEntity).on(userLogEntity.contentId.eq(contentEntity.id)) .join(categoryEntity).on(categoryEntity.id.eq(contentEntity.categoryId)) - .join(bookmarkEntity).on(bookmarkEntity.contentId.eq(contentEntity.id)) + .leftJoin(bookmarkEntity).on(bookmarkEntity.contentId.eq(contentEntity.id)) .where( categoryEntity.userId.eq(userId), contentEntity.deleted.isFalse, @@ -149,7 +153,8 @@ class ContentAdapter( ContentsResult.of( it[contentEntity]!!.toDomain(), it[categoryEntity.name]!!, - it[userLogEntity.count()]!! + it[userLogEntity.count()]!!, + it[bookmarkEntity.count()]!! ) } diff --git a/domain/src/main/kotlin/com/pokit/content/dto/response/ContentsResult.kt b/domain/src/main/kotlin/com/pokit/content/dto/response/ContentsResult.kt index 8d92247f..a08a0e5b 100644 --- a/domain/src/main/kotlin/com/pokit/content/dto/response/ContentsResult.kt +++ b/domain/src/main/kotlin/com/pokit/content/dto/response/ContentsResult.kt @@ -15,10 +15,11 @@ data class ContentsResult( val alertYn: String, val createdAt: LocalDateTime, val isRead: Boolean, - val thumbNail: String + val thumbNail: String, + val isFavorite: Boolean ) { companion object { - fun of(content: Content, categoryName: String, isRead: Long): ContentsResult { + fun of(content: Content, categoryName: String, isRead: Long, isFavorite: Long): ContentsResult { return ContentsResult( contentId = content.id, category = RemindCategory(content.categoryId, categoryName), @@ -29,7 +30,8 @@ data class ContentsResult( alertYn = content.alertYn, createdAt = content.createdAt, isRead = isRead > 0, - thumbNail = content.thumbNail ?: ContentDefault.THUMB_NAIL + thumbNail = content.thumbNail ?: ContentDefault.THUMB_NAIL, + isFavorite = isFavorite > 0 ) } }