OWL ITS + 탐지시스템(인터넷 진흥원)
이민희
2022-01-13 84d2bd3ecedfaf82cad8698b0e82b2469b7dccb7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/**
 * Created by wisestone on 2018-05-08.
 */
'use strict';
 
define([
        'app',
        'angular',
        'saveSvgAsPng'
    ],
    function (app, angular, saveSvgAsPng) {
        app.controller('workflowModifyController', ['$scope', '$rootScope', '$log', '$resourceProvider', '$uibModalInstance', 'Workflow', 'parameter', 'SweetAlert', '$window', '$filter',
            function ($scope, $rootScope, $log, $resourceProvider, $uibModalInstance, Workflow, parameter, SweetAlert, $window, $filter) {
 
                $scope.fn = {
                    cancel : cancel,    //  팝업 창 닫기
                    formSubmit : formSubmit,    //  폼 전송
                    formCheck : formCheck,  //  폼 체크
                    detail : detail //  상세 정보 조회
                };
 
                $scope.vm = {
                    search : {
                        id : parameter.id,
                        deep : "01"    //  워크플로우 연관된 모든 정보를 어느정도까지 가져올지 결정, 01 - 일반 정보, 연관된 정보
                    },
                    form : {
                        id : parameter.id,
                        name : "",
                        issueStatusVos : [],    //  다이어그램에 상태를 주입하고 만들어진 상태 모음 - 워크플로우 생성과 조금 다르게 사용된다.
                    },
                    step : "01",
                    isolationWorkflow : true,   //  워크플로우에 고립된 이슈 상태가 있는지 여부를 체크한다.
                    firstStatusExist : true,    //  워크플로우에 상태 속성 '대기'인 상태가 존재하는지 체크한다.
                    middleStatusExist : true,   //  워크플로우에 상태 속성 '진행'인 상태가 존재하는지 체크한다.
                    lastStatusExist : true,  //  워크플로우에 상태 속성 '종료'인 상태가 존재하는지 체크한다.
                };
 
                function formCheck(formInvalid) {
                    if (formInvalid) {
                        return true;
                    }
 
                    return false;
                }
 
 
                function formSubmit() {
                    $rootScope.spinner = true;
 
                    var content = {
                        id : parameter.id,
                        name : $rootScope.preventXss($scope.vm.form.name),
                        issueStatusVos : $scope.vm.form.issueStatusVos,
                        nodes : (function () {
                            var keys = Object.keys($scope.vm.form.nodes);
                            var nodes = [];
 
                            angular.forEach(keys, function (key) {
                                var node = $scope.vm.form.nodes[key];
 
                                if ($rootScope.isDefined(node)) {
                                    nodes.push(node);
                                }
                            });
 
                            return nodes;
                        })(),
                        links : $scope.vm.form.links
                    };
 
                    Workflow.modify($resourceProvider.getContent(
                        content,
                        $resourceProvider.getPageContent(0, 0))).then(function (result) {
 
                        if (result.data.message.status === "success") {
                            $scope.fn.cancel();
                            //  목록 화면 갱신
                            $rootScope.$broadcast("getWorkflowList", {});
                        }
                        else {
                            SweetAlert.error($filter("translate")("managementWorkflow.failedToModifyWorkflow"), result.data.message.message); // 워크플로우 수정 실패
                        }
 
                        $rootScope.spinner = false;
                    });
                }
 
                //  팝업 창 닫기
                function cancel() {
                    $rootScope.$broadcast("closeLayer");    //  팝업이 열리고 나서 js-multi, js-single 등에서 body 이벤트가 날아가는 현상 수정
                    $uibModalInstance.dismiss('cancel');
                    $(document).unbind("keydown");  //  단축키 이벤트 제거
                }
 
                function detail() {
                    Workflow.detail($resourceProvider.getContent(
                        $scope.vm.search,
                        $resourceProvider.getPageContent(0, 1))).then(function (result) {
 
                        if (result.data.message.status === "success") {
                            if (angular.isDefined(result.data.data)) {
                                $scope.vm.form.name = result.data.data.name;
                                $scope.vm.form.issueStatusVos = result.data.data.issueStatusVos;
                                $scope.vm.issueStatusVos = [];    //  다이어그램 에디터에서 이 값을 감지하면서 조회가 시작된다.
                            }
                        }
                        else {
                            SweetAlert.error($filter("translate")("managementWorkflow.failedToWorkflowDetails"), result.data.message.message); // 워크플로우 상세 정보 조회 실패
                        }
                    });
                }
 
                $scope.fn.detail();
            }]);
    });