'use strict'; define([ 'app', 'angular' ], function (app, angular) { app.controller('issueSendMailPartnersController', ['$scope', '$rootScope', '$q','$log', '$resourceProvider', '$uibModalInstance', '$controller', '$injector', 'SweetAlert', '$filter', 'parameter', 'Issue', function ($scope, $rootScope, $q, $log, $resourceProvider, $uibModalInstance, $controller, $injector, SweetAlert, $filter, parameter, Issue) { $scope.fn = { getUserListCallBack : getUserListCallBack, // 사용자 auto complete callback function cancel : cancel, // 팝업 창 닫기 getMails : getMails, removeMailTarget : removeMailTarget, formSubmit : formSubmit, // 폼 전송 formCheck : formCheck, // 폼 체크 changeTemplate : changeTemplate, // showEmailTemplate : showEmailTemplate, }; $scope.vm = { companyVos : parameter.companyVos, ispVos : parameter.ispVos, hostingVos : parameter.hostingVos, partners : parameter.partnersAll.slice(), form : { id : parameter.issueId, // 이슈 번호 template : "ISSUE_SEND_2", projects : [{ id : parameter.projectId}], // 프로젝트 mailUsers : parameter.partners.slice() // 메일 전송받는 사용자 }, userName : "", autoCompletePage : { user : { page : 0, totalPage : 0 } } }; angular.extend(this, $controller('autoCompleteController', {$scope : $scope, $injector : $injector})); // 사용자 삭제 function removeMailTarget(index) { $scope.vm.form.mailUsers.splice(index, 1); } function formCheck(formInvalid) { if (formInvalid) { return true; } if ($scope.vm.form.mailUsers.length < 1) { return true; } return false; } // 업체/ISP/호스팅 이메일 폼 전송 function formSubmit() { $rootScope.spinner = true; var content = { id : $scope.vm.form.id, template : $scope.vm.form.template, sendEmails : (function () { var sendEmails = []; angular.forEach($scope.vm.form.mailUsers, function (user) { sendEmails.push($rootScope.encryption(user.account)); }); return sendEmails; })(), }; Issue.sendEmailPartners($resourceProvider.getContent( content, $resourceProvider.getPageContent(0, 10))).then(function (result) { if (result.data.message.status === "success") { SweetAlert.success($filter("translate")("issue.succeededIssueMail"), $filter("translate")("issue.sentToTheSelectedUser")); // "이슈 메일 발송 완료" $scope.fn.cancel(); $rootScope.$broadcast("getIssueDetail", {id: $rootScope.currentDetailIssueId}); } else { SweetAlert.error($filter("translate")("issue.failedIssueMail"), result.data.message.message); // "이슈 메일 발송 실패" } $rootScope.spinner = false; }); } // 사용자 auto complete callback function function getUserListCallBack(result) { $scope.vm.autoCompletePage.user.totalPage = result.data.page.totalPage; } function cancel() { $rootScope.$broadcast("closeLayer"); // 팝업이 열리고 나서 js-multi, js-single 등에서 body 이벤트가 날아가는 현상 수정 $uibModalInstance.dismiss('cancel'); $(document).unbind("keydown"); // 단축키 이벤트 제거 } function getMails(excludeList) { var deferred = $q.defer(); var partners = []; if (excludeList != null && excludeList.length > 0) { $scope.vm.partners.forEach(function (partner) { excludeList.forEach(function (exclude) { if (partner.id !== exclude.id) { partners.push(partner); } }); }); } else { partners = $scope.vm.partners; } deferred.resolve(partners); return deferred.promise; } function changeTemplate(templateId){ $scope.vm.form.template = templateId; var elements = document.getElementsByClassName("TemplateIMG"); for (let i = elements.length - 1; i >= 0; i--) { if (elements[i].id === templateId) { elements[i].className += " TemplateIMG-selected"; } else { elements[i].className = "TemplateIMG"; } } const div1 = document.getElementById('Email-Template1'); const div2 = document.getElementById('Email-Template2'); const div3 = document.getElementById('Email-Template3'); const div4 = document.getElementById('Email-Template4'); if(div1.style.display === 'none' && div4.style.display === 'none') { div1.style.display = 'block'; div4.style.display = 'block'; } else if (div1.style.display === 'block' && div4.style.display === 'block') { div1.style.display = 'none'; div4.style.display = 'none'; } if (div2.style.display === 'none' && div4.style.display === 'none') { div2.style.display = 'block'; div4.style.display = 'block' } else if (div2.style.display === 'block' && div4.style.display === 'block'){ div2.style.display = 'none'; div4.style.display = 'none' } if (div3.style.display == 'none' && div4.style.display === 'none') { div3.style.display = 'block'; div4.style.display = 'block'; } else if (div3.style.display === 'block' && div4.style.display === 'block'){ div3.style.display = 'none'; div4.style.display = 'none'; } if (div4.style.display == 'none' || div4.style.display === 'block') { div4.style.display = 'block'; } else { div4.style.display = 'none'; } } }]); });