From 5fec5801b937a2270920787891e39a8504cdf53f Mon Sep 17 00:00:00 2001 From: wyu <kknd09321@nate.com> Date: 금, 03 12월 2021 15:00:44 +0900 Subject: [PATCH] 사용자 정의 필드 사용중일때 삭제 불가하게 수정 --- src/main/java/kr/wisestone/owl/service/impl/CustomFieldServiceImpl.java | 46 ++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 38 insertions(+), 8 deletions(-) diff --git a/src/main/java/kr/wisestone/owl/service/impl/CustomFieldServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/CustomFieldServiceImpl.java index 391ffcf..31af4eb 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/CustomFieldServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/CustomFieldServiceImpl.java @@ -11,6 +11,7 @@ import kr.wisestone.owl.exception.OwlRuntimeException; import kr.wisestone.owl.mapper.CustomFieldMapper; import kr.wisestone.owl.repository.CustomFieldRepository; +import kr.wisestone.owl.repository.IssueTypeCustomFieldRepository; import kr.wisestone.owl.service.*; import kr.wisestone.owl.util.ConvertUtil; import kr.wisestone.owl.util.MapUtil; @@ -45,6 +46,9 @@ @Autowired private CustomFieldRepository customFieldRepository; + + @Autowired + private IssueTypeCustomFieldRepository issueTypeCustomFieldRepository; @Autowired private CustomFieldMapper customFieldMapper; @@ -126,8 +130,8 @@ // �샃�뀡 媛� �쑀�슚 泥댄겕 private void verifyOptions(CustomFieldForm customFieldForm) { - // �궗�슜�옄 �젙�쓽 �븘�뱶 �쑀�삎�씠 �뀓�뒪�듃 �씪�븣�뒗 �샃�뀡 媛믪씠 議댁옱�븯硫� �븞�맂�떎. - if (CustomFieldType.valueOf(customFieldForm.getCustomFieldType()).equals(CustomFieldType.INPUT)) { + // �궗�슜�옄 �젙�쓽 �븘�뱶 �쑀�삎�씠 �뀓�뒪�듃 �씪�븣�뒗 �샃�뀡 媛믪씠 議댁옱�븯硫� �븞�맂�떎. => �떒�씪�꽑�깮 �삉�뒗 �떎以묒꽑�깮 �븘�뱶媛� �븘�땺 寃쎌슦 �샃�뀡 媛� 議댁옱 �븯硫� �븞�릺�뒗 寃껋쑝濡� 蹂�寃� + if (!CustomFieldType.valueOf(customFieldForm.getCustomFieldType()).equals(CustomFieldType.MULTI_SELECT) && !CustomFieldType.valueOf(customFieldForm.getCustomFieldType()).equals(CustomFieldType.SINGLE_SELECT)) { if (customFieldForm.getOptions().size() > 0) { throw new OwlRuntimeException( this.messageAccessor.getMessage(MsgConstants.CUSTOM_FIELD_OPTIONS_NOT_USE_INPUT_FIELD)); @@ -163,7 +167,6 @@ } // 湲곕낯 媛믪쑝濡� 吏��젙�븳 媛믪씠 �샃�뀡�뿉 �엳�뒗吏� �솗�씤�븳�떎. this.verifyOptionsDefaultValue(customFieldForm); - break; case MULTI_SELECT: // 湲곕낯 媛믪쑝濡� 吏��젙�븳 媛믪씠 �샃�뀡�뿉 �엳�뒗吏� �솗�씤�븳�떎. @@ -287,9 +290,9 @@ // �궗�슜�옄 �젙�쓽 �븘�뱶 �쑀�삎�씠 �떒�씪, �떎以� �꽑�깮�뿉�꽌 臾몄옄�뿴濡� 蹂�寃쎈맆 寃쎌슦 �궗�슜�옄 �젙�쓽 �븘�뱶 媛믪쓣 珥덇린�솕�븳�떎. private void checkChangeCustomFieldType(CustomFieldForm customFieldForm, CustomField customField) { - if (!customField.getCustomFieldType().equals(CustomFieldType.INPUT)) { + if (customField.getCustomFieldType().equals(CustomFieldType.MULTI_SELECT) || customField.getCustomFieldType().equals(CustomFieldType.SINGLE_SELECT)) { // �떒�씪, �떎以� �꽑�깮�뿉�꽌 臾몄옄�뿴 �븘�뱶濡� 蹂�寃쎈맂 寃쎌슦 - if (CustomFieldType.valueOf(customFieldForm.getCustomFieldType()).equals(CustomFieldType.INPUT)) { + if (!CustomFieldType.valueOf(customFieldForm.getCustomFieldType()).equals(CustomFieldType.MULTI_SELECT) && !CustomFieldType.valueOf(customFieldForm.getCustomFieldType()).equals(CustomFieldType.SINGLE_SELECT)) { customField.getCustomFieldValues().clear(); } } @@ -302,7 +305,6 @@ throw new OwlRuntimeException( this.messageAccessor.getMessage(MsgConstants.CUSTOM_FIELD_NOT_EXIST)); } - CustomField customField = this.findOne(id); @@ -320,10 +322,18 @@ public void removeCustomFields(CustomFieldForm customFieldForm) { // �궗�슜�븯怨� �엳�뒗 �뾽臾� 怨듦컙�씠 �솢�꽦 �긽�깭�씤吏� �솗�씤�븳�떎. �궗�슜 怨듦컙�뿉�꽌 濡쒓렇�씤�븳 �궗�슜�옄媛� 鍮꾪솢�꽦�씤吏� �솗�씤�븳�떎. this.workspaceService.checkUseWorkspace(); - - if (customFieldForm.getRemoveIds().size() < 1) { + List<Long> removeIds = customFieldForm.getRemoveIds(); + if (removeIds.size() < 1) { throw new OwlRuntimeException( this.messageAccessor.getMessage(MsgConstants.CUSTOM_FIELD_REMOVE_NOT_SELECT)); + }else { + for (Long id : removeIds) { + Long count = this.issueTypeCustomFieldRepository.countByCustomFieldId(id); + if (count > 0){ + throw new OwlRuntimeException( + this.messageAccessor.getMessage(MsgConstants.CUSTOM_FIELD_USED_DATA_REMOVE)); + } + } } for (Long projectId : customFieldForm.getRemoveIds()) { @@ -331,6 +341,7 @@ } // this.customFieldRepository.flush(); + this.customFieldRepository.flush(); } private void removeCustomFields(Long customFieldId) { @@ -338,6 +349,7 @@ customField.setUse(UseType.N.toString()); this.customFieldRepository.saveAndFlush(customField); // this.customFieldRepository.delete(customField); + this.customFieldRepository.delete(customField); } // �씠�뒋 �뿊�� import �뿉�꽌 �궗�슜�븳�떎. @@ -383,6 +395,24 @@ case "MULTI_SELECT" : customFieldTypeName = this.messageAccessor.message("common.multipleSelectionField"); // �떎以� �꽑�깮 �븘�뱶 break; + case "NUMBER" : + customFieldTypeName = this.messageAccessor.message("common.numberField"); // �닽�옄 �븘�뱶 + break; + case "DATETIME" : + customFieldTypeName = this.messageAccessor.message("common.datetimeField"); // �궇吏� �븘�뱶 + break; + case "IP_ADDRESS" : + customFieldTypeName = this.messageAccessor.message("common.ipAddressField"); // IP 二쇱냼 �븘�뱶 + break; + case "EMAIL" : + customFieldTypeName = this.messageAccessor.message("common.emailField"); // �씠硫붿씪 �븘�뱶 + break; + case "SITE" : + customFieldTypeName = this.messageAccessor.message("common.siteField"); // �솃�럹�씠吏� 二쇱냼 �븘�뱶 + break; + case "TEL" : + customFieldTypeName = this.messageAccessor.message("common.telField"); // �쟾�솕踰덊샇 �븘�뱶 + break; } } -- Gitblit v1.8.0