From b2bf222751b9bba2315f861c2c5a2511dad86626 Mon Sep 17 00:00:00 2001
From: 이민희 <mhlee@maprex.co.kr>
Date: 화, 23 11월 2021 21:34:43 +0900
Subject: [PATCH] 이력 남기기

---
 src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java |   69 ++++++++++++++++++++++++----------
 1 files changed, 48 insertions(+), 21 deletions(-)

diff --git a/src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java
index 1bb3151..ebf90a3 100644
--- a/src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java
+++ b/src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java
@@ -222,6 +222,12 @@
         //this.issueUserService.modifyIssueUser(issue, project.getWorkspace(), issueForm.getUserIds());
         //  �떞�떦遺��꽌 吏��젙
         this.issueDepartmentService.modifyIssueDepartment(issue, project.getWorkspace(), issueForm.getDepartmentIds());
+        //  �뾽泥� �젙蹂� ���옣
+        this.issueCompanyService.modifyIssueCompanyField(issue, issueForm.getIssueCompanyFields());
+        //  ISP �젙蹂� ���옣
+        this.issueIspService.modifyIssueIspField(issue, issueForm.getIssueIspFields());
+        //  HOSTING �젙蹂� ���옣
+        this.issueHostingService.modifyIssueHostingField(issue, issueForm.getIssueHostingFields());
 
         //  multipartFile �쓣 file Map List 媛앹껜濡� 蹂�寃쏀븳�떎.
         List<Map<String, Object>> convertFileMaps = this.convertMultipartFileToFile(multipartFiles);
@@ -241,12 +247,6 @@
         this.reservationIssueEmail(issue.getId(), EmailType.ISSUE_ADD);
         //  �궗�슜�옄 �떆�뒪�뀥 湲곕뒫 �궗�슜 �젙蹂� �닔吏�
         log.info(ElasticSearchUtil.makeUserActiveHistoryMessage(this.webAppUtil.getLoginUser(), ElasticSearchConstants.ISSUE_ADD));
-        //  �뾽泥� �젙蹂� ���옣
-        this.issueCompanyService.modifyIssueCompanyField(issue, issueForm.getIssueCompanyFields());
-        //  ISP �젙蹂� ���옣
-        this.issueIspService.modifyIssueIspField(issue, issueForm.getIssueIspFields());
-        //  HOSTING �젙蹂� ���옣
-        this.issueHostingService.modifyIssueHostingField(issue, issueForm.getIssueHostingFields());
 
         return issue;
     }
@@ -865,7 +865,6 @@
 
     }
 
-
     //  �긽�쐞�씪媛� �젙蹂� 異붽�
     private void setParentIssue(Issue issue, IssueVo issueVo) {
         if(issue.getParentIssue() != null){
@@ -1225,11 +1224,11 @@
         boolean hasPermission = false;
 
         //  �뾽臾� 怨듦컙 愿�由ъ옄�씪 寃쎌슦 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎.
-        hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.WORKSPACE_MANAGER, issueVo, null);
+        hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.WORKSPACE_MANAGER, issueVo, null, null);
         //  �봽濡쒖젥�듃 愿�由ъ옄�씪 寃쎌슦 �빐�떦 �봽濡쒖젥�듃�뿉 �벑濡앸맂 �씠�뒋�뒗 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎.
-        hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.PROJECT_MANAGER, issueVo, null);
+        hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.PROJECT_MANAGER, issueVo, null, null);
         //   �씠�뒋 �벑濡앹옄�씪 寃쎌슦 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎.
-        hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.REGISTER, issueVo, null);
+        hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.REGISTER, issueVo, null, null);
         //  �씠�뒋 �떞�떦�옄�씪 寃쎌슦 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎. => �떞�떦遺��꽌濡� �닔�젙 - 泥댄겕
         //hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.ASSIGNEE, issueVo, issueUserVos);
         //  �떞�떦�옄媛� �뾾�쑝硫� 紐⑤뱺 �궗�슜�옄媛� �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎.
@@ -1238,7 +1237,7 @@
     }
 
     //  �씠�뒋 �닔�젙 沅뚰븳�쓣 �솗�씤�븳�떎.
-    private boolean checkIssueModifyPermission(Boolean hasPermission, String checkType, IssueVo issueVo, List<UserVo> issueUserVos) {
+    private boolean checkIssueModifyPermission(Boolean hasPermission, String checkType, IssueVo issueVo, List<UserVo> issueUserVos, List<DepartmentVo> issueDepartmentVos) {
         if (!hasPermission) {
             switch (checkType) {
                 case Issue.WORKSPACE_MANAGER:  //  �뾽臾� 怨듦컙 愿�由ъ옄
@@ -1262,15 +1261,28 @@
                         hasPermission = true;
                         break;
                     }
-
-                    //   �씠�뒋 �떞�떦�옄 �뿬遺� �솗�씤 => �떞�떦遺��꽌濡� �닔�젙 - 泥댄겕
-                    /*for (UserVo issueUserVo : issueUserVos) {
+                    //   �씠�뒋 �떞�떦�옄 �뿬遺� �솗�씤
+                    for (UserVo issueUserVo : issueUserVos) {
                         if (issueUserVo.getId().equals(this.webAppUtil.getLoginId())) {
                             hasPermission = true;
                             break;
                         }
-                    }*/
+                    }
+                    break;
 
+                case Issue.DEPARTMENT:
+                    //  �떞�떦遺��꽌媛� �뾾�쑝硫� 紐⑤뱺 �궗�슜�옄媛� �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎.
+                    if (issueDepartmentVos.size() < 1) {
+                        hasPermission = true;
+                        break;
+                    }
+                    //   �씠�뒋 �떞�떦遺��꽌 �뿬遺� �솗�씤
+                    /*for (DepartmentVo issueDepartmentVo : issueDepartmentVos) {
+                        if (issueDepartmentVo.getId().equals()) {
+                            hasPermission = true;
+                            break;
+                        }
+                    }*/
                     break;
             }
         }
@@ -1373,7 +1385,7 @@
         issue.setProject(this.projectService.getProject(issueForm.getProjectId()));
 
         //  蹂�寃� �씠�젰 �젙蹂� 異붿텧
-        this.issueHistoryService.detectIssueManager(issue, issueForm, detectIssueChange);
+        this.issueHistoryService.detectIssueDepartment(issue, issueForm, detectIssueChange);
 
         //this.issueUserService.modifyIssueUser(issue, issue.getProject().getWorkspace(), issueForm.getUserIds());
         this.issueDepartmentService.modifyIssueDepartment(issue, issue.getProject().getWorkspace(), issueForm.getDepartmentIds());
@@ -1982,6 +1994,7 @@
             Map<String, Long> issueRiskMap = new HashMap<>();
             issueRiskMap.put("issueId", issueForm.getId());
             issueRiskMap.put("changeAssigneeCount", 0L);
+            issueRiskMap.put("changeDepartmentCount", 0L);
             issueRiskMap.put("changeIssueStatusCount", 0L);
             issueRiskMap.put("workspaceId", workspace.getId());
             issueRiskMap.put("issueStatusIds", issueForm.getIssueStatusId());
@@ -2613,16 +2626,30 @@
 
     @Transactional
     @Override
-    public void modifyParentIssue(IssueForm issueForm) {
-        Issue issue = this.issueRepository.getOne(issueForm.getId());
-        Long parentIssueId = issueForm.getParentIssueId();
-        if (parentIssueId != null) {
-            Issue parentIssue = this.issueRepository.getOne(parentIssueId);
+    public void modifyParentIssue(IssueForm issueDownForm) {
+        System.out.println(issueDownForm.getTitle());
+        Issue issue = this.getIssue(issueDownForm.getId());
+        Issue parentIssue = issue.getParentIssue();
+
+        Long newParentIssueId = issueDownForm.getParentIssueId();
+        StringBuilder sb = new StringBuilder();
+
+        IssueHistoryType type =  IssueHistoryType.ADD;
+        if (newParentIssueId != null) {
+           // todo �씠�쟾 �븯�쐞 �씪媛� �엳�뒪�넗由ш린濡� �븘�슂
+            type = IssueHistoryType.ADD;
+            parentIssue = this.getIssue(newParentIssueId);
             issue.setParentIssue(parentIssue);
+            this.issueHistoryService.detectDownIssues(type, issue, sb);
         } else  {
+            // remove
+            type = IssueHistoryType.DELETE;
+            this.issueHistoryService.detectDownIssues(type, issue, sb);
             issue.setParentIssue(null);
         }
 
+        this.issueHistoryService.addIssueHistory(parentIssue, IssueHistoryType.MODIFY, sb.toString());
         this.issueRepository.saveAndFlush(issue);
+
     }
 }

--
Gitblit v1.8.0