tableBuilder.js
3.54 KB
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
117
118
119
120
/*
* Copyright 2015 Open Networking Laboratory
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
ONOS GUI -- Widget -- Table Service
*/
(function () {
'use strict';
// injected refs
var $log, $interval, fs, wss, ts;
// constants
var refreshInterval = 2000;
// example params to buildTable:
// {
// scope: $scope, <- controller scope
// tag: 'device', <- table identifier
// selCb: selCb <- row selection callback (optional)
// query: params <- query parameters in URL (optional)
// }
// Note: selCb() is passed the row data model of the selected row,
// or null when no row is selected.
// Note: query is always an object (empty or containing properties)
// it comes from $location.search()
function buildTable(o) {
var handlers = {},
root = o.tag + 's',
req = o.tag + 'DataRequest',
resp = o.tag + 'DataResponse',
onSel = fs.isF(o.selCb),
promise;
o.scope.tableData = [];
o.scope.sortParams = {};
o.scope.autoRefresh = true;
function respCb(data) {
o.scope.tableData = data[root];
o.scope.$apply();
}
function sortCb(params) {
var p = angular.extend({}, params, o.query);
wss.sendEvent(req, p);
}
o.scope.sortCallback = sortCb;
function selCb($event, selRow) {
o.scope.selId = (o.scope.selId === selRow.id) ? null : selRow.id;
onSel && onSel($event, selRow);
}
o.scope.selectCallback = selCb;
function startRefresh() {
promise = $interval(function () {
$log.debug('Refreshing ' + root + ' page');
sortCb(o.scope.sortParams);
}, refreshInterval);
}
function stopRefresh() {
if (angular.isDefined(promise)) {
$interval.cancel(promise);
promise = undefined;
}
}
function toggleRefresh() {
o.scope.autoRefresh = !o.scope.autoRefresh;
o.scope.autoRefresh ? startRefresh() : stopRefresh();
}
o.scope.toggleRefresh = toggleRefresh;
handlers[resp] = respCb;
wss.bindHandlers(handlers);
// Cleanup on destroyed scope
o.scope.$on('$destroy', function () {
wss.unbindHandlers(handlers);
ts.resetSort();
stopRefresh();
});
sortCb();
startRefresh();
}
angular.module('onosWidget')
.factory('TableBuilderService',
['$log', '$interval', 'FnService', 'WebSocketService', 'TableService',
function (_$log_, _$interval_, _fs_, _wss_, _ts_) {
$log = _$log_;
$interval = _$interval_;
fs = _fs_;
wss = _wss_;
ts = _ts_;
return {
buildTable: buildTable
};
}]);
}());