From 3571222dcf5f25b458b822fe888d695622144016 Mon Sep 17 00:00:00 2001
From: 이민희 <mhlee@maprex.co.kr>
Date: 화, 28 12월 2021 21:44:36 +0900
Subject: [PATCH] - 연관이슈, 하위이슈 추가 시 이슈타입 별 담당부서 불러오기 - 이슈 상세페이지에서 하위이슈 리스트에서 제거 시 팝업 문구 수정

---
 src/main/webapp/scripts/components/utils/autoComplete.controller.js |  138 +++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 117 insertions(+), 21 deletions(-)

diff --git a/src/main/webapp/scripts/components/utils/autoComplete.controller.js b/src/main/webapp/scripts/components/utils/autoComplete.controller.js
index 8be4e38..7fd4e7e 100644
--- a/src/main/webapp/scripts/components/utils/autoComplete.controller.js
+++ b/src/main/webapp/scripts/components/utils/autoComplete.controller.js
@@ -23,6 +23,7 @@
                 var IspField = $injector.get("IspField");
                 var HostingField = $injector.get("HostingField");
                 var IssueType = $injector.get("IssueType");
+                var IssueTypeCustomField = $injector.get("IssueTypeCustomField");
                 var CustomField = $injector.get("CustomField");
                 var $log = $injector.get("$log");
                 var SweetAlert = $injector.get("SweetAlert");
@@ -31,6 +32,7 @@
                 $scope.fn.getUserList = getUserList;    //  �궗�슜�옄 紐⑸줉 �젙蹂대�� 議고쉶�븳�떎.
                 $scope.fn.getProjectList = getProjectList;  //  �봽濡쒖젥�듃 紐⑸줉 �젙蹂대�� 議고쉶�븳�떎.
                 $scope.fn.getIssueList = getIssueList;  //  �씪媛� 紐⑸줉 �젙蹂대�� 議고쉶�븳�떎.
+                $scope.fn.getRelIssueList = getRelIssueList;   // �뿰愿� �씠�뒋 紐⑸줉 �젙蹂대�� 議고쉶�븳�떎.
                 $scope.fn.getDownIssueList = getDownIssueList;  //  �븯�쐞 �씠�뒋 紐⑸줉 �젙蹂대�� 議고쉶�븳�떎.
                 $scope.fn.getWorkflowList = getWorkflowList;    //  �썙�겕�뵆濡쒖슦 紐⑸줉 �젙蹂대�� 議고쉶�븳�떎.
                 $scope.fn.getUserDepartmentList = getUserDepartmentList;    //  遺��꽌 紐⑸줉 �젙蹂대�� 議고쉶�븳�떎.
@@ -42,6 +44,7 @@
                 $scope.fn.getIssueTypeList = getIssueTypeList;          // �씠�뒋 �쑀�삎 紐⑸줉 議고쉶
                 $scope.fn.getCustomFieldList = getCustomFieldList;          // �궗�슜�옄 �젙�쓽 �븘�뱶 紐⑸줉 議고쉶
                 $scope.fn.getMailTargetAll = getMailTargetAll;          // �궗�슜�옄 �젙�쓽 �븘�뱶 紐⑸줉 議고쉶
+                $scope.fn.getIssueTypeCustomFieldList = getIssueTypeCustomFieldList;      // �씠�뒋 �쑀�삎�뿉�꽌 �궗�슜以묒씤 �궗�슜�옄�젙�쓽 �븘�뱶媛��졇�삤湲�
 
                 function getUserList(query, excludeList, page, callBack) {
                     var conditions = {
@@ -131,13 +134,13 @@
                 function getIssueList(query, issueTypeId, excludeList, page, callBack) {
                     var conditions = {
                         name : query,
-                        issueTypeIds : (function () {
+                        /*issueTypeIds : (function () {
                             var ids = [];
 
                             ids.push(issueTypeId);
 
                             return ids;
-                        })(),
+                        })(),*/
                         excludeIds : (function () {
                             var excludeIds = [];
 
@@ -169,17 +172,51 @@
                     return deferred.promise;
                 }
 
-
-                function getDownIssueList(query, issueTypeId, excludeList, page, callBack) {
+                function getRelIssueList(query, issueTypeId, excludeList, page, callBack) {
                     var conditions = {
                         name : query,
-                        // issueTypeIds : (function () {
-                        //     var ids = [];
-                        //
-                        //     ids.push(issueTypeId);
-                        //
-                        //     return ids;
-                        // })(),
+                        excludeIds : (function () {
+                            var excludeIds = [];
+
+                            angular.forEach(excludeList, function (exclude) {
+                                excludeIds.push(exclude.id);
+                            });
+                            return excludeIds;
+                        })()
+                    };
+
+                    var deferred = $q.defer();
+
+                    if ($rootScope.isDefined(page) && page > 0) {
+                        $rootScope.spinner = true;
+                    }
+
+                    Issue.find($resourceProvider.getContent(
+                        conditions, $resourceProvider.getPageContent($rootScope.isDefined(page) ? page : 0, $rootScope.isDefined(page) ? 10 : 25))).then(function (result) {
+                        if (result.data.message.status === "success") {
+                            if ($rootScope.isDefined(callBack)) {
+                                callBack(result);
+                            }
+                            deferred.resolve(result.data.data);
+                        }
+                        else {
+                            SweetAlert.swal($filter("translate")("common.failedToIssueListLookUp"), result.data.message.message, "error"); // "�썙�겕�뵆濡쒖슦 紐⑸줉 議고쉶 �떎�뙣"
+                        }
+                        $rootScope.spinner = false;
+                    });
+                    return deferred.promise;
+                }
+
+                function getDownIssueList(query, issueTypeId, parentIssueId, excludeList, page, callBack) {
+                    var conditions = {
+                        name : query,
+                        issueTypeIds : (function () {
+                            var ids = [];
+
+                            ids.push(issueTypeId);
+
+                            return ids;
+                        })(),
                         excludeIds : (function () {
                             var excludeIds = [];
 
@@ -187,27 +224,31 @@
                                 excludeIds.push(exclude.id);
                             });
 
+                            if(parentIssueId != null) {
+                                excludeIds.push(parentIssueId);
+                            }
                             return excludeIds;
                         })()
                     };
-
                     var deferred = $q.defer();
+
+                    if ($rootScope.isDefined(page) && page > 0) {
+                        $rootScope.spinner = true;
+                    }
 
                     Issue.find($resourceProvider.getContent(         //  �럹�씠吏� �뾽�뜲�씠�듃媛� �븘�슂�븳 而댄룷�꼳�듃 �씪寃쎌슦, page �뾽�뜲�씠�듃媛� �엳�쓣 寃쎌슦 湲곕낯 10媛쒖뵫 媛��졇�삤怨� �븘�땺寃쎌슦 25媛쒖뵫 媛��졇�삩�떎.
                         conditions, $resourceProvider.getPageContent($rootScope.isDefined(page) ? page : 0, $rootScope.isDefined(page) ? 10 : 25))).then(function (result) {
                         if (result.data.message.status === "success") {
-
                             if ($rootScope.isDefined(callBack)) {
                                 callBack(result);
                             }
-
                             deferred.resolve(result.data.data);
                         }
                         else {
                             SweetAlert.swal($filter("translate")("common.failedToIssueListLookUp"), result.data.message.message, "error"); // "�썙�겕�뵆濡쒖슦 紐⑸줉 議고쉶 �떎�뙣"
                         }
+                        $rootScope.spinner = false;
                     });
-
                     return deferred.promise;
                 }
 
@@ -277,7 +318,7 @@
 
                 function getIssueCompanyFieldList(query, excludeList, page, callBack) {
                     var conditions = {
-                        companyName : query,
+                        name : query,
                         excludeIds : (function () {
                             var excludeIds = [];
 
@@ -310,8 +351,10 @@
                     return deferred.promise;
                 }
 
-                function getIssueDepartmentList(query, excludeList, page, callBack) {
+                function getIssueDepartmentList(issueTypeId, query, excludeList, page, callBack) {
                     var conditions = {
+                        //issueTypeId : $scope.vm.form.issueTypeId,
+                        issueTypeId : Number(issueTypeId),
                         departmentName : query,
                         userId : $rootScope.user.id,
                         projectId : (function () {
@@ -339,15 +382,23 @@
                     var deferred = $q.defer();
 
 
-                    //�봽濡쒖젥�듃�뿉 �냽�빐�엳�뒗 �떞�떦遺��꽌 李얘린
-                    UserWorkspace.findProjectDepartment($resourceProvider.getContent(         //  �럹�씠吏� �뾽�뜲�씠�듃媛� �븘�슂�븳 而댄룷�꼳�듃 �씪寃쎌슦, page �뾽�뜲�씠�듃媛� �엳�쓣 寃쎌슦 湲곕낯 10媛쒖뵫 媛��졇�삤怨� �븘�땺寃쎌슦 25媛쒖뵫 媛��졇�삩�떎.
+                    //�썙�겕�뵆濡쒖슦�뿉 �냽�빐�엳�뒗 �떞�떦遺��꽌 李얘린
+                    UserWorkspace.findWorkflowDepartment($resourceProvider.getContent(         //  �럹�씠吏� �뾽�뜲�씠�듃媛� �븘�슂�븳 而댄룷�꼳�듃 �씪寃쎌슦, page �뾽�뜲�씠�듃媛� �엳�쓣 寃쎌슦 湲곕낯 10媛쒖뵫 媛��졇�삤怨� �븘�땺寃쎌슦 25媛쒖뵫 媛��졇�삩�떎.
                         conditions, $resourceProvider.getPageContent($rootScope.isDefined(page) ? page : 0, $rootScope.isDefined(page) ? 10 : 25))).then(function (result) {
                         if (result.data.message.status === "success") {
+                            const departments = result.data.data;
+                            if(departments != null){
+                                var filterDepartments = departments.filter(function(item, idx){
+                                    return departments.findIndex(function(item2, idx2){
+                                        return item.departmentName === item2.departmentName
+                                    }) == idx;
+                                });
+                            }
+
                             if ($rootScope.isDefined(callBack)) {
                                 callBack(result);
                             }
-
-                            deferred.resolve(result.data.data);
+                            deferred.resolve(filterDepartments);
                         }
                         else {
                             SweetAlert.swal($filter("translate")("common.failedToProjectListLookUp"), result.data.message.message, "error"); // "�봽濡쒖젥�듃 紐⑸줉 議고쉶 �떎�뙣"
@@ -525,6 +576,51 @@
                     return deferred.promise;
                 }
 
+                //  �씠�뒋 �쑀�삎�뿉 �뿰寃곕맂 �궗�슜�옄 �젙�쓽 �븘�뱶
+                function getIssueTypeCustomFieldList(query, excludeList, projectId, issueTypeId, page, callBack) {
+
+                    if (projectId == null) return;
+                    if (issueTypeId == null) return;
+
+                    var deferred = $q.defer();
+
+                    IssueTypeCustomField.find($resourceProvider.getContent({
+                            name : query,
+                            projectId : projectId,
+                            issueTypeId : issueTypeId,
+                            excludeIds : (function () {
+                                var excludeIds = [];
+
+                                angular.forEach(excludeList, function (exclude) {
+                                    excludeIds.push(exclude.id);
+                                });
+
+                                return excludeIds;
+                            })()
+                        },
+                        $resourceProvider.getPageContent(0, 1000))).then(function (result) {
+                        if (result.data.message.status === "success") {
+                            if ($rootScope.isDefined(callBack)) {
+                                callBack(result);
+                            }
+
+                            var customFields = result.data.data;
+                            var customFieldVos = [];
+                            customFields.forEach(function (customField) {
+                                customFieldVos.push(customField.customFieldVo);
+                            })
+
+                            deferred.resolve(customFieldVos);
+                        }
+                        else {
+                            SweetAlert.swal($filter("translate")("issue.failedToUserDefinedFieldListAssociatedLookup"), result.data.message.message, "error"); // �씠�뒋 �쑀�삎�뿉 �뿰寃곕맂 �궗�슜�옄 �젙�쓽 �븘�뱶 紐⑸줉 議고쉶 �떎�뙣
+                        }
+
+                    });
+
+                    return deferred.promise;
+                }
+
                 function getMailTargetAll(excludeList) {
                     var deferred = $q.defer();
 

--
Gitblit v1.8.0