Skip to content

Commit

Permalink
feat: 홈화면 가게 별 선결제 디데이 추가, 쿼리문 조정 (#169)
Browse files Browse the repository at this point in the history
* feat: 장바구니 추가 기능 구현

* feat: 장바구니 조회 기능 구현

* feat: 상품 주문과 식권 사용 기능 구현

* style: 포인트트랜잭션 레포지토리명 변경

* deploy: 재배포

* deploy: 재배포2

* deploy: 로그인 로직 수정에 따른 재배포

* deploy: 로그인 로직 수정에 따른 재배포2

* feat: 식권 사용 기능 구현

* feat: yml 수정 사항 반영

* feat: 식권 사용 로직 수정

* feat: 주문 로직 수정 완료

* fix: 장바구니에 아무것도 없을 때 주문 시 active 되는 현상 수정

* feat: 주문 완료 시 리턴 값 수정

* feat: 내 그룹 조회 기능 구현

* feat: 기본 프로필 이미지 url 추가

* feat: 그룹 멤버 전체 조회 기능 구현

* feat: 1인당 사용 가능 금액 설정 컬럼 추가

* feat: 내 지갑 조회 기능 구현

* feat: 선결제 기능 구현

* feat: 유저 홈 화면 조회 기능 구현

* feat: 그룹 상세 조회 기능 구현

* feat: 가게 상세 조회 쿼리 수정

* deploy: 변경사항 반영을 위한 커밋

* deploy: 수정 사항 반영 재배포

* deploy: rds 교체로 인한 재배포

* deploy: rds 교체로 인한 재배포2

* feat: 홈 화면 소속팀 조회 쿼리 제대로 안되던 현상 해결, 대표이미지 반환 추가

* feat: 그룹 상세 조회 응답 컬럼명 변경

* feat: memberLimit 컬럼 삭제

* feat: 선결제 시 기존 결제 내역과 멱등성 문제 해결

* fix: 팀 상세 조회 시 이미지 쿼리가 의미 없이 join 되던 쿼리 수정

* feat: 가게 검색 기능 대폭 수정

* feat: 프론트 요구사 반영

* feat: searchcondition 삭제

* feat: 팀타입 desription 리턴 하도록 수정

* feat: 카테고리별 팀 조회 시 팀 생성일 컬럼 추가

* feat: 매장찾기_상세 페이지 조회 기능 구현

* feat: 비밀 코드 조회 기능 엔드 포인트 수정

* fix: conflict fix

* hotfix: 서버 복구

* hotfix: 서버 복구2

* feat: Barobill api 연동

* fix: 홈 화면에 같은 데이터가 중복되는 현상 수정

* infra: ElastiCache 연결을 위한 docker-compose 설정

* infra: cicd script 수정

* infra: cicd script ec2 주소 설정

* infra: cicd script 수정2

* infra: cicd script 수정3

* infra: cicd script 수정4

* infra: cicd script 수정5

* infra: cicd script 수정6

* infra: cicd script 수정7

* infra: cicd script 수정7

* infra: cicd script 수정8

* infra: cicd script 수정9

* infra: cicd script 수정10

* infra: cicd script 수정11

* infra: cicd script 수정12

* infra: cicd script 수정13

* infra: cicd script 수정14

* infra: cicd script 수정15

* infra: cicd script 수정16

* infra: cicd script 수정17

* infra: cicd script 수정18

* infra: cicd script 수정19

* infra: cicd script 수정20

* infra: cicd script 수정21

* infra: cicd script 수정22

* fix: 보유금액이 선결제 금액보다 작을 경우 상태값 변경(200->400)

* feat: 홈화면 가게 별 선결제 디데이 추가, 쿼리문 조정
  • Loading branch information
LEEJaeHyeok97 authored Nov 27, 2024
1 parent b6c9a32 commit 0d0d7b4
Show file tree
Hide file tree
Showing 4 changed files with 23 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import jakarta.persistence.Id;
import jakarta.persistence.JoinColumn;
import jakarta.persistence.ManyToOne;
import java.time.LocalDate;
import lombok.AccessLevel;
import lombok.Builder;
import lombok.Getter;
Expand Down Expand Up @@ -44,6 +45,9 @@ public class StoreTeam extends BaseEntity {
@Column(name = "remain_point")
private Integer remainPoint;

@Column(name = "prepaid_expiration_date")
private LocalDate prepaidExpirationDate;

public void updatePersonalAllocatedPoint(Integer point) {
this.personalAllocatedPoint = point;
}
Expand Down Expand Up @@ -71,13 +75,16 @@ public void subRemainPoint(Integer point) {
this.remainPoint -= point;
}


@Builder
public StoreTeam(Store store, Team team, Integer point, Integer personalAllocatedPoint, Integer remainPoint) {
public StoreTeam(Store store, Team team, Integer point, Integer personalAllocatedPoint, Integer remainPoint,
LocalDate prepaidExpirationDate) {
this.store = store;
this.team = team;
this.point = point;
this.personalAllocatedPoint = personalAllocatedPoint;
this.remainPoint = remainPoint;
this.prepaidExpirationDate = prepaidExpirationDate;
}

public static StoreTeam create(Team team, Store store, Integer point) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
import com.jangburich.global.error.DefaultNullPointerException;
import com.jangburich.global.payload.ErrorCode;
import com.jangburich.global.payload.Message;
import java.time.LocalDate;
import java.util.Optional;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Service;
Expand Down Expand Up @@ -57,13 +58,16 @@ public Message prepay(String userId, PrepayRequest prepayRequest) {

pointTransactionRepository.save(pointTransaction);

LocalDate expirationDate = LocalDate.now().plusDays(store.getPrepaymentDuration());

StoreTeam buildedStoreTeam = StoreTeam
.builder()
.team(team)
.store(store)
.point(prepayRequest.prepayAmount())
.personalAllocatedPoint(prepayRequest.personalAllocatedAmount())
.remainPoint(prepayRequest.prepayAmount())
.prepaidExpirationDate(expirationDate)
.build();

Optional<StoreTeam> storeAndTeam = storeTeamRepository.findByStoreAndTeam(store, team);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
public record TeamsResponse(
Long teamId,
Long storeId,
int dDay,
String storeImgUrl,
Boolean isLikedAtStore,
String teamName,
Expand All @@ -14,10 +15,12 @@ public record TeamsResponse(
) {

@QueryProjection
public TeamsResponse(Long teamId, Long storeId, String storeImgUrl, Boolean isLikedAtStore, String teamName,
public TeamsResponse(Long teamId, Long storeId, int dDay, String storeImgUrl, Boolean isLikedAtStore,
String teamName,
String storeName, int totalAmount, int currentAmount) {
this.teamId = teamId;
this.storeId = storeId;
this.dDay = dDay;
this.storeImgUrl = storeImgUrl;
this.isLikedAtStore = isLikedAtStore;
this.teamName = teamName;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,24 +33,26 @@ public UserHomeResponse findUserHomeData(Long userId) {

List<TeamsResponse> teamsResponses = queryFactory
.selectDistinct(new QTeamsResponse(
storeTeam.team.id,
userTeam.team.id,
storeTeam.store.id,
Expressions.numberTemplate(Integer.class,
"DATEDIFF({0}, CURRENT_DATE)",
storeTeam.prepaidExpirationDate),
storeTeam.store.representativeImage,
Expressions.constant(false),
storeTeam.team.name,
storeTeam.store.name,
storeTeam.point,
storeTeam.remainPoint
))
.from(storeTeam)
.leftJoin(team).on(team.id.eq(storeTeam.team.id))
.leftJoin(userTeam).on(storeTeam.team.eq(team))
.from(userTeam)
.leftJoin(team).on(team.id.eq(userTeam.team.id))
.leftJoin(storeTeam).on(storeTeam.team.eq(team))
.where(storeTeam.status.eq(Status.ACTIVE),
userTeam.user.userId.eq(userId))
.orderBy(storeTeam.createdAt.desc())
.fetch();


UserHomeResponse userHomeResponse = queryFactory.select(new QUserHomeResponse(
user.userId,
Expressions.constant(formattedDate),
Expand Down

0 comments on commit 0d0d7b4

Please sign in to comment.