Skip to content

Commit

Permalink
feat: 마이페이지 - 관심 챌린지 조회 api
Browse files Browse the repository at this point in the history
  • Loading branch information
daeunkwak committed Aug 10, 2023
1 parent 060b5be commit bd30e2e
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -361,6 +361,17 @@ private List<ChallengeResponseDto> makeChallengeResponseDto(String tokenString,
return challengeResponseDtos;
}

private List<ChallengeResponseDto> makeChallengeResponseDtoV2(Long memberId, List<ChallengeResponseVo> challengeVos){

List<ChallengeResponseDto> challengeResponseDtos = new ArrayList<>();
challengeResponseDtos = challengeVos.stream().map(vo -> {
return ChallengeResponseDto.from(vo.getChallenge(), vo.getParticipateNum(),
findIsLike(vo.getChallenge(), memberId), ChronoUnit.DAYS.between(LocalDate.now(), vo.getChallenge().getChallengeStartDate()));
}).toList();

return challengeResponseDtos;
}

private Boolean findIsLike(Challenge challenge, Long memberId){

for(ChallengeLike challengeLike : challenge.getChallengeLikes()){
Expand Down Expand Up @@ -415,6 +426,20 @@ public ResponseEntity<MyChallengeResponseDto> getMyChallenge(@Parameter(hidden =
PassedChallengeListResponseDto.from(passedChallengeResponseDtos), JudgingChallengeListResponseDto.from(judgingChallengeResponseDtos)));
}

@Tag(name = "myPage", description = "마이페이지 API")
@Operation(summary = "관심 챌린지 리스트 조회 api")
@GetMapping("/like")
public ResponseEntity<List<ChallengeResponseDto>> getMyChallengeLike(@Parameter(hidden = true) @RequestMemberId Long memberId) {

List<Challenge> challenges = challengeService.getMyChallengeLike(memberId);
List<ChallengeResponseVo>challengeVos = challenges.stream().map(challenge -> {
return new ChallengeResponseVo(challenge, challenge.getParticipates().size());
}).collect(Collectors.toList());

List<ChallengeResponseDto> challengeResponseDtos = makeChallengeResponseDtoV2(memberId, challengeVos);
return ResponseEntity.ok(challengeResponseDtos);
}

private Integer getSuccessNum(Challenge challenge){

int cnt = 0;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,25 +3,31 @@
import com.cmc.challenge.Challenge;
import com.cmc.challenge.constant.JudgeStatus;
import com.cmc.challenge.constant.ChallengeStatus;
import com.cmc.challengeLike.ChallengeLike;
import com.cmc.common.exception.BadRequestException;
import com.cmc.common.exception.CiderException;
import com.cmc.common.exception.NoSuchIdException;
import com.cmc.domains.challenge.dto.request.ChallengeCreateRequestDto;
import com.cmc.domains.challenge.repository.ChallengeRepository;
import com.cmc.domains.challenge.vo.ChallengeResponseVo;
import com.cmc.domains.member.repository.MemberRepository;
import com.cmc.member.Member;
import com.cmc.participate.Participate;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;

import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;

@Service
@Transactional
@RequiredArgsConstructor
public class ChallengeService {

private final ChallengeRepository challengeRepository;
private final MemberRepository memberRepository;

// 챌린지 생성
public Challenge create(ChallengeCreateRequestDto req, Long memberId) {
Expand Down Expand Up @@ -179,4 +185,20 @@ public Challenge getChallenge(Long challengeId) {
}
return challenge;
}

// 마이페이지 - 관심 챌린지 조회
public List<Challenge> getMyChallengeLike(Long memberId) {

Member member = findMemberOrThrow(memberId);
return member.getChallengeLikes().stream()
.map(ChallengeLike::getChallenge)
.collect(Collectors.toList());
}

private Member findMemberOrThrow(Long memberId) {
return memberRepository.findById(memberId).orElseThrow(() -> {
throw new BadRequestException("요청한 멤버는 존재하지 않습니다.");
});

}
}

0 comments on commit bd30e2e

Please sign in to comment.