OWL ITS + 탐지시스템(인터넷 진흥원)
이민희
2022-01-26 893c062eb572b55a7dd2ef9c5fac02bad3646959
- 섬머노트 사진/동영상 버튼 삭제
- 이슈 파트너 메일에 첨부파일 추가
8개 파일 변경됨
229 ■■■■■ 파일 변경됨
src/main/java/kr/wisestone/owl/service/IssueService.java 2 ●●● 패치 | 보기 | raw | blame | 히스토리
src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java 4 ●●●● 패치 | 보기 | raw | blame | 히스토리
src/main/java/kr/wisestone/owl/service/impl/SystemEmailServiceImpl.java 2 ●●● 패치 | 보기 | raw | blame | 히스토리
src/main/java/kr/wisestone/owl/web/controller/IssueController.java 6 ●●●● 패치 | 보기 | raw | blame | 히스토리
src/main/webapp/custom_components/summernote/summernote.js 4 ●●●● 패치 | 보기 | raw | blame | 히스토리
src/main/webapp/scripts/app/issue/issueSendMailPartners.controller.js 157 ●●●●● 패치 | 보기 | raw | blame | 히스토리
src/main/webapp/scripts/components/issue/issue.service.js 7 ●●●● 패치 | 보기 | raw | blame | 히스토리
src/main/webapp/views/issue/issueSendMailPartners.html 47 ●●●●● 패치 | 보기 | 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>