src/main/java/kr/wisestone/owl/service/IssueService.java | ●●●●● 패치 | 보기 | raw | blame | 히스토리 | |
src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java | ●●●●● 패치 | 보기 | raw | blame | 히스토리 | |
src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java | ●●●●● 패치 | 보기 | raw | blame | 히스토리 | |
src/main/java/kr/wisestone/owl/web/controller/IssueController.java | ●●●●● 패치 | 보기 | raw | blame | 히스토리 | |
src/main/webapp/custom_components/summernote/summernote.js | ●●●●● 패치 | 보기 | raw | blame | 히스토리 | |
src/main/webapp/scripts/app/issue/issueSendMailPartners.controller.js | ●●●●● 패치 | 보기 | raw | blame | 히스토리 | |
src/main/webapp/scripts/components/issue/issue.service.js | ●●●●● 패치 | 보기 | raw | blame | 히스토리 | |
src/main/webapp/views/issue/issueSendMailPartners.html | ●●●●● 패치 | 보기 | raw | blame | 히스토리 |
src/main/java/kr/wisestone/owl/service/IssueService.java
@@ -96,7 +96,7 @@ void sendIssueEmail(IssueForm issueForm); void sendIssueEmailPartners(EmailTemplateForm emailTemplateForm); void sendIssueEmailPartners(EmailTemplateForm emailTemplateForm, List<MultipartFile> files); void reservationIssue(); src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java
@@ -3842,7 +3842,7 @@ // 이슈를 템플릿에 따라 파트너 담당자에게 메일로 발송한다. @Override @Transactional(readOnly = true) public void sendIssueEmailPartners(EmailTemplateForm emailTemplateForm) { public void sendIssueEmailPartners(EmailTemplateForm emailTemplateForm, List<MultipartFile> multipartFiles) { if (emailTemplateForm.getSendEmails().size() < 1) { throw new OwlRuntimeException( this.messageAccessor.getMessage(MsgConstants.ISSUE_NOT_SEND_USER)); @@ -3869,7 +3869,7 @@ for(int i=0; i < sendMails.length; i++) { sendMails[i] = CommonUtil.decryptAES128(sendMails[i]); } this.systemEmailService.sendEmail(emailTemplateForm.getTitle(), emailTemplateForm.getTemplate(), sendMails, null, null); this.systemEmailService.sendEmail(emailTemplateForm.getTitle(), emailTemplateForm.getTemplate(), sendMails, null, multipartFiles); this.issueHistoryService.detectSendIssueMail(IssueHistoryType.SEND, emailTemplateForm.getSendEmails(), sb); this.issueHistoryService.addIssueHistory(issue, IssueHistoryType.SEND, sb.toString()); src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java
@@ -276,7 +276,7 @@ if (multipartFiles != null && multipartFiles.size() > 0) { for (MultipartFile file : multipartFiles) { // 파일 첨부 messageHelper.addAttachment(file.getOriginalFilename(), file); messageHelper.addAttachment(MimeUtility.encodeText(file.getOriginalFilename(), "utf-8", "B"), file); } } src/main/java/kr/wisestone/owl/web/controller/IssueController.java
@@ -236,12 +236,12 @@ } // 이슈 메일 파트너 담당자에게 발송 (템플릿 추가) @RequestMapping(value = "/issue/sendEmailPartners", produces = MediaType.APPLICATION_JSON_VALUE) @RequestMapping(value = "/issue/sendEmailPartners", method = RequestMethod.POST) public @ResponseBody Map<String, Object> sendEmailPartners(@RequestBody Map<String, Map<String, Object>> params) { Map<String, Object> sendEmailPartners(MultipartHttpServletRequest request) { Map<String, Object> resJsonData = new HashMap<>(); this.issueService.sendIssueEmailPartners(EmailTemplateForm.make(params.get(Constants.REQ_KEY_CONTENT))); this.issueService.sendIssueEmailPartners(EmailTemplateForm.make(ConvertUtil.convertJsonToMap(request.getParameter(Constants.REQ_KEY_CONTENT))), request.getFiles("file")); // this.issueService.sendIssueEmailPartners(IssueForm.make(params.get(Constants.REQ_KEY_CONTENT))); return this.setSuccessMessage(resJsonData); } src/main/webapp/custom_components/summernote/summernote.js
@@ -5679,7 +5679,7 @@ }).render(); }); context.memo('button.picture', function () { /*context.memo('button.picture', function () { return ui.button({ contents: ui.icon(options.icons.picture), tooltip: lang.image.image, @@ -5693,7 +5693,7 @@ tooltip: lang.video.video, click: context.createInvokeHandler('videoDialog.show') }).render(); }); });*/ context.memo('button.hr', function () { return ui.button({ src/main/webapp/scripts/app/issue/issueSendMailPartners.controller.js
@@ -17,7 +17,10 @@ formCheck : formCheck, // 폼 체크 onChangeEmailTemplate : onChangeEmailTemplate, // 이메일 템플릿 선택시 실행 getEmailTemplateList : getEmailTemplateList, // 이메일 템플릿 목록 가져오기 getAccount : getAccount getAccount : getAccount, onFileSelect : onFileSelect, // 파일 첨부 removeUploadFile : removeUploadFile, // 업로드하려는 특정 파일을 삭제 imageUpload : imageUpload, // 섬머노트 이미지 업로드 }; $scope.vm = { @@ -32,6 +35,8 @@ projects : [{ id : parameter.projectId}], // 프로젝트 mailUsers : parameter.partners.slice(), // 메일 전송받는 사용자 account : [{account : [], name : [], id : []}], files : [], // 업로드 파일 attachedFiles : [], // 섬머노트로 파일 업로드를 할 경우 서버에서 pk를 따고 issue id와 연동 작업이 필요하다. }, userName : "", autoCompletePage : { @@ -97,6 +102,132 @@ } } // 섬머노트 이미지 업로드 function imageUpload($files) { var listFiles = []; var uploadFileSize = 0; for (var count in $files) { var $file = $files[count]; if (typeof ($file) == "object") { uploadFileSize += $file.size; // 파일당 용량 제한 10MB if ($file.size > $rootScope.fileByte.image) { SweetAlert.error($filter("translate")("issue.capacityExceededImageFile"), $filter("translate")("issue.attachedOnlyImageFiles10mb")); // "이미지 파일 용량 초과", "10MB 이하의 이미지 파일만 첨부가 가능합니다." listFiles = []; break; } // 여러건의 파일을 한번에 업로드할 경우 제한 300MB if (uploadFileSize > $rootScope.fileByte.file) { SweetAlert.error($filter("translate")("issue.capacityExceededImageFile"), $filter("translate")("issue.attachedMultipleImageFiles100mb")); // "이미지 파일 용량 초과", "여러 건의 이미지를 한번에 첨부할 경우 100MB 이하까지만 첨부가 가능합니다." listFiles = []; break; } if (!$rootScope.checkImageType($file)) { SweetAlert.error($filter("translate")("issue.limitImageFile"), $filter("translate")("issue.canBeUploadedOnlyImageFiles")); // "이미지 파일 제한", "이미지 파일만 업로드 가능합니다. - bmp, jpg, jpeg, png, tif" listFiles = []; break; } if (!angular.isDefined($file.name)) { var fileType = $file.type.split("/"); var imageType = ""; if (fileType[0] === "image") { imageType = "." + fileType[1]; } $file.name = new Date().getTime() + imageType; } else { if ($file.name.indexOf(';') !== -1) { SweetAlert.error($filter("translate")("issue.nameErrorImageFile"), $filter("translate")("issue.cannotUploadFileNameSpecialCharacters")); // "이미지 파일명 오류", "파일명에 특수문자(;)가 들어가면 업로드 할 수 없습니다." listFiles = []; break; } } listFiles.push($file); } } // 파일 업로드 검증을 거친 파일이 1개이상 존재할 경우에만 실행 if (listFiles.length > 0) { AttachedFile.add({ method : "POST", file : listFiles, // data 속성으로 별도의 데이터 전송 fields : { content : { workspaceId : $rootScope.user.lastWorkspaceId } }, fileFormDataName : "file" }) .then(function (result) { if (result.data.message.status === "success") { angular.forEach(result.data.attachedFiles, function (fileInfo) { $scope.vm.summerNote.editor.summernote("editor.insertImage", fileInfo.path); $scope.vm.form.attachedFiles.push(fileInfo); }); } else { SweetAlert.error($filter("translate")("issue.errorFileUpload"), result.data.message.message); // 파일 업로드 오류 } }); } } // 파일 업로드에 사용 function onFileSelect($files) { var uploadFileSize = 0; // 이전에 첨부한 파일이 있을 경우 전체 업로드 용량에 포함 angular.forEach($scope.vm.form.files, function ($file) { uploadFileSize += $file.size; }); for (var count in $files) { var $file = $files[count]; if (typeof ($file) == "object") { uploadFileSize += $file.size; // 파일당 용량 제한 300MB if (($file.size > $rootScope.fileByte.file) || (uploadFileSize > $rootScope.fileByte.file)) { SweetAlert.error($filter("translate")("issue.attachmentCapacityExceeded"), $filter("translate")("issue.canAttachFileUpTo100mb")); // "첨부 파일 용량 초과", "100MB 이하까지만 파일 첨부가 가능합니다." break; } // 파일을 업로드할 때 파일 유형을 확인해주는 기능 - 허용되지 않은 확장자일 때는 첨부 금지 if (!$rootScope.checkFileType($file)) { SweetAlert.error($filter("translate")("issue.limitAttachmentExtensions"), $filter("translate")("issue.notAllowedAttachment")); // "첨부 파일 확장자 제한", "첨부가 허용되지 않는 파일입니다." break; } if ($file.name.indexOf(';') !== -1) { SweetAlert.error($filter("translate")("issue.nameErrorAttachment"), $filter("translate")("issue.cannotUploadFileNameSpecialCharacters")); // "첨부 파일명 오류", "파일명에 특수문자(;)가 들어가면 업로드 할 수 없습니다." break; } $file.index = count; $scope.vm.form.files.push($file); } } } // 업로드 파일 삭제 function removeUploadFile(index) { $scope.vm.form.files.splice(index, 1); angular.forEach($scope.vm.form.files, function (file, index) { file.index = index; }); } // 사용자 삭제 function removeMailTarget(index) { @@ -134,12 +265,28 @@ return sendEmails; })(), attachedFileIds : (function () { var attachedFileIds = []; angular.forEach($scope.vm.form.attachedFiles, function (attachedFile) { if ($scope.vm.form.description.indexOf(attachedFile.path) !== -1) { attachedFileIds.push(attachedFile.id); } }); return attachedFileIds; })(), }; Issue.sendEmailPartners($resourceProvider.getContent( content, $resourceProvider.getPageContent(0, 10))).then(function (result) { Issue.sendEmailPartners({ method : "POST", file : $scope.vm.form.files, // data 속성으로 별도의 데이터 전송 fields : { content : content }, fileFormDataName : "file" }).then(function (result) { if (result.data.message.status === "success") { SweetAlert.success($filter("translate")("issue.succeededIssueMail"), $filter("translate")("issue.sentToTheSelectedUser")); // "이슈 메일 발송 완료" $scope.fn.cancel(); src/main/webapp/scripts/components/issue/issue.service.js
@@ -140,7 +140,11 @@ }); }, sendEmailPartners : function (conditions) { return $http.post("issue/sendEmailPartners", conditions).then(function (response) { conditions.url = "issue/sendEmailPartners"; return $upload.upload(conditions).progress(function (evt) { // 파일 업로드 진행율을 표시해준다. fileUploadProgress(evt); }).then(function (response) { $log.debug("이슈 이메일 발송 결과 : ", response); return response; }); @@ -150,7 +154,6 @@ return $upload.upload(conditions).progress(function (evt) { // 파일 업로드 진행율을 표시해준다. fileUploadProgress(evt); }).then(function (response) { $log.debug("이슈 이메일 발송 결과 : ", response); return response; src/main/webapp/views/issue/issueSendMailPartners.html
@@ -76,6 +76,53 @@ ng-model="vm.html" target=".note-editable"></summernote> </div> <div class="form-group mgb5 mt-10"> <label class="issue-label"><span translate="common.attachFiles">파일 첨부</span></label> <div class="filebox input-group"> <input class="upload-name form-control" placeholder="{{'users.pleaseSelectFile' | translate}}" tabindex="-1" disabled="disabled"> <label for="uploadFileField"><span translate="common.selectFile">파일선택</span></label> <input id="uploadFileField" tabindex="-1" type="file" class="form-control" multiple ng-file-select="fn.onFileSelect($files)"> </div> <div class="select2-selection__choicediv"> <div class="select2-selection__choice2" ng-repeat="file in vm.form.files"> <div class="select2-selection__choice2__remove" ng-click="fn.removeUploadFile($index)"> × </div> <div class="ssg-items ssg-items-blocks"> <div class="ssg-item"> <div class="item-icon"> <!-- 문서 --> <i class="os-icon os-icon-file-text" ng-if="file.fileType == 'DOC'"></i> <!-- 미디어 --> <i class="os-icon os-icon-film" ng-if="file.fileType == 'MEDIA'"></i> <!-- 이미지(업로드 전) --> <i class="os-icon os-icon-documents-07" ng-if="file.fileType == 'IMAGE'"></i> <!-- 기타 --> <i class="os-icon os-icon-ui-51" ng-if="file.fileType == 'ETC'"></i> </div> <div class="item-name"> <small>{{file.name}}</small> </div> <div class="item-amount"> ({{file.size/1024/1024 | number:2}} MB) </div> </div> </div> </div> </div> </div> </div> </form> </div>