diff --git a/src/main/java/com/potatocake/everymoment/dto/request/DiaryFilterRequest.java b/src/main/java/com/potatocake/everymoment/dto/request/DiaryFilterRequest.java index 720a07e..1f31183 100644 --- a/src/main/java/com/potatocake/everymoment/dto/request/DiaryFilterRequest.java +++ b/src/main/java/com/potatocake/everymoment/dto/request/DiaryFilterRequest.java @@ -27,10 +27,11 @@ public List getEmojis() { : Collections.emptyList(); } - public List getCategories() { + public List getCategories() { return (category != null && !category.isEmpty()) ? Arrays.stream(category.split(",")) - .map(Long::parseLong) + .map(String::trim) + .filter(s -> !s.isEmpty()) .collect(Collectors.toList()) : Collections.emptyList(); } diff --git a/src/main/java/com/potatocake/everymoment/dto/request/DiaryManualCreateRequest.java b/src/main/java/com/potatocake/everymoment/dto/request/DiaryManualCreateRequest.java index 849298a..9df2ed2 100644 --- a/src/main/java/com/potatocake/everymoment/dto/request/DiaryManualCreateRequest.java +++ b/src/main/java/com/potatocake/everymoment/dto/request/DiaryManualCreateRequest.java @@ -13,7 +13,5 @@ public class DiaryManualCreateRequest { private boolean isBookmark; private boolean isPublic; private String emoji; - private List file; private String content; } - diff --git a/src/main/java/com/potatocake/everymoment/entity/Diary.java b/src/main/java/com/potatocake/everymoment/entity/Diary.java index 23d7583..c60f671 100644 --- a/src/main/java/com/potatocake/everymoment/entity/Diary.java +++ b/src/main/java/com/potatocake/everymoment/entity/Diary.java @@ -1,5 +1,6 @@ package com.potatocake.everymoment.entity; +import jakarta.persistence.CascadeType; import jakarta.persistence.Column; import jakarta.persistence.Entity; import jakarta.persistence.FetchType; @@ -9,6 +10,9 @@ import jakarta.persistence.JoinColumn; import jakarta.persistence.Lob; import jakarta.persistence.ManyToOne; +import jakarta.persistence.OneToMany; +import java.util.HashSet; +import java.util.Set; import lombok.AccessLevel; import lombok.AllArgsConstructor; import lombok.Builder; @@ -53,6 +57,9 @@ public class Diary extends BaseTimeEntity { @Builder.Default private boolean isPublic = false; + @OneToMany(mappedBy = "diary", cascade = CascadeType.ALL, orphanRemoval = true) + private Set diaryCategories = new HashSet<>(); + public void updateContent(String content) { if (content != null) { this.content = content; diff --git a/src/main/java/com/potatocake/everymoment/entity/DiaryCategory.java b/src/main/java/com/potatocake/everymoment/entity/DiaryCategory.java index 3a724d8..534c7dd 100644 --- a/src/main/java/com/potatocake/everymoment/entity/DiaryCategory.java +++ b/src/main/java/com/potatocake/everymoment/entity/DiaryCategory.java @@ -31,4 +31,13 @@ public class DiaryCategory { @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(foreignKey = @ForeignKey(name = "fk_category_id"), nullable = false) private Category category; + + public void setDiary(Diary diary) { + this.diary = diary; + } + + public void setCategory(Category category) { + this.category = category; + } + } diff --git a/src/main/java/com/potatocake/everymoment/service/DiaryService.java b/src/main/java/com/potatocake/everymoment/service/DiaryService.java index 8293530..c4ac02a 100644 --- a/src/main/java/com/potatocake/everymoment/service/DiaryService.java +++ b/src/main/java/com/potatocake/everymoment/service/DiaryService.java @@ -100,7 +100,6 @@ public void createDiaryManual(Long memberId, DiaryManualCreateRequest diaryManua Member currentMember = memberRepository.findById(memberId) .orElseThrow(() -> new GlobalException(ErrorCode.MEMBER_NOT_FOUND)); - double longitude = diaryManualCreateRequest.getLocationPoint().getLongitude(); double latitude = diaryManualCreateRequest.getLocationPoint().getLatitude(); @@ -149,21 +148,21 @@ public MyDiariesResponse getMyDiaries(Long memberId, DiaryFilterRequest diaryFil Page diaryPage; - List categoryIds = diaryFilterRequest.getCategories(); + List categories = diaryFilterRequest.getCategories(); List emojis = diaryFilterRequest.getEmojis(); Specification spec = DiarySpecification.filterDiaries( diaryFilterRequest.getKeyword(), emojis, - categoryIds, + categories, diaryFilterRequest.getDate(), diaryFilterRequest.getFrom(), diaryFilterRequest.getUntil(), diaryFilterRequest.getIsBookmark()) .and((root, query, builder) -> builder.equal(root.get("member"), currentMember)); - diaryPage = diaryRepository.findAll(spec, PageRequest.of(diaryFilterRequest.getKey(), diaryFilterRequest.getSize())); - + diaryPage = diaryRepository.findAll(spec, + PageRequest.of(diaryFilterRequest.getKey(), diaryFilterRequest.getSize())); List diaryDTOs = diaryPage.getContent().stream() .map(this::convertToMyDiarySimpleResponseDto) diff --git a/src/main/java/com/potatocake/everymoment/service/DiarySpecification.java b/src/main/java/com/potatocake/everymoment/service/DiarySpecification.java index 3a9826d..95dd147 100644 --- a/src/main/java/com/potatocake/everymoment/service/DiarySpecification.java +++ b/src/main/java/com/potatocake/everymoment/service/DiarySpecification.java @@ -1,22 +1,23 @@ package com.potatocake.everymoment.service; +import com.potatocake.everymoment.entity.Category; import com.potatocake.everymoment.entity.Diary; import com.potatocake.everymoment.entity.DiaryCategory; import jakarta.persistence.criteria.CriteriaBuilder; import jakarta.persistence.criteria.CriteriaQuery; import jakarta.persistence.criteria.Join; +import jakarta.persistence.criteria.JoinType; import jakarta.persistence.criteria.Predicate; import jakarta.persistence.criteria.Root; +import java.time.LocalDate; import java.util.List; import org.springframework.data.jpa.domain.Specification; -import java.time.LocalDate; - public class DiarySpecification { public static Specification filterDiaries( - String keyword, List emojis, List categories, + String keyword, List emojis, List categories, LocalDate date, LocalDate from, LocalDate until, Boolean isBookmark) { return (Root root, CriteriaQuery query, CriteriaBuilder builder) -> { Predicate predicate = builder.conjunction(); @@ -29,15 +30,17 @@ public static Specification filterDiaries( } if (categories != null && !categories.isEmpty()) { - Join diaryCategoryJoin = root.join("diaryCategories"); - predicate = builder.and(predicate, diaryCategoryJoin.get("category").get("id").in(categories)); + Join diaryCategoryJoin = root.join("diaryCategories", JoinType.LEFT); + Join categoryJoin = diaryCategoryJoin.join("category", JoinType.LEFT); + predicate = builder.and(predicate, categoryJoin.get("categoryName").in(categories)); } LocalDate filterDate = (date != null) ? date : LocalDate.now(); predicate = builder.and(predicate, builder.equal(root.get("createAt").as(LocalDate.class), filterDate)); if (from != null && until != null) { - predicate = builder.and(predicate, builder.between(root.get("createAt"), from.atStartOfDay(), until.plusDays(1).atStartOfDay())); + predicate = builder.and(predicate, + builder.between(root.get("createAt"), from.atStartOfDay(), until.plusDays(1).atStartOfDay())); } if (isBookmark != null) { predicate = builder.and(predicate, builder.equal(root.get("isBookmark"), isBookmark)); diff --git a/src/main/java/com/potatocake/everymoment/service/FriendDiaryService.java b/src/main/java/com/potatocake/everymoment/service/FriendDiaryService.java index fb83595..2afa0a4 100644 --- a/src/main/java/com/potatocake/everymoment/service/FriendDiaryService.java +++ b/src/main/java/com/potatocake/everymoment/service/FriendDiaryService.java @@ -53,20 +53,21 @@ public FriendDiariesResponse getFriendDiaries(Long memberId, DiaryFilterRequest Page diaryPage; // 카테고리와 이모지가 여러 개 전달될 수 있으므로 이를 리스트로 변환 - List categoryIds = diaryFilterRequest.getCategories(); + List categories = diaryFilterRequest.getCategories(); List emojis = diaryFilterRequest.getEmojis(); Specification spec = DiarySpecification.filterDiaries( diaryFilterRequest.getKeyword(), emojis, - categoryIds, + categories, diaryFilterRequest.getDate(), diaryFilterRequest.getFrom(), diaryFilterRequest.getUntil(), diaryFilterRequest.getIsBookmark()) .and((root, query, builder) -> root.get("member").in(friendIdList)); - diaryPage = diaryRepository.findAll(spec, PageRequest.of(diaryFilterRequest.getKey(), diaryFilterRequest.getSize())); + diaryPage = diaryRepository.findAll(spec, + PageRequest.of(diaryFilterRequest.getKey(), diaryFilterRequest.getSize())); List friendDiarySimpleResponseList = diaryPage.getContent().stream() .map(this::convertToFriendDiariesResponseDTO)