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
|
appDS2.controller('treeViewController',function(
$scope, $rootScope, $log, $modal, ExecutionService, ControllerService){
'use strict';
// Set to true for verbose output
var debug = false;
// this object holds all app data and functions
$scope.ecdapp = {};
$scope.ecdapp.isDataLoading = false;
$scope.ecdapp.isRequestFailed = false;
$scope.orgChart = true;
$scope.status = '';
var selectedItem = {
name: ''
};
// Initial data as eye candy
$scope.orgChartData = [ { 'blueprint_id': 'Root', 'parent': 'parent' } ];
var controllersList = [];
var getControllers = function(){
ControllerService.getControllers().then(function(jsonObj) {
if (debug)
$log.debug("treeViewController.getControllers succeeded: " + JSON.stringify(jsonObj));
// Empty
controllersList.length = 0;
// Refill
jsonObj.filter(function(d) {
controllersList.push(d);
if (d.selected)
selectedItem = d;
return;
});
$scope.ecdapp.loadTable();
}, function(error) {
alert('Failed to load controllers. Please retry.');
$log.error("treeViewController.getControllers failed: " + error);
});
}
/**
* Called from the directive when user picks a status value.
*/
$scope.ecdapp.loadTable = function(status) {
$scope.ecdapp.isDataLoading = true;
$scope.status = status;
// Empty list and create the root controller item
$scope.orgChartData.length = 0;
$scope.orgChartData.push({
"blueprint_id": selectedItem.name,
"parent": "parent"
});
ExecutionService.getExecutionsByStatus(status).then(
function(jsonObj) {
if (jsonObj.error) {
$log.error("treeViewController.loadTable failed: "
+ jsonObj.error);
$scope.ecdapp.isRequestFailed = true;
$scope.ecdapp.errMsg = jsonObj.error;
} else {
$scope.ecdapp.isRequestFailed = false;
$scope.ecdapp.errMsg = null;
for (var i=0; i < jsonObj.items.length; i++) {
$scope.orgChartData.push(jsonObj.items[i]);
}
$scope.$broadcast('listenEvent', {data: $scope.orgChartData} );
}
$scope.ecdapp.isDataLoading = false;
},
function(error) {
$log.error("treeViewController.loadTable failed: "
+ error);
$scope.ecdapp.isRequestFailed = true;
$scope.ecdapp.errMsg = error;
$scope.ecdapp.isDataLoading = false;
});
};
// Listens for change of the selected controller
$rootScope.$on('controllerChange', function(e, d){
$scope.orgChartData[0].blueprint_id = d.name;
$scope.$broadcast('listenEvent', {data: $scope.orgChartData});
})
// Shows popup with list of controllers
$scope.ecdapp.showEcompCInstancesModalPopup = function() {
var modalInstance = $modal.open({
templateUrl : 'ecompc_instances_popup.html',
controller : 'selectEcompcController',
windowClass: 'modal-docked',
sizeClass: 'modal-medium',
resolve : {
message : function() {
return { items: controllersList }
}
}
});
modalInstance.result.then(function(response) {
// Always reload the table
// $log.debug('modalInstance: reloading controllers');
getControllers('active');
},
function(error) {
// Should never happen
$log.error('modalInstance: ERROR!?');
});
};
// Populate the table on load.
getControllers('active');
});
|