bugfix menu tree dnd update

This commit is contained in:
shinmj
2021-11-19 17:09:08 +09:00
parent 5068dca753
commit d289bc883d
20 changed files with 726 additions and 656 deletions

View File

@@ -58,6 +58,11 @@ public class BoardListResponseDto implements Serializable {
*/
private LocalDateTime createdDate;
/**
* 게시글이 있는지 여부
*/
private Boolean isPosts;
/**
* 게시판 목록 응답 DTO 생성자
*
@@ -66,10 +71,11 @@ public class BoardListResponseDto implements Serializable {
* @param skinTypeCode 스킨 유형 코드
*/
@QueryProjection
public BoardListResponseDto(Integer boardNo, String boardName, String skinTypeCode) {
public BoardListResponseDto(Integer boardNo, String boardName, String skinTypeCode, Boolean isPosts) {
this.boardNo = boardNo;
this.boardName = boardName;
this.skinTypeCode = skinTypeCode;
this.isPosts = isPosts;
}
/**
@@ -82,12 +88,13 @@ public class BoardListResponseDto implements Serializable {
* @param createdDate 생성 일시
*/
@QueryProjection
public BoardListResponseDto(Integer boardNo, String boardName, String skinTypeCode, String skinTypeCodeName, LocalDateTime createdDate) {
public BoardListResponseDto(Integer boardNo, String boardName, String skinTypeCode, String skinTypeCodeName, LocalDateTime createdDate, Boolean isPosts) {
this.boardNo = boardNo;
this.boardName = boardName;
this.skinTypeCode = skinTypeCode;
this.skinTypeCodeName = skinTypeCodeName;
this.createdDate = createdDate;
this.isPosts = isPosts;
}
}

View File

@@ -1,6 +1,7 @@
package org.egovframe.cloud.boardservice.api.posts.dto;
import lombok.Getter;
import org.egovframe.cloud.boardservice.domain.board.Board;
import org.egovframe.cloud.boardservice.domain.posts.Posts;
import org.egovframe.cloud.boardservice.domain.posts.PostsId;
@@ -49,6 +50,9 @@ public class PostsDeleteRequestDto {
.boardNo(boardNo)
.postsNo(postsNo)
.build())
.board(Board.builder()
.boardNo(boardNo)
.build())
.build();
}

View File

@@ -1,6 +1,7 @@
package org.egovframe.cloud.boardservice.api.posts.dto;
import com.querydsl.core.annotations.QueryProjection;
import java.time.LocalDate;
import lombok.Getter;
import lombok.NoArgsConstructor;
import org.egovframe.cloud.boardservice.api.board.dto.BoardResponseDto;
@@ -92,7 +93,8 @@ public class PostsSimpleResponseDto implements Serializable {
*/
public PostsSimpleResponseDto setIsNew(BoardResponseDto boardResponseDto) {
if (boardResponseDto.getNewDisplayDayCount() != null) {
this.isNew = createdDate.plusDays(boardResponseDto.getNewDisplayDayCount()).compareTo(LocalDateTime.now()) <= 0;
int compareTo = createdDate.toLocalDate().compareTo(LocalDate.now());
this.isNew = 0 <= compareTo && compareTo <= boardResponseDto.getNewDisplayDayCount();
} else {
this.isNew = false;
}

View File

@@ -1,12 +1,17 @@
package org.egovframe.cloud.boardservice.domain.board;
import java.util.ArrayList;
import java.util.List;
import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;
import org.egovframe.cloud.boardservice.domain.posts.Posts;
import org.egovframe.cloud.servlet.domain.BaseEntity;
import javax.persistence.*;
import java.math.BigDecimal;
import org.hibernate.annotations.OnDelete;
import org.hibernate.annotations.OnDeleteAction;
/**
* org.egovframe.cloud.boardservice.domain.board.Board
@@ -113,9 +118,9 @@ public class Board extends BaseEntity {
/**
* 게시물 엔티티
*/
/*@OneToMany(mappedBy = "board", fetch = FetchType.LAZY)
@OneToMany(mappedBy = "board", fetch = FetchType.LAZY)
@OnDelete(action = OnDeleteAction.CASCADE)
private List<Posts> posts;*/
private List<Posts> posts = new ArrayList<>();
/**
* 빌더 패턴 클래스 생성자

View File

@@ -1,11 +1,14 @@
package org.egovframe.cloud.boardservice.domain.board;
import static com.querydsl.core.types.Projections.constructor;
import com.google.common.base.CaseFormat;
import com.querydsl.core.QueryResults;
import com.querydsl.core.types.Order;
import com.querydsl.core.types.OrderSpecifier;
import com.querydsl.core.types.Path;
import com.querydsl.core.types.dsl.BooleanExpression;
import com.querydsl.core.types.dsl.CaseBuilder;
import com.querydsl.core.types.dsl.Expressions;
import com.querydsl.jpa.JPQLQuery;
import com.querydsl.jpa.impl.JPAQueryFactory;
@@ -58,12 +61,16 @@ public class BoardRepositoryImpl implements BoardRepositoryCustom {
@Override
public Page<BoardListResponseDto> findPage(RequestDto requestDto, Pageable pageable) {
JPQLQuery<BoardListResponseDto> query = jpaQueryFactory
.select(new QBoardListResponseDto(
.select(constructor(BoardListResponseDto.class,
QBoard.board.boardNo,
QBoard.board.boardName,
QBoard.board.skinTypeCode,
Expressions.as(QCode.code.codeName, "skinTypeCodeName"),
QBoard.board.createdDate
QBoard.board.createdDate,
new CaseBuilder()
.when(QBoard.board.posts.size().gt(0))
.then(Boolean.TRUE)
.otherwise(Boolean.FALSE).as("isPosts")
))
.from(QBoard.board)
.leftJoin(QCode.code).on(QBoard.board.skinTypeCode.eq(QCode.code.codeId).and(QCode.code.parentCodeId.eq("skin_type_code")))

View File

@@ -128,7 +128,6 @@ public class Posts extends BaseEntity {
String postsContent, String postsAnswerContent, String attachmentCode,
Integer readCount, Boolean noticeAt, Integer deleteAt,
User creator, List<Comment> comments) {
this.board = board;
this.postsId = postsId;
this.postsTitle = postsTitle;
this.postsContent = postsContent;
@@ -139,6 +138,17 @@ public class Posts extends BaseEntity {
this.deleteAt = deleteAt;
this.creator = creator;
this.comments = comments == null ? null : new ArrayList<>(comments);
setBoard(board);
}
/**
* 연관관계 설정
*
* @param board
*/
public void setBoard(Board board) {
this.board = board;
board.getPosts().add(this);
}
/**

View File

@@ -1,23 +1,9 @@
package org.egovframe.cloud.boardservice.service.posts;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import lombok.RequiredArgsConstructor;
import org.egovframe.cloud.boardservice.api.board.dto.BoardResponseDto;
import org.egovframe.cloud.boardservice.api.posts.dto.PostsDeleteRequestDto;
import org.egovframe.cloud.boardservice.api.posts.dto.PostsListResponseDto;
import org.egovframe.cloud.boardservice.api.posts.dto.PostsResponseDto;
import org.egovframe.cloud.boardservice.api.posts.dto.PostsSaveRequestDto;
import org.egovframe.cloud.boardservice.api.posts.dto.PostsSimpleResponseDto;
import org.egovframe.cloud.boardservice.api.posts.dto.PostsSimpleSaveRequestDto;
import org.egovframe.cloud.boardservice.api.posts.dto.PostsUpdateRequestDto;
import org.egovframe.cloud.boardservice.domain.posts.Posts;
import org.egovframe.cloud.boardservice.domain.posts.PostsId;
import org.egovframe.cloud.boardservice.domain.posts.PostsRead;
import org.egovframe.cloud.boardservice.domain.posts.PostsReadRepository;
import org.egovframe.cloud.boardservice.domain.posts.PostsRepository;
import org.egovframe.cloud.boardservice.api.posts.dto.*;
import org.egovframe.cloud.boardservice.domain.posts.*;
import org.egovframe.cloud.boardservice.service.board.BoardService;
import org.egovframe.cloud.common.dto.AttachmentEntityMessage;
import org.egovframe.cloud.common.dto.RequestDto;
@@ -32,6 +18,11 @@ import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.StringUtils;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/**
* org.egovframe.cloud.postsservice.service.posts.PostsService
* <p>
@@ -111,7 +102,6 @@ public class PostsService extends AbstractService {
board.setNewestPosts(posts.stream().map(post -> post.setIsNew(board))
.collect(Collectors.toList()));
}
data.put(board.getBoardNo(), board);
}