From ebfd37816a332308519b30af5bfb017c5052be69 Mon Sep 17 00:00:00 2001
From: 이민희 <mhlee@maprex.co.kr>
Date: 목, 13 1월 2022 17:34:35 +0900
Subject: [PATCH] Merge branch 'master' of http://192.168.0.25:9001/r/owl-kisa

---
 src/main/java/kr/wisestone/owl/service/impl/IssueIspServiceImpl.java |   64 +++++++++++++++++++++++++------
 1 files changed, 51 insertions(+), 13 deletions(-)

diff --git a/src/main/java/kr/wisestone/owl/service/impl/IssueIspServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/IssueIspServiceImpl.java
index 9d2f7be..c5203db 100644
--- a/src/main/java/kr/wisestone/owl/service/impl/IssueIspServiceImpl.java
+++ b/src/main/java/kr/wisestone/owl/service/impl/IssueIspServiceImpl.java
@@ -1,12 +1,15 @@
 package kr.wisestone.owl.service.impl;
 
 import kr.wisestone.owl.domain.*;
+import kr.wisestone.owl.domain.enumType.IssueHistoryType;
 import kr.wisestone.owl.mapper.IssueIspMapper;
 import kr.wisestone.owl.repository.IssueIspRepository;
 import kr.wisestone.owl.service.*;
 import kr.wisestone.owl.util.ConvertUtil;
 import kr.wisestone.owl.util.MapUtil;
 import kr.wisestone.owl.web.condition.IssueCondition;
+import kr.wisestone.owl.web.form.IspFieldForm;
+import kr.wisestone.owl.web.form.IssueForm;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -28,6 +31,9 @@
     private IspFieldService ispFieldService;
 
     @Autowired
+    private IssueHistoryService issueHistoryService;
+
+    @Autowired
     private IssueIspMapper issueIspMapper;
 
     @Override
@@ -38,36 +44,68 @@
     //  �씠�뒋�뿉�꽌 �궗�슜�릺�뒗 �뾽泥� 媛믪쓣 �뾽�뜲�씠�듃�븳�떎.
     @Override
     @Transactional
-    public void modifyIssueIspField(Issue issue, List<Map<String, Object>> issueIspFields) {
+    public void modifyIssueIspField(Issue issue, IssueForm issueForm) {
         if (issue != null) {
+            List<Map<String, Object>> issueIspFields = issueForm.getIssueIspFields();
             if (issueIspFields != null && issueIspFields.size() > 0) {
                 Map<String, Object> param = issueIspFields.get(0);
 
-                if (param != null) {
+                if (param != null && param.get("ispId") != null  && param.get("ispId") != "") {
                     IspField ispField = this.ispFieldService.getIsp(MapUtil.getLong(param, "ispId"));
 
                     Set<IssueIsp> issueIsps = issue.getIssueIspFields();
-                    if (issueIsps != null && issueIsps.size() > 0) {
-                        IssueIsp issueIsp = issueIsps.iterator().next();
+                    IssueIsp issueIsp = new IssueIsp();
+                    if (issueIsps != null && issueIsps.size() > 0) {//�닔�젙 �븷 寃쎌슦
+                        issueIsp = issueIsps.iterator().next();
+                        // 蹂�寃� �씠�젰
+                        StringBuilder sb = new StringBuilder();
+                        issueHistoryService.detectIssueIsp(IssueHistoryType.MODIFY, param, null, issueIsp, sb);
+                        issueHistoryService.addIssueHistory(issue, IssueHistoryType.MODIFY, sb.toString());
 
                         issueIsp.setIspField(ispField);
                         issueIsp.setName(MapUtil.getString(param, "name"));
                         issueIsp.setEmail(MapUtil.getString(param, "email"));
                         issueIsp.setCode(MapUtil.getString(param, "code"));
+                        issueIsp.setUrl(MapUtil.getString(param, "url"));
                         issueIsp.setManager(MapUtil.getString(param, "manager"));
                         issueIsp.setTel(MapUtil.getString(param, "tel"));
                         issueIsp.setMemo(MapUtil.getString(param, "memo"));
-
-                        this.issueIspRepository.saveAndFlush(issueIsp);
-
-                    } else  {
-                        IssueIsp newIssueIsp = ConvertUtil.convertMapToClass(param, IssueIsp.class);
-                        newIssueIsp.setIssue(issue);
-                        newIssueIsp.setIspField(ispField);
-
-                        this.issueIspRepository.saveAndFlush(newIssueIsp);
+                    } else  {//異붽� �븷 寃쎌슦
+                        issueIsp = ConvertUtil.convertMapToClass(param, IssueIsp.class);
+                        issueIsp.setIssue(issue);
+                        if (ispField != null) {
+                            issueIsp.setIspField(ispField);
+                        }
+                        // 異붽� �씠�젰
+                        StringBuilder sb = new StringBuilder();
+                        issueHistoryService.detectIssueIsp(IssueHistoryType.ADD, param, null, issueIsp, sb);
+                        issueHistoryService.addIssueHistory(issue, IssueHistoryType.MODIFY, sb.toString());
                     }
+                    this.issueIspRepository.saveAndFlush(issueIsp);
+                }else {
+                    this.issueIspRepository.deleteById(MapUtil.getLong(param, "id"));
                 }
+            } else if(issueForm.getIspName() != null && !issueForm.getIspName().equals("")) {
+                IspFieldForm ispFieldForm = new IspFieldForm();
+                ispFieldForm.setName(issueForm.getIspName());
+                ispFieldForm.setCode(issueForm.getIspCode());
+                ispFieldForm.setEmail(issueForm.getIspEmail());
+                ispFieldForm.setUrl(issueForm.getIspUrl());
+                ispFieldForm.setManager(issueForm.getIspManager());
+                ispFieldForm.setTel(issueForm.getIspTel());
+                ispFieldForm.setMemo(issueForm.getIspMemo());
+
+                IspField ispField = this.ispFieldService.add(ispFieldForm);
+                IssueIsp issueIsp = ConvertUtil.copyProperties(ispFieldForm, IssueIsp.class);
+                issueIsp.setIssue(issue);
+                if (ispField != null) {
+                    issueIsp.setIspField(ispField);
+                }
+                // 異붽� �씠�젰
+                StringBuilder sb = new StringBuilder();
+                issueHistoryService.detectIssueIsp(IssueHistoryType.ADD, null, ispField, issueIsp, sb);
+                issueHistoryService.addIssueHistory(issue, IssueHistoryType.MODIFY, sb.toString());
+                this.issueIspRepository.saveAndFlush(issueIsp);
             }
         }
     }

--
Gitblit v1.8.0