From e667982e30dbf36b093132c7293d63e12242fb51 Mon Sep 17 00:00:00 2001 From: 이민희 <mhlee@maprex.co.kr> Date: 목, 09 12월 2021 10:47:58 +0900 Subject: [PATCH] Merge branch 'master' of http://192.168.0.25:9001/r/owl-kisa --- src/main/webapp/scripts/app/api/apiSetting.controller.js | 407 ++++++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 382 insertions(+), 25 deletions(-) diff --git a/src/main/webapp/scripts/app/api/apiSetting.controller.js b/src/main/webapp/scripts/app/api/apiSetting.controller.js index a96bc8c..acb070f 100644 --- a/src/main/webapp/scripts/app/api/apiSetting.controller.js +++ b/src/main/webapp/scripts/app/api/apiSetting.controller.js @@ -7,8 +7,12 @@ 'app', 'angular' ], function (app, angular) { - app.controller('apiSettingController', ['$scope', '$rootScope', '$log', '$resourceProvider','$uibModal', 'SweetAlert', '$timeout', '$filter', '$injector', '$controller', 'Api', 'Priority', 'Severity', - function ($scope, $rootScope, $log, $resourceProvider, $uibModal, SweetAlert, $timeout, $filter, $injector, $controller, Api, Priority, Severity) { + app.controller('apiSettingController', ['$scope', '$rootScope', '$log', '$resourceProvider','$uibModal', 'SweetAlert', + '$timeout', '$filter', '$injector', '$controller', 'Api', 'Priority', 'Severity', 'IssueType', 'IssueTypeCustomField', + 'IssueStatus', + function ($scope, $rootScope, $log, $resourceProvider, $uibModal, SweetAlert, + $timeout, $filter, $injector, $controller, Api, Priority, Severity, IssueType, IssueTypeCustomField, + IssueStatus) { $scope.fn = { changeTab : changeTab, @@ -19,23 +23,50 @@ initForm : initForm, getPriorities : getPriorities, getSeverities : getSeverities, - start : start + onChangeColumnSetting : onChangeColumnSetting, + getIssueTypes : getIssueTypes, + onChangeIssueType : onChangeIssueType, + reset : reset, + resetOverlap : resetOverlap, + formSubmitOverlap : formSubmitOverlap, + removeCustomField : removeCustomField, + getOverlapList : getOverlapList, + onChangeIssueTypeOverlap : onChangeIssueTypeOverlap, + getIssueTypeCustomFields : getIssueTypeCustomFields, + getCurrentIssueTypeVo : getCurrentIssueTypeVo, + getIssueStatuses : getIssueStatuses, + onChangeIssueTypeSpec : onChangeIssueTypeSpec, + createRequestModifyJson : createRequestModifyJson, + createRequestAddJson : createRequestAddJson, + createCustomFields : createCustomFields, + getProjects : getProjects, + formSubmitCompleteIssueStatus : formSubmitCompleteIssueStatus, + loadPage : loadPage, + resetCompleteIssueStatus : resetCompleteIssueStatus }; $scope.vm = { - tab : "API_COL_SETTING", + tab : "", issueTypes : [], + issueStatuses : [], + completeIssueStatuses : [], severities : [], priorities : [], + projects : [], + sampleJsonAdd : "", + sampleJsonModify : "", // projects : [], form : { + issueCustomFields : [], issueApiDefault : { title : "", description : "", priorityId : "", severityId : "", + customFields : [], // projectName : "", - } + }, + customFieldId : "", }, autoCompletePage : { @@ -48,8 +79,17 @@ // totalPage : 0 // } }, + completeIssueStatusId : "", + issueTypeId : "", issueTypeName : "", - issueTypeData : null // �씠�뒋 �쑀�삎 媛앹껜 + + issueStatusId : "", + issueStatusName : "", + + customFieldName : "", + + projectId : "", + projectName : "", }; angular.extend(this, $controller('autoCompleteController', {$scope : $scope, $injector : $injector})); @@ -61,22 +101,114 @@ $scope.vm.form.issueApiDefault.severityId = ""; } - // �씠�뒋 �쑀�삎 �겢由��떆 - $scope.$on("onClickIssueType", function (evnet, args) { - if (args != null && args.length > 0) { + function reset() { + $scope.fn.initForm(); + $scope.fn.formSubmit(); + } + // �옄�룞醫낅즺 �꽕�젙 珥덇린�솕 + function resetCompleteIssueStatus() { + $scope.vm.completeIssueStatusId = ""; + } + + // �븯�쐞 �씠�뒋 泥섎━ 湲곗� �빆紐� 珥덇린�솕(以묐났泥섎━�븷 �빆紐�) + function resetOverlap() { + $scope.vm.form.customFieldIds = []; + $scope.fn.form.formSubmitOverlap(); + } + + function getOverlapList() { + let conditions = { + issueTypeId: $scope.vm.issueTypeId + } + + Api.findApiOverlap($resourceProvider.getContent( + conditions, $resourceProvider.getPageContent(0, 1000))).then(function (result) { + if (result.data.message.status === "success") { + $scope.vm.form.customFields = []; + let customFieldApiOverlaps = result.data.data; + + if (customFieldApiOverlaps != null && customFieldApiOverlaps.length > 0) { + customFieldApiOverlaps.forEach(function (customFieldApiOverlap) { + $scope.vm.form.customFields.push(customFieldApiOverlap.customFieldVo); + }); + } + } + else { + SweetAlert.swal($filter("translate")("issue.failedToIssueTypeListLookup"), result.data.message.message, "error"); // "�씠�뒋 �쑀�삎 紐⑸줉 議고쉶 �떎�뙣" + } + }); + } + + $scope.$watch("vm.issueTypeId", function (newValue, oldValue){ + if (newValue != null && newValue !== "") { + $scope.fn.loadPage(); + } + }); + + function getIssueTypes() { + var conditions = { + }; + + IssueType.find($resourceProvider.getContent( + conditions, $resourceProvider.getPageContent(0, 1000))).then(function (result) { + if (result.data.message.status === "success") { + $scope.vm.issueTypes = result.data.data; + if ($scope.vm.issueTypes != null && $scope.vm.issueTypes.length > 0) { + if ($scope.vm.issueTypeId === "") { + $scope.vm.issueTypeId = $scope.vm.issueTypes[0].id.toString(); + } + if ($scope.vm.tab === "") { + $scope.fn.changeTab("API_COL_SETTING"); + } + + // if ($scope.vm.tab === "API_COL_SETTING") { + // $scope.fn.onChangeIssueType(); + // } else if ($scope.vm.tab === "API_SPEC_SETTING") { + // $scope.fn.onChangeIssueTypeSpec(); + // } else if ($scope.vm.tab === "API_OVERLAP_SETTING") { + // } + } + } + else { + SweetAlert.swal($filter("translate")("issue.failedToIssueTypeListLookup"), result.data.message.message, "error"); // "�씠�뒋 �쑀�삎 紐⑸줉 議고쉶 �떎�뙣" + } + }); + } + + function getCurrentIssueTypeVo() { + var issueTypeId = $scope.vm.issueTypeId; + + var issueTypeVo = null; + $scope.vm.issueTypes.forEach(function (issueType) { + if (issueType.id == issueTypeId) { + issueTypeVo = issueType; + } + }); + return issueTypeVo; + } + + function onChangeIssueTypeOverlap() { + $scope.fn.getIssueTypeCustomFields(); + $scope.fn.getOverlapList(); + } + + function onChangeIssueType() { + if ($scope.vm.issueTypeId != null) { let conditions = { - issueTypeId: args[0].id + issueTypeId: $scope.vm.issueTypeId } Api.findApiDefault($resourceProvider.getContent( - conditions, $resourceProvider.getPageContent(0, 0))).then(function (result) { + conditions, $resourceProvider.getPageContent(0, 1000))).then(function (result) { $scope.fn.initForm(); + if (result.data.message.status === "success") { if (angular.isDefined(result.data.data)) { $scope.vm.form.issueApiDefault = result.data.data; - $scope.vm.form.issueApiDefault.priorityId = result.data.data.priorityId.toString(); - $scope.vm.form.issueApiDefault.severityId = result.data.data.severityId.toString(); + $scope.vm.form.issueApiDefault.priorityId = result.data.data.priorityId != null ? result.data.data.priorityId.toString() : ""; + $scope.vm.form.issueApiDefault.severityId = result.data.data.severityId != null ? result.data.data.severityId.toString() : ""; + // if (angular.isDefined(result.data.data.projectVo)) { // $scope.vm.projects = []; @@ -88,7 +220,28 @@ } }); } - }); + + } + + function formSubmitCompleteIssueStatus() { + if ($scope.vm.issueTypeId != null) { + let content = { + id: $scope.vm.issueTypeId, + completeIssueStatusId: $scope.vm.completeIssueStatusId + } + + Api.saveCompleteIssueStatus($resourceProvider.getContent( + content, $resourceProvider.getPageContent(0, 1000))).then(function (result) { + + if (result.data.message.status === "success") { + SweetAlert.swal($filter("translate")("api.successToApiAutoCompleteIssueStatus"), result.data.message.message, "success"); // "�꽕�젙 �꽦怨�" + $scope.fn.getIssueTypes(); + } else { + SweetAlert.swal($filter("translate")("api.failedToApiAutoCompleteIssueStatus"), result.data.message.message, "error"); // "�꽕�젙 �떎�뙣" + } + }); + } + } // �뤌 泥댄겕 function formCheck(formInvalid) { @@ -100,11 +253,11 @@ } function formSubmit() { - if ($scope.vm.issueTypes == null || $scope.vm.issueTypes.length === 0) + if ($scope.vm.issueTypeId == null) return; let condition = { - issueTypeId : $scope.vm.issueTypes[0].id, + issueTypeId : $scope.vm.issueTypeId, title : $scope.vm.form.issueApiDefault.title, // projectId : $scope.vm.projects != null && $scope.vm.projects.length > 0 ? $scope.vm.projects[0].id : null, priorityId : $scope.vm.form.issueApiDefault.priorityId, @@ -116,10 +269,45 @@ $resourceProvider.getPageContent(0, 1))).then(function (result) { if (result.data.message.status === "success") { - SweetAlert.swal($filter("translate")("api.successToApiIssueDefault"), result.data.message.message, "success"); // "api �넗�겙 �깮�꽦 �꽦怨�" + SweetAlert.swal($filter("translate")("api.successToApiIssueDefault"), result.data.message.message, "success"); // "api 湲곕낯媛� �꽕�젙 �꽦怨�" } else { - SweetAlert.swal($filter("translate")("api.failedToApiIssueDefault"), result.data.message.message, "error"); // "api �넗�겙 �깮�꽦 �떎�뙣" + SweetAlert.swal($filter("translate")("api.failedToApiIssueDefault"), result.data.message.message, "error"); // "api 湲곕낯媛� �꽕�젙 �떎�뙣" + } + }); + } + + // �궗�슜�옄 �젙�쓽 �븘�뱶 �꽑�깮 �빆紐� �궘�젣 + function removeCustomField(index) { + $scope.vm.form.customFields.splice(index, 1); + } + + // 以묐났 �빆紐� �쟾�넚 + function formSubmitOverlap() { + if ($scope.vm.issueTypeId === null) + return; + + let condition = { + issueTypeId : $scope.vm.issueTypeId, + customFieldIds : (function () { + var ids = []; + + angular.forEach($scope.vm.form.customFields, function (customField) { + ids.push(customField.id); + }); + + return ids; + })(), + } + + Api.modifyApiOverlap($resourceProvider.getContent(condition, + $resourceProvider.getPageContent(0, 1))).then(function (result) { + + if (result.data.message.status === "success") { + SweetAlert.swal($filter("translate")("api.successToApiIssueOverlap"), result.data.message.message, "success"); // "api 以묐났媛� �꽕�젙 �꽦怨�" + } + else { + SweetAlert.swal($filter("translate")("api.failedToApiIssueOverlap"), result.data.message.message, "error"); // "api 以묐났媛� �꽕�젙 �떎�뙣" } }); } @@ -146,6 +334,39 @@ }); } + // �씠�뒋 �쑀�삎�뿉 �뿰寃곕맂 �궗�슜�옄 �젙�쓽 �븘�뱶 + function getIssueTypeCustomFields() { + + $scope.vm.form.issueCustomFields = []; + + var issueTypeVo = $scope.fn.getCurrentIssueTypeVo(); + var projectId = $scope.vm.projectId; + + if (issueTypeVo == null || projectId == null) return; + + IssueTypeCustomField.find($resourceProvider.getContent({ + projectId : projectId, + IssueTypeId : issueTypeVo.id }, + $resourceProvider.getPageContent(0, 1000))).then(function (result) { + $scope.vm.form.issueCustomFields = []; + if (result.data.message.status === "success") { + + angular.forEach(result.data.data, function (issueTypeCustomField) { + $scope.vm.form.issueCustomFields.push(issueTypeCustomField); + }); + + $scope.$broadcast("getIssueTypeListComplete", $scope.vm.form.issueCustomFields); + } + else { + + SweetAlert.swal($filter("translate")("issue.failedToUserDefinedFieldListAssociatedLookup"), result.data.message.message, "error"); // �씠�뒋 �쑀�삎�뿉 �뿰寃곕맂 �궗�슜�옄 �젙�쓽 �븘�뱶 紐⑸줉 議고쉶 �떎�뙣 + } + + }); + } + + + // 以묒슂�룄 紐⑸줉 function getSeverities() { Severity.find($resourceProvider.getContent({}, @@ -160,23 +381,159 @@ }); } + $scope.$on("getIssueTypeListComplete", function (event, args) { + if ($scope.vm.tab === "API_SPEC_SETTING") { + $scope.fn.createRequestAddJson(); + $scope.fn.createRequestModifyJson(); + } + }); function changeTab(tab) { $scope.vm.tab = tab; + $scope.fn.loadPage(); + } + + // �쁽�옱 �꺆 �럹�씠吏� 遺덈윭�삤湲� + function loadPage() { + let tab = $scope.vm.tab; if (tab === "API_COL_SETTING") { - $rootScope.$broadcast("changeColumnSettingTab"); + $scope.fn.onChangeColumnSetting(); } else if (tab === "API_OVERLAP_SETTING") { - $rootScope.$broadcast("changeOverlapSettingTab"); + $scope.fn.getIssueStatuses(); + $scope.fn.onChangeIssueTypeOverlap(); + } else if (tab === "API_SPEC_SETTING") { + $scope.fn.onChangeIssueTypeSpec(); } } - function start() { - $scope.fn.initForm(); - $scope.fn.getSeverities(); - $scope.fn.getPriorities(); + $scope.$on("getIssueStatusComplete", function (event, args){ + if ($scope.vm.tab === "API_OVERLAP_SETTING") { + if ($scope.vm.issueStatuses != null) { + $scope.vm.completeIssueStatuses = []; + + $scope.vm.issueStatuses.forEach(function (issueStatus) { + if (issueStatus.issueStatusType === "CLOSE") { + $scope.vm.completeIssueStatuses.push(issueStatus); + } + }); + + // �꽕�젙�맂 �긽�깭 吏��젙 + $scope.vm.completeIssueStatusId = ""; + let issueTypeVo = $scope.fn.getCurrentIssueTypeVo(); + if (issueTypeVo.completeIssueStatusVo != null) { + $scope.vm.completeIssueStatuses.forEach(function (issueStatus) { + if (issueStatus.id === issueTypeVo.completeIssueStatusVo.id) { + $scope.vm.completeIssueStatusId = issueStatus.id.toString(); + } + }); + } + } + } + }); + + function getIssueStatuses() { + var condition = { + issueTypeId: $scope.vm.issueTypeId + } + IssueStatus.findIssueStatusesByIssueType($resourceProvider.getContent(condition, + $resourceProvider.getPageContent(0, 1000))).then(function (result) { + + if (result.data.message.status === "success") { + $scope.vm.issueStatuses = result.data.data; + + // $scope.vm.issueStatusId = ""; + if ($scope.vm.issueTypeId === "") { + if ($scope.vm.issueStatuses != null && $scope.vm.issueStatuses.length > 0) { + $scope.vm.issueStatusId = $scope.vm.issueStatuses[0].id.toString(); + } + } + $scope.$broadcast("getIssueStatusComplete", $scope.vm.issueStatuses); + } else { + SweetAlert.swal($filter("translate")("issue.failedToCriticalListLookup"), result.data.message.message, "error"); // 以묒슂�룄 紐⑸줉 議고쉶 �떎�뙣 + } + }); } - $scope.fn.start(); + function onChangeColumnSetting() { + $scope.fn.getSeverities(); + $scope.fn.getPriorities(); + $scope.fn.onChangeIssueType(); + } + + + function onChangeIssueTypeSpec() { + $scope.fn.getIssueStatuses(); + $scope.fn.getIssueTypeCustomFields(); + } + + // �슂泥� �뜲�씠�꽣 留뚮뱾湲�( 異붽�) + function createRequestAddJson() { + var customFields = $scope.fn.createCustomFields(); + + var jsonData = { + token: "||諛쒓툒諛쏆� �넗�겙}||", + title: "||�씠�뒋 �젣紐�||", + issueTypeId: $scope.vm.issueTypeId, + apiType: "add", + customFields : customFields + }; + + $scope.vm.sampleJsonAdd = JSON.stringify(jsonData,undefined, 4); + } + + function createCustomFields() { + var customFields = []; + $scope.vm.form.issueCustomFields.forEach(function (issueCustomField){ + customFields.push({ + customFieldId: issueCustomField.customFieldVo.id, + useValue: "||�엯�젰媛�||" + }) + }); + return customFields; + } + + // �슂泥� �뜲�씠�꽣 留뚮뱾湲�(�닔�젙) + function createRequestModifyJson() { + var customFields = $scope.fn.createCustomFields(); + + var jsonData = { + token: "||諛쒓툒諛쏆� �넗�겙||", + issueTypeId: $scope.vm.issueTypeId, + apiType: "modify", + issueStatusId: $scope.vm.issueStatusId, + customFields : customFields + }; + + $scope.vm.sampleJsonModify = JSON.stringify(jsonData, undefined, 2); + } + + $scope.$watch(function() { + return $rootScope.projects; + }, function() { + if ($rootScope.projects != null && $rootScope.projects.length > 0) { + // 怨듯넻 �뜲�씠�꽣 遺덈윭�삤湲� + $scope.fn.getProjects(); + $scope.fn.getIssueTypes(); + } + }, true); + + + function getProjects() { + if ($rootScope.projects != null) { + $scope.vm.projects = []; + $rootScope.projects.forEach(function (project){ + if (project.id > -1) { + $scope.vm.projects.push(project); + } + }); + + if ( $scope.vm.projects.length > 0) { + $scope.vm.projectId = $scope.vm.projects[0].id.toString(); + } + } + } + + }]); }); -- Gitblit v1.8.0