nutella_framework 0.4.23 → 0.4.24
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/framework_components/monitoring-bot/monitoring-bot.rb +11 -2
- data/framework_components/monitoring-interface/.gitignore +2 -0
- data/framework_components/monitoring-interface/README.md +1 -0
- data/framework_components/monitoring-interface/bower.json +29 -0
- data/framework_components/monitoring-interface/bower_components/bower-mqttws/.bower.json +23 -0
- data/framework_components/monitoring-interface/bower_components/bower-mqttws/bower.json +14 -0
- data/framework_components/monitoring-interface/bower_components/bower-mqttws/mqttws31.js +2081 -0
- data/framework_components/monitoring-interface/bower_components/bower-mqttws/readme.md +4 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/.bower.json +37 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/LICENSE +21 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/README.md +15 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/bower.json +28 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/examples/browser/mqtt_client_hello_world.html +23 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/examples/browser/nutella_hello_world.html +52 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/examples/node/mqtt_client_hello_world.js +14 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/examples/node/nutella_hello_world.js +38 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/nutella_lib.js +789 -0
- data/framework_components/monitoring-interface/bower_components/nutella_lib/package.json +30 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface.html +215 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/animations.js +27 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/application-view-controller.js +232 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/applications-model.js +61 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/bootstrap.min.js +7 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/cursor.css +7 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/d3.v3.min.js +5 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/graphics.js +156 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/grid-layout.js +103 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/highlight.min.js +2 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/instance-view-controller.js +104 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/jquery-1.10.0.min.js +6 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/notification-center.js +63 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/notifications.js +14 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/page.css +33 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/radial-layout.js +175 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/tab-table.js +8 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-application.css +0 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-application.js +320 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-connection-view.css +10 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-connection-view.js +426 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-element.js +205 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-notification.js +94 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-tab.js +229 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/underscore-min.js +5 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/view-controller.js +68 -0
- data/framework_components/monitoring-interface/css/Monitoring Interface_files/window-view-controller.js +169 -0
- data/framework_components/monitoring-interface/css/alerts.css +3 -0
- data/framework_components/monitoring-interface/css/bootstrap.min.css +5 -0
- data/framework_components/monitoring-interface/css/cursor.css +7 -0
- data/framework_components/monitoring-interface/css/highlight.default.min.css +1 -0
- data/framework_components/monitoring-interface/css/page.css +41 -0
- data/framework_components/monitoring-interface/css/ui-application.css +0 -0
- data/framework_components/monitoring-interface/css/ui-connection-view.css +10 -0
- data/framework_components/monitoring-interface/css/ui-legend-view.css +7 -0
- data/framework_components/monitoring-interface/data/alert.json +8 -0
- data/framework_components/monitoring-interface/data/data.json +2118 -0
- data/framework_components/monitoring-interface/data/data2.json +814 -0
- data/framework_components/monitoring-interface/data/data3.json +823 -0
- data/framework_components/monitoring-interface/data/data4.json +848 -0
- data/framework_components/monitoring-interface/data/message.json +999 -0
- data/framework_components/monitoring-interface/gulpfile.js +29 -0
- data/framework_components/monitoring-interface/img/arrow_white.svg +120 -0
- data/framework_components/monitoring-interface/img/arrow_white_right.svg +104 -0
- data/framework_components/monitoring-interface/img/back.svg +164 -0
- data/framework_components/monitoring-interface/img/cross_red_border_white.svg +143 -0
- data/framework_components/monitoring-interface/img/cross_red_border_white_mouseover.svg +143 -0
- data/framework_components/monitoring-interface/img/email.svg +89 -0
- data/framework_components/monitoring-interface/img/email_highlighted.svg +89 -0
- data/framework_components/monitoring-interface/index.html +144 -0
- data/framework_components/monitoring-interface/js/d3/layout/grid-layout.js +103 -0
- data/framework_components/monitoring-interface/js/d3/layout/radial-layout.js +184 -0
- data/framework_components/monitoring-interface/js/d3/plugin/graphics.js +156 -0
- data/framework_components/monitoring-interface/js/d3/plugin/tab-table.js +8 -0
- data/framework_components/monitoring-interface/js/d3/ui/animations.js +27 -0
- data/framework_components/monitoring-interface/js/d3/ui/ui-application.js +471 -0
- data/framework_components/monitoring-interface/js/d3/ui/ui-connection-view.js +847 -0
- data/framework_components/monitoring-interface/js/d3/ui/ui-element.js +245 -0
- data/framework_components/monitoring-interface/js/d3/ui/ui-legend.js +174 -0
- data/framework_components/monitoring-interface/js/d3/ui/ui-notification.js +90 -0
- data/framework_components/monitoring-interface/js/d3/ui/ui-tab.js +309 -0
- data/framework_components/monitoring-interface/js/lib/JSXTransformer-0.12.2.js +15199 -0
- data/framework_components/monitoring-interface/js/lib/bootstrap.min.js +7 -0
- data/framework_components/monitoring-interface/js/lib/d3.v3.min.js +5 -0
- data/framework_components/monitoring-interface/js/lib/highlight.min.js +2 -0
- data/framework_components/monitoring-interface/js/lib/jquery-1.10.0.min.js +6 -0
- data/framework_components/monitoring-interface/js/lib/nutella_lib.js +5121 -0
- data/framework_components/monitoring-interface/js/lib/react-with-addons-0.12.2.js +19822 -0
- data/framework_components/monitoring-interface/js/lib/underscore-min.js +5 -0
- data/framework_components/monitoring-interface/js/model/alerts-model.js +74 -0
- data/framework_components/monitoring-interface/js/model/applications-model.js +78 -0
- data/framework_components/monitoring-interface/js/model/messages-model.js +112 -0
- data/framework_components/monitoring-interface/js/notification/notification-center.js +63 -0
- data/framework_components/monitoring-interface/js/notification/notifications.js +21 -0
- data/framework_components/monitoring-interface/js/react/dist/ui-alerts.js +178 -0
- data/framework_components/monitoring-interface/js/react/dist/ui-message-send.js +389 -0
- data/framework_components/monitoring-interface/js/react/dist/ui-messages.js +103 -0
- data/framework_components/monitoring-interface/js/react/src/ui-alerts.js +178 -0
- data/framework_components/monitoring-interface/js/react/src/ui-message-send.js +389 -0
- data/framework_components/monitoring-interface/js/react/src/ui-messages.js +103 -0
- data/framework_components/monitoring-interface/js/view-controller/application-view-controller.js +256 -0
- data/framework_components/monitoring-interface/js/view-controller/instance-view-controller.js +112 -0
- data/framework_components/monitoring-interface/js/view-controller/view-controller.js +74 -0
- data/framework_components/monitoring-interface/js/view-controller/window-view-controller.js +169 -0
- data/framework_components/monitoring-interface/nutella.json +6 -0
- data/framework_components/order.json +1 -0
- data/framework_components/roomcast-bot/roomcast_bot.rb +139 -117
- data/framework_components/roomcast-channel-creator/dist/app.js +9 -7
- data/framework_components/roomcast-channel-creator/index.html +1 -1
- data/framework_components/roomcast-channel-creator/src/app/components/main.js +8 -6
- data/framework_components/roomcast-package-creator/dist/app.js +4 -4
- data/framework_components/roomcast-package-creator/index.html +1 -1
- data/framework_components/roomcast-package-creator/package.json +3 -3
- data/framework_components/roomcast-package-creator/src/app/components/ConfigurationsPanel.js +2 -2
- data/framework_components/roomcast-package-creator/src/app/components/PoolRow.js +1 -1
- data/framework_components/roomcast-teacher-controls/.gitignore +2 -0
- data/framework_components/roomcast-teacher-controls/README.md +9 -0
- data/framework_components/roomcast-teacher-controls/dist/app.js +38327 -0
- data/framework_components/roomcast-teacher-controls/dist/main.css +3052 -0
- data/framework_components/roomcast-teacher-controls/dist/nutella_lib.js +5121 -0
- data/framework_components/roomcast-teacher-controls/gulp/config.js +51 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/browserify.js +77 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/build.js +3 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/css.js +7 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/default.js +3 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/fonts.js +7 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/less.js +16 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/mui-fonts.js +7 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/nutella.js +7 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/setWatch.js +5 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/svgs.js +7 -0
- data/framework_components/roomcast-teacher-controls/gulp/tasks/watch.js +12 -0
- data/framework_components/roomcast-teacher-controls/gulp/util/bundleLogger.js +21 -0
- data/framework_components/roomcast-teacher-controls/gulp/util/handleErrors.js +15 -0
- data/framework_components/roomcast-teacher-controls/gulpfile.js +16 -0
- data/framework_components/roomcast-teacher-controls/index.html +51 -0
- data/framework_components/roomcast-teacher-controls/nutella.json +6 -0
- data/framework_components/roomcast-teacher-controls/package.json +38 -0
- data/framework_components/roomcast-teacher-controls/src/app/app.js +22 -0
- data/framework_components/roomcast-teacher-controls/src/app/components/ActivitiesGrid.js +87 -0
- data/framework_components/roomcast-teacher-controls/src/app/components/ActivityCard.js +141 -0
- data/framework_components/roomcast-teacher-controls/src/app/components/Channel.js +70 -0
- data/framework_components/roomcast-teacher-controls/src/app/components/Footer.js +34 -0
- data/framework_components/roomcast-teacher-controls/src/app/components/main.js +74 -0
- data/framework_components/roomcast-teacher-controls/src/less/main.less +186 -0
- data/framework_components/roomcast-teacher-controls/src/less/my_overrides.less +14 -0
- data/lib/commands/meta/run_command.rb +11 -9
- metadata +135 -2
data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-notification.js
ADDED
@@ -0,0 +1,94 @@
|
|
1
|
+
var UINotification = function(delegate) {
|
2
|
+
var self = UIElement(delegate);
|
3
|
+
|
4
|
+
// Static attributes
|
5
|
+
UINotification.style = {
|
6
|
+
notificationRadius: 10,
|
7
|
+
notificationFontSize: 14,
|
8
|
+
margin: {x: 0, y: 10}
|
9
|
+
};
|
10
|
+
|
11
|
+
// Public attributes
|
12
|
+
self.name = undefined; // Name of the notification
|
13
|
+
|
14
|
+
// Private variables
|
15
|
+
var notificationGroup = undefined;
|
16
|
+
var notificationCircle = undefined;
|
17
|
+
var notificationText = undefined;
|
18
|
+
|
19
|
+
self.render = function() {
|
20
|
+
|
21
|
+
console.log("Render: notification");
|
22
|
+
|
23
|
+
var layer = self.view;
|
24
|
+
|
25
|
+
if(notificationGroup == undefined)
|
26
|
+
notificationGroup = layer.layerWithName("notificationGroup");
|
27
|
+
|
28
|
+
if(self.show == false) {
|
29
|
+
notificationGroup
|
30
|
+
.transition()
|
31
|
+
.duration(Animations.notification.NOTIFICATION_FADE_OUT.duration)
|
32
|
+
.delay(Animations.notification.NOTIFICATION_FADE_OUT.delay)
|
33
|
+
.opacity(0);
|
34
|
+
|
35
|
+
notificationCircle
|
36
|
+
.transition()
|
37
|
+
.cx(0)
|
38
|
+
.cy(0)
|
39
|
+
.r(0);
|
40
|
+
|
41
|
+
notificationText
|
42
|
+
.transition()
|
43
|
+
.x(1000);
|
44
|
+
}
|
45
|
+
else {
|
46
|
+
notificationGroup
|
47
|
+
.transition()
|
48
|
+
.duration(Animations.notification.NOTIFICATION_FADE_IN.duration)
|
49
|
+
.delay(Animations.notification.NOTIFICATION_FADE_IN.delay)
|
50
|
+
.opacity(1);
|
51
|
+
|
52
|
+
notificationCircle
|
53
|
+
.cx(0)
|
54
|
+
.cy(0)
|
55
|
+
.r(UINotification.style.notificationRadius);
|
56
|
+
}
|
57
|
+
|
58
|
+
if(notificationCircle == undefined) {
|
59
|
+
notificationCircle = notificationGroup
|
60
|
+
.append("circle")
|
61
|
+
.class("notificationCircle")
|
62
|
+
.cx(0)
|
63
|
+
.cy(0)
|
64
|
+
.r(UINotification.style.notificationRadius)
|
65
|
+
.fill(self.palette.accent2.normal);
|
66
|
+
}
|
67
|
+
|
68
|
+
if(notificationText == undefined) {
|
69
|
+
notificationText = notificationGroup
|
70
|
+
.append("text")
|
71
|
+
.class("no_interaction")
|
72
|
+
.class("notificationText")
|
73
|
+
.attr("text-anchor", "middle")
|
74
|
+
.attr("font-size", UINotification.style.notificationFontSize);
|
75
|
+
}
|
76
|
+
|
77
|
+
notificationText
|
78
|
+
.y(UINotification.style.notificationFontSize/3)
|
79
|
+
.text(delegate.notification(self.name));
|
80
|
+
};
|
81
|
+
|
82
|
+
// Constructor
|
83
|
+
self.init = function() {
|
84
|
+
|
85
|
+
}();
|
86
|
+
|
87
|
+
// Destructor
|
88
|
+
self.deinit = function() {
|
89
|
+
// Place here the code for dealloc eventual objects
|
90
|
+
|
91
|
+
};
|
92
|
+
|
93
|
+
return self;
|
94
|
+
};
|
@@ -0,0 +1,229 @@
|
|
1
|
+
var UITab = function(delegate, name) {
|
2
|
+
var self = UIElement(delegate);
|
3
|
+
|
4
|
+
UITab.style = {
|
5
|
+
height: 100,
|
6
|
+
width: 200,
|
7
|
+
optionRectWidth: 100
|
8
|
+
};
|
9
|
+
|
10
|
+
// Public variables
|
11
|
+
self.name = undefined;
|
12
|
+
|
13
|
+
|
14
|
+
// Private variables
|
15
|
+
var instanceTab = undefined;
|
16
|
+
var instanceTabText = undefined;
|
17
|
+
var optionGroup = undefined;
|
18
|
+
var optionRect = undefined;
|
19
|
+
var optionMessage = undefined;
|
20
|
+
|
21
|
+
self.openOptionRect = function (optionGroup) {
|
22
|
+
optionGroup
|
23
|
+
.transition()
|
24
|
+
.attr("transform", "translate(" + UITab.style.optionRectWidth + ",0)");
|
25
|
+
};
|
26
|
+
|
27
|
+
self.closeOptionRect = function (optionGroup) {
|
28
|
+
optionGroup
|
29
|
+
.transition()
|
30
|
+
.attr("transform", "translate(" + (- UITab.style.optionRectWidth) + ", 0)");
|
31
|
+
};
|
32
|
+
|
33
|
+
self.render = function() {
|
34
|
+
|
35
|
+
console.log("Render: tab "+name+" "+delegate.parentApplicationViewController.name);
|
36
|
+
|
37
|
+
var layer = self.view;
|
38
|
+
|
39
|
+
if(optionGroup == undefined) {
|
40
|
+
optionGroup = layer.append("g")
|
41
|
+
.class("optionGroup");
|
42
|
+
}
|
43
|
+
|
44
|
+
if(optionRect == undefined) {
|
45
|
+
optionRect = optionGroup.append("rect")
|
46
|
+
.class("optionRect")
|
47
|
+
.class("pointer")
|
48
|
+
.width(UITab.style.optionRectWidth)
|
49
|
+
.height(UITab.style.height)
|
50
|
+
.x(UITab.style.width / 2 - UITab.style.optionRectWidth)
|
51
|
+
.y(-UITab.style.height/2)
|
52
|
+
.fill(self.palette.accent1.normal)
|
53
|
+
.on("mouseover", function() {
|
54
|
+
self.openOptionRect(optionGroup);
|
55
|
+
if (!delegate.selected) {
|
56
|
+
instanceTab.fill(self.palette.accent1.bright);
|
57
|
+
}
|
58
|
+
})
|
59
|
+
.on("mouseout", function () {
|
60
|
+
self.closeOptionRect(optionGroup);
|
61
|
+
if (!delegate.selected) {
|
62
|
+
instanceTab.fill(self.palette.accent1.normal);
|
63
|
+
}
|
64
|
+
})
|
65
|
+
.on("click", function() {
|
66
|
+
alert("ciao simona")
|
67
|
+
})
|
68
|
+
.opacity(0);
|
69
|
+
}
|
70
|
+
|
71
|
+
// add mail text to the option group
|
72
|
+
if(optionMessage == undefined) {
|
73
|
+
optionMessage = optionGroup.append("text")
|
74
|
+
.x(UITab.style.width / 2 - UITab.style.optionRectWidth + 50)
|
75
|
+
.y(0)
|
76
|
+
.class("mailIcon")
|
77
|
+
.class("pointer")
|
78
|
+
.class("no_interaction")
|
79
|
+
.attr("text-anchor", "middle")
|
80
|
+
.fill(self.palette.text.bright)
|
81
|
+
.text("subscribe")
|
82
|
+
.opacity(0);
|
83
|
+
}
|
84
|
+
|
85
|
+
// Tab background
|
86
|
+
if(instanceTab == undefined) {
|
87
|
+
instanceTab = layer.append("rect")
|
88
|
+
.class("instanceTab")
|
89
|
+
.class("pointer")
|
90
|
+
.x(-UITab.style.width / 2)
|
91
|
+
.y(-UITab.style.height / 2)
|
92
|
+
.margin(undefined)
|
93
|
+
.width(0)
|
94
|
+
.height(UITab.style.height)
|
95
|
+
.on("mouseover", function () {
|
96
|
+
if (!delegate.selected) {
|
97
|
+
d3.select(this).fill(self.palette.accent1.bright);
|
98
|
+
}
|
99
|
+
self.openOptionRect(optionGroup);
|
100
|
+
})
|
101
|
+
.on("mouseout", function () {
|
102
|
+
d3.select(this).fill(self.getTabColor());
|
103
|
+
self.closeOptionRect(optionGroup);
|
104
|
+
})
|
105
|
+
.on("click", function () {
|
106
|
+
self.delegate.clicked();
|
107
|
+
})
|
108
|
+
.fill(self.getTabColor());
|
109
|
+
}
|
110
|
+
|
111
|
+
// Tab text
|
112
|
+
if(instanceTabText == undefined) {
|
113
|
+
|
114
|
+
instanceTabText = layer
|
115
|
+
.append("text")
|
116
|
+
.class("pointer")
|
117
|
+
.class("instanceTabText")
|
118
|
+
.class("no_interaction")
|
119
|
+
.attr("text-anchor", "middle")
|
120
|
+
.x(-UITab.style.width / 2)
|
121
|
+
.fill(self.palette.text.bright);
|
122
|
+
}
|
123
|
+
|
124
|
+
if(self.delegate.parentApplicationViewController.expanded) {
|
125
|
+
|
126
|
+
// Tab background
|
127
|
+
instanceTab
|
128
|
+
.transition()
|
129
|
+
.duration(Animations.instance.INSTANCE_ENTER.duration)
|
130
|
+
.delay(Animations.instance.INSTANCE_ENTER.delay)
|
131
|
+
.margin(undefined)
|
132
|
+
.width(UITab.style.width)
|
133
|
+
.fill(self.getTabColor())
|
134
|
+
.opacity(1);
|
135
|
+
|
136
|
+
// Tab text
|
137
|
+
instanceTabText
|
138
|
+
.transition()
|
139
|
+
.duration(Animations.instance.INSTANCE_ENTER.duration)
|
140
|
+
.delay(Animations.instance.INSTANCE_ENTER.delay)
|
141
|
+
.x(0)
|
142
|
+
.opacity(1)
|
143
|
+
.text(name);
|
144
|
+
|
145
|
+
// Option rect
|
146
|
+
optionRect
|
147
|
+
.opacity(1)
|
148
|
+
.transition()
|
149
|
+
.duration(Animations.optionRect.INSTANCE_ENTER.duration)
|
150
|
+
.delay(Animations.optionRect.INSTANCE_ENTER.delay)
|
151
|
+
.width(UITab.style.optionRectWidth);
|
152
|
+
|
153
|
+
// Option message
|
154
|
+
optionMessage
|
155
|
+
.transition()
|
156
|
+
.duration(Animations.optionRect.INSTANCE_ENTER.duration)
|
157
|
+
.delay(Animations.optionRect.INSTANCE_ENTER.delay)
|
158
|
+
.opacity(1);
|
159
|
+
|
160
|
+
}
|
161
|
+
else {
|
162
|
+
|
163
|
+
// Tab background
|
164
|
+
instanceTab
|
165
|
+
.transition()
|
166
|
+
.duration(Animations.instance.INSTANCE_EXIT.duration)
|
167
|
+
.delay(Animations.instance.INSTANCE_EXIT.delay)
|
168
|
+
.margin(undefined)
|
169
|
+
.width(0)
|
170
|
+
.opacity(0);
|
171
|
+
|
172
|
+
// Tab text
|
173
|
+
instanceTabText
|
174
|
+
.data([{}])
|
175
|
+
.x(-UITab.style.width / 2)
|
176
|
+
.opacity(0);
|
177
|
+
|
178
|
+
// Option rect
|
179
|
+
optionRect
|
180
|
+
.width(0)
|
181
|
+
.opacity(0);
|
182
|
+
// Option message
|
183
|
+
optionMessage
|
184
|
+
.opacity(0);
|
185
|
+
}
|
186
|
+
};
|
187
|
+
|
188
|
+
self.getTabHeight = function() {
|
189
|
+
return Math.min(UITab.style.maxHeight, self.getParentHeight()/delegate.getTabsNumber());
|
190
|
+
};
|
191
|
+
|
192
|
+
self.getTabColor = function() {
|
193
|
+
var color;
|
194
|
+
if(delegate.selected) {
|
195
|
+
color = self.palette.accent1.dark;
|
196
|
+
}
|
197
|
+
else {
|
198
|
+
color = self.palette.accent1.normal;
|
199
|
+
}
|
200
|
+
return color;
|
201
|
+
};
|
202
|
+
|
203
|
+
self.getTopParent = function() {
|
204
|
+
return -windowViewController.height / 2 + UIApplication.style.margin;
|
205
|
+
};
|
206
|
+
|
207
|
+
self.getLeftParent = function() {
|
208
|
+
return -windowViewController.width / 2 + UIApplication.style.margin;
|
209
|
+
};
|
210
|
+
|
211
|
+
self.getParentHeight = function() {
|
212
|
+
return windowViewController.height - 2 * UIApplication.style.margin - UIApplication.style.titleBarHeight;
|
213
|
+
};
|
214
|
+
self.getParentWidth = function() {
|
215
|
+
return windowViewController.width - 2 * UIApplication.style.margin;
|
216
|
+
};
|
217
|
+
|
218
|
+
// Constructor
|
219
|
+
self.init = function() {
|
220
|
+
self.name = name;
|
221
|
+
}();
|
222
|
+
|
223
|
+
// Destructor
|
224
|
+
self.deinit = function() {
|
225
|
+
};
|
226
|
+
|
227
|
+
return self;
|
228
|
+
|
229
|
+
};
|
data/framework_components/monitoring-interface/css/Monitoring Interface_files/underscore-min.js
ADDED
@@ -0,0 +1,5 @@
|
|
1
|
+
// Underscore.js 1.8.2
|
2
|
+
// http://underscorejs.org
|
3
|
+
// (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
|
4
|
+
// Underscore may be freely distributed under the MIT license.
|
5
|
+
(function(){function n(n){function t(t,r,e,u,i,o){for(;i>=0&&o>i;i+=n){var a=u?u[i]:i;e=r(e,t[a],a,t)}return e}return function(r,e,u,i){e=d(e,i,4);var o=!w(r)&&m.keys(r),a=(o||r).length,c=n>0?0:a-1;return arguments.length<3&&(u=r[o?o[c]:c],c+=n),t(r,e,u,o,c,a)}}function t(n){return function(t,r,e){r=b(r,e);for(var u=null!=t&&t.length,i=n>0?0:u-1;i>=0&&u>i;i+=n)if(r(t[i],i,t))return i;return-1}}function r(n,t){var r=S.length,e=n.constructor,u=m.isFunction(e)&&e.prototype||o,i="constructor";for(m.has(n,i)&&!m.contains(t,i)&&t.push(i);r--;)i=S[r],i in n&&n[i]!==u[i]&&!m.contains(t,i)&&t.push(i)}var e=this,u=e._,i=Array.prototype,o=Object.prototype,a=Function.prototype,c=i.push,l=i.slice,f=o.toString,s=o.hasOwnProperty,p=Array.isArray,h=Object.keys,v=a.bind,g=Object.create,y=function(){},m=function(n){return n instanceof m?n:this instanceof m?void(this._wrapped=n):new m(n)};"undefined"!=typeof exports?("undefined"!=typeof module&&module.exports&&(exports=module.exports=m),exports._=m):e._=m,m.VERSION="1.8.2";var d=function(n,t,r){if(t===void 0)return n;switch(null==r?3:r){case 1:return function(r){return n.call(t,r)};case 2:return function(r,e){return n.call(t,r,e)};case 3:return function(r,e,u){return n.call(t,r,e,u)};case 4:return function(r,e,u,i){return n.call(t,r,e,u,i)}}return function(){return n.apply(t,arguments)}},b=function(n,t,r){return null==n?m.identity:m.isFunction(n)?d(n,t,r):m.isObject(n)?m.matcher(n):m.property(n)};m.iteratee=function(n,t){return b(n,t,1/0)};var x=function(n,t){return function(r){var e=arguments.length;if(2>e||null==r)return r;for(var u=1;e>u;u++)for(var i=arguments[u],o=n(i),a=o.length,c=0;a>c;c++){var l=o[c];t&&r[l]!==void 0||(r[l]=i[l])}return r}},_=function(n){if(!m.isObject(n))return{};if(g)return g(n);y.prototype=n;var t=new y;return y.prototype=null,t},j=Math.pow(2,53)-1,w=function(n){var t=n&&n.length;return"number"==typeof t&&t>=0&&j>=t};m.each=m.forEach=function(n,t,r){t=d(t,r);var e,u;if(w(n))for(e=0,u=n.length;u>e;e++)t(n[e],e,n);else{var i=m.keys(n);for(e=0,u=i.length;u>e;e++)t(n[i[e]],i[e],n)}return n},m.map=m.collect=function(n,t,r){t=b(t,r);for(var e=!w(n)&&m.keys(n),u=(e||n).length,i=Array(u),o=0;u>o;o++){var a=e?e[o]:o;i[o]=t(n[a],a,n)}return i},m.reduce=m.foldl=m.inject=n(1),m.reduceRight=m.foldr=n(-1),m.find=m.detect=function(n,t,r){var e;return e=w(n)?m.findIndex(n,t,r):m.findKey(n,t,r),e!==void 0&&e!==-1?n[e]:void 0},m.filter=m.select=function(n,t,r){var e=[];return t=b(t,r),m.each(n,function(n,r,u){t(n,r,u)&&e.push(n)}),e},m.reject=function(n,t,r){return m.filter(n,m.negate(b(t)),r)},m.every=m.all=function(n,t,r){t=b(t,r);for(var e=!w(n)&&m.keys(n),u=(e||n).length,i=0;u>i;i++){var o=e?e[i]:i;if(!t(n[o],o,n))return!1}return!0},m.some=m.any=function(n,t,r){t=b(t,r);for(var e=!w(n)&&m.keys(n),u=(e||n).length,i=0;u>i;i++){var o=e?e[i]:i;if(t(n[o],o,n))return!0}return!1},m.contains=m.includes=m.include=function(n,t,r){return w(n)||(n=m.values(n)),m.indexOf(n,t,"number"==typeof r&&r)>=0},m.invoke=function(n,t){var r=l.call(arguments,2),e=m.isFunction(t);return m.map(n,function(n){var u=e?t:n[t];return null==u?u:u.apply(n,r)})},m.pluck=function(n,t){return m.map(n,m.property(t))},m.where=function(n,t){return m.filter(n,m.matcher(t))},m.findWhere=function(n,t){return m.find(n,m.matcher(t))},m.max=function(n,t,r){var e,u,i=-1/0,o=-1/0;if(null==t&&null!=n){n=w(n)?n:m.values(n);for(var a=0,c=n.length;c>a;a++)e=n[a],e>i&&(i=e)}else t=b(t,r),m.each(n,function(n,r,e){u=t(n,r,e),(u>o||u===-1/0&&i===-1/0)&&(i=n,o=u)});return i},m.min=function(n,t,r){var e,u,i=1/0,o=1/0;if(null==t&&null!=n){n=w(n)?n:m.values(n);for(var a=0,c=n.length;c>a;a++)e=n[a],i>e&&(i=e)}else t=b(t,r),m.each(n,function(n,r,e){u=t(n,r,e),(o>u||1/0===u&&1/0===i)&&(i=n,o=u)});return i},m.shuffle=function(n){for(var t,r=w(n)?n:m.values(n),e=r.length,u=Array(e),i=0;e>i;i++)t=m.random(0,i),t!==i&&(u[i]=u[t]),u[t]=r[i];return u},m.sample=function(n,t,r){return null==t||r?(w(n)||(n=m.values(n)),n[m.random(n.length-1)]):m.shuffle(n).slice(0,Math.max(0,t))},m.sortBy=function(n,t,r){return t=b(t,r),m.pluck(m.map(n,function(n,r,e){return{value:n,index:r,criteria:t(n,r,e)}}).sort(function(n,t){var r=n.criteria,e=t.criteria;if(r!==e){if(r>e||r===void 0)return 1;if(e>r||e===void 0)return-1}return n.index-t.index}),"value")};var A=function(n){return function(t,r,e){var u={};return r=b(r,e),m.each(t,function(e,i){var o=r(e,i,t);n(u,e,o)}),u}};m.groupBy=A(function(n,t,r){m.has(n,r)?n[r].push(t):n[r]=[t]}),m.indexBy=A(function(n,t,r){n[r]=t}),m.countBy=A(function(n,t,r){m.has(n,r)?n[r]++:n[r]=1}),m.toArray=function(n){return n?m.isArray(n)?l.call(n):w(n)?m.map(n,m.identity):m.values(n):[]},m.size=function(n){return null==n?0:w(n)?n.length:m.keys(n).length},m.partition=function(n,t,r){t=b(t,r);var e=[],u=[];return m.each(n,function(n,r,i){(t(n,r,i)?e:u).push(n)}),[e,u]},m.first=m.head=m.take=function(n,t,r){return null==n?void 0:null==t||r?n[0]:m.initial(n,n.length-t)},m.initial=function(n,t,r){return l.call(n,0,Math.max(0,n.length-(null==t||r?1:t)))},m.last=function(n,t,r){return null==n?void 0:null==t||r?n[n.length-1]:m.rest(n,Math.max(0,n.length-t))},m.rest=m.tail=m.drop=function(n,t,r){return l.call(n,null==t||r?1:t)},m.compact=function(n){return m.filter(n,m.identity)};var k=function(n,t,r,e){for(var u=[],i=0,o=e||0,a=n&&n.length;a>o;o++){var c=n[o];if(w(c)&&(m.isArray(c)||m.isArguments(c))){t||(c=k(c,t,r));var l=0,f=c.length;for(u.length+=f;f>l;)u[i++]=c[l++]}else r||(u[i++]=c)}return u};m.flatten=function(n,t){return k(n,t,!1)},m.without=function(n){return m.difference(n,l.call(arguments,1))},m.uniq=m.unique=function(n,t,r,e){if(null==n)return[];m.isBoolean(t)||(e=r,r=t,t=!1),null!=r&&(r=b(r,e));for(var u=[],i=[],o=0,a=n.length;a>o;o++){var c=n[o],l=r?r(c,o,n):c;t?(o&&i===l||u.push(c),i=l):r?m.contains(i,l)||(i.push(l),u.push(c)):m.contains(u,c)||u.push(c)}return u},m.union=function(){return m.uniq(k(arguments,!0,!0))},m.intersection=function(n){if(null==n)return[];for(var t=[],r=arguments.length,e=0,u=n.length;u>e;e++){var i=n[e];if(!m.contains(t,i)){for(var o=1;r>o&&m.contains(arguments[o],i);o++);o===r&&t.push(i)}}return t},m.difference=function(n){var t=k(arguments,!0,!0,1);return m.filter(n,function(n){return!m.contains(t,n)})},m.zip=function(){return m.unzip(arguments)},m.unzip=function(n){for(var t=n&&m.max(n,"length").length||0,r=Array(t),e=0;t>e;e++)r[e]=m.pluck(n,e);return r},m.object=function(n,t){for(var r={},e=0,u=n&&n.length;u>e;e++)t?r[n[e]]=t[e]:r[n[e][0]]=n[e][1];return r},m.indexOf=function(n,t,r){var e=0,u=n&&n.length;if("number"==typeof r)e=0>r?Math.max(0,u+r):r;else if(r&&u)return e=m.sortedIndex(n,t),n[e]===t?e:-1;if(t!==t)return m.findIndex(l.call(n,e),m.isNaN);for(;u>e;e++)if(n[e]===t)return e;return-1},m.lastIndexOf=function(n,t,r){var e=n?n.length:0;if("number"==typeof r&&(e=0>r?e+r+1:Math.min(e,r+1)),t!==t)return m.findLastIndex(l.call(n,0,e),m.isNaN);for(;--e>=0;)if(n[e]===t)return e;return-1},m.findIndex=t(1),m.findLastIndex=t(-1),m.sortedIndex=function(n,t,r,e){r=b(r,e,1);for(var u=r(t),i=0,o=n.length;o>i;){var a=Math.floor((i+o)/2);r(n[a])<u?i=a+1:o=a}return i},m.range=function(n,t,r){arguments.length<=1&&(t=n||0,n=0),r=r||1;for(var e=Math.max(Math.ceil((t-n)/r),0),u=Array(e),i=0;e>i;i++,n+=r)u[i]=n;return u};var O=function(n,t,r,e,u){if(!(e instanceof t))return n.apply(r,u);var i=_(n.prototype),o=n.apply(i,u);return m.isObject(o)?o:i};m.bind=function(n,t){if(v&&n.bind===v)return v.apply(n,l.call(arguments,1));if(!m.isFunction(n))throw new TypeError("Bind must be called on a function");var r=l.call(arguments,2),e=function(){return O(n,e,t,this,r.concat(l.call(arguments)))};return e},m.partial=function(n){var t=l.call(arguments,1),r=function(){for(var e=0,u=t.length,i=Array(u),o=0;u>o;o++)i[o]=t[o]===m?arguments[e++]:t[o];for(;e<arguments.length;)i.push(arguments[e++]);return O(n,r,this,this,i)};return r},m.bindAll=function(n){var t,r,e=arguments.length;if(1>=e)throw new Error("bindAll must be passed function names");for(t=1;e>t;t++)r=arguments[t],n[r]=m.bind(n[r],n);return n},m.memoize=function(n,t){var r=function(e){var u=r.cache,i=""+(t?t.apply(this,arguments):e);return m.has(u,i)||(u[i]=n.apply(this,arguments)),u[i]};return r.cache={},r},m.delay=function(n,t){var r=l.call(arguments,2);return setTimeout(function(){return n.apply(null,r)},t)},m.defer=m.partial(m.delay,m,1),m.throttle=function(n,t,r){var e,u,i,o=null,a=0;r||(r={});var c=function(){a=r.leading===!1?0:m.now(),o=null,i=n.apply(e,u),o||(e=u=null)};return function(){var l=m.now();a||r.leading!==!1||(a=l);var f=t-(l-a);return e=this,u=arguments,0>=f||f>t?(o&&(clearTimeout(o),o=null),a=l,i=n.apply(e,u),o||(e=u=null)):o||r.trailing===!1||(o=setTimeout(c,f)),i}},m.debounce=function(n,t,r){var e,u,i,o,a,c=function(){var l=m.now()-o;t>l&&l>=0?e=setTimeout(c,t-l):(e=null,r||(a=n.apply(i,u),e||(i=u=null)))};return function(){i=this,u=arguments,o=m.now();var l=r&&!e;return e||(e=setTimeout(c,t)),l&&(a=n.apply(i,u),i=u=null),a}},m.wrap=function(n,t){return m.partial(t,n)},m.negate=function(n){return function(){return!n.apply(this,arguments)}},m.compose=function(){var n=arguments,t=n.length-1;return function(){for(var r=t,e=n[t].apply(this,arguments);r--;)e=n[r].call(this,e);return e}},m.after=function(n,t){return function(){return--n<1?t.apply(this,arguments):void 0}},m.before=function(n,t){var r;return function(){return--n>0&&(r=t.apply(this,arguments)),1>=n&&(t=null),r}},m.once=m.partial(m.before,2);var F=!{toString:null}.propertyIsEnumerable("toString"),S=["valueOf","isPrototypeOf","toString","propertyIsEnumerable","hasOwnProperty","toLocaleString"];m.keys=function(n){if(!m.isObject(n))return[];if(h)return h(n);var t=[];for(var e in n)m.has(n,e)&&t.push(e);return F&&r(n,t),t},m.allKeys=function(n){if(!m.isObject(n))return[];var t=[];for(var e in n)t.push(e);return F&&r(n,t),t},m.values=function(n){for(var t=m.keys(n),r=t.length,e=Array(r),u=0;r>u;u++)e[u]=n[t[u]];return e},m.mapObject=function(n,t,r){t=b(t,r);for(var e,u=m.keys(n),i=u.length,o={},a=0;i>a;a++)e=u[a],o[e]=t(n[e],e,n);return o},m.pairs=function(n){for(var t=m.keys(n),r=t.length,e=Array(r),u=0;r>u;u++)e[u]=[t[u],n[t[u]]];return e},m.invert=function(n){for(var t={},r=m.keys(n),e=0,u=r.length;u>e;e++)t[n[r[e]]]=r[e];return t},m.functions=m.methods=function(n){var t=[];for(var r in n)m.isFunction(n[r])&&t.push(r);return t.sort()},m.extend=x(m.allKeys),m.extendOwn=m.assign=x(m.keys),m.findKey=function(n,t,r){t=b(t,r);for(var e,u=m.keys(n),i=0,o=u.length;o>i;i++)if(e=u[i],t(n[e],e,n))return e},m.pick=function(n,t,r){var e,u,i={},o=n;if(null==o)return i;m.isFunction(t)?(u=m.allKeys(o),e=d(t,r)):(u=k(arguments,!1,!1,1),e=function(n,t,r){return t in r},o=Object(o));for(var a=0,c=u.length;c>a;a++){var l=u[a],f=o[l];e(f,l,o)&&(i[l]=f)}return i},m.omit=function(n,t,r){if(m.isFunction(t))t=m.negate(t);else{var e=m.map(k(arguments,!1,!1,1),String);t=function(n,t){return!m.contains(e,t)}}return m.pick(n,t,r)},m.defaults=x(m.allKeys,!0),m.clone=function(n){return m.isObject(n)?m.isArray(n)?n.slice():m.extend({},n):n},m.tap=function(n,t){return t(n),n},m.isMatch=function(n,t){var r=m.keys(t),e=r.length;if(null==n)return!e;for(var u=Object(n),i=0;e>i;i++){var o=r[i];if(t[o]!==u[o]||!(o in u))return!1}return!0};var E=function(n,t,r,e){if(n===t)return 0!==n||1/n===1/t;if(null==n||null==t)return n===t;n instanceof m&&(n=n._wrapped),t instanceof m&&(t=t._wrapped);var u=f.call(n);if(u!==f.call(t))return!1;switch(u){case"[object RegExp]":case"[object String]":return""+n==""+t;case"[object Number]":return+n!==+n?+t!==+t:0===+n?1/+n===1/t:+n===+t;case"[object Date]":case"[object Boolean]":return+n===+t}var i="[object Array]"===u;if(!i){if("object"!=typeof n||"object"!=typeof t)return!1;var o=n.constructor,a=t.constructor;if(o!==a&&!(m.isFunction(o)&&o instanceof o&&m.isFunction(a)&&a instanceof a)&&"constructor"in n&&"constructor"in t)return!1}r=r||[],e=e||[];for(var c=r.length;c--;)if(r[c]===n)return e[c]===t;if(r.push(n),e.push(t),i){if(c=n.length,c!==t.length)return!1;for(;c--;)if(!E(n[c],t[c],r,e))return!1}else{var l,s=m.keys(n);if(c=s.length,m.keys(t).length!==c)return!1;for(;c--;)if(l=s[c],!m.has(t,l)||!E(n[l],t[l],r,e))return!1}return r.pop(),e.pop(),!0};m.isEqual=function(n,t){return E(n,t)},m.isEmpty=function(n){return null==n?!0:w(n)&&(m.isArray(n)||m.isString(n)||m.isArguments(n))?0===n.length:0===m.keys(n).length},m.isElement=function(n){return!(!n||1!==n.nodeType)},m.isArray=p||function(n){return"[object Array]"===f.call(n)},m.isObject=function(n){var t=typeof n;return"function"===t||"object"===t&&!!n},m.each(["Arguments","Function","String","Number","Date","RegExp","Error"],function(n){m["is"+n]=function(t){return f.call(t)==="[object "+n+"]"}}),m.isArguments(arguments)||(m.isArguments=function(n){return m.has(n,"callee")}),"function"!=typeof/./&&"object"!=typeof Int8Array&&(m.isFunction=function(n){return"function"==typeof n||!1}),m.isFinite=function(n){return isFinite(n)&&!isNaN(parseFloat(n))},m.isNaN=function(n){return m.isNumber(n)&&n!==+n},m.isBoolean=function(n){return n===!0||n===!1||"[object Boolean]"===f.call(n)},m.isNull=function(n){return null===n},m.isUndefined=function(n){return n===void 0},m.has=function(n,t){return null!=n&&s.call(n,t)},m.noConflict=function(){return e._=u,this},m.identity=function(n){return n},m.constant=function(n){return function(){return n}},m.noop=function(){},m.property=function(n){return function(t){return null==t?void 0:t[n]}},m.propertyOf=function(n){return null==n?function(){}:function(t){return n[t]}},m.matcher=m.matches=function(n){return n=m.extendOwn({},n),function(t){return m.isMatch(t,n)}},m.times=function(n,t,r){var e=Array(Math.max(0,n));t=d(t,r,1);for(var u=0;n>u;u++)e[u]=t(u);return e},m.random=function(n,t){return null==t&&(t=n,n=0),n+Math.floor(Math.random()*(t-n+1))},m.now=Date.now||function(){return(new Date).getTime()};var M={"&":"&","<":"<",">":">",'"':""","'":"'","`":"`"},N=m.invert(M),I=function(n){var t=function(t){return n[t]},r="(?:"+m.keys(n).join("|")+")",e=RegExp(r),u=RegExp(r,"g");return function(n){return n=null==n?"":""+n,e.test(n)?n.replace(u,t):n}};m.escape=I(M),m.unescape=I(N),m.result=function(n,t,r){var e=null==n?void 0:n[t];return e===void 0&&(e=r),m.isFunction(e)?e.call(n):e};var B=0;m.uniqueId=function(n){var t=++B+"";return n?n+t:t},m.templateSettings={evaluate:/<%([\s\S]+?)%>/g,interpolate:/<%=([\s\S]+?)%>/g,escape:/<%-([\s\S]+?)%>/g};var T=/(.)^/,R={"'":"'","\\":"\\","\r":"r","\n":"n","\u2028":"u2028","\u2029":"u2029"},q=/\\|'|\r|\n|\u2028|\u2029/g,K=function(n){return"\\"+R[n]};m.template=function(n,t,r){!t&&r&&(t=r),t=m.defaults({},t,m.templateSettings);var e=RegExp([(t.escape||T).source,(t.interpolate||T).source,(t.evaluate||T).source].join("|")+"|$","g"),u=0,i="__p+='";n.replace(e,function(t,r,e,o,a){return i+=n.slice(u,a).replace(q,K),u=a+t.length,r?i+="'+\n((__t=("+r+"))==null?'':_.escape(__t))+\n'":e?i+="'+\n((__t=("+e+"))==null?'':__t)+\n'":o&&(i+="';\n"+o+"\n__p+='"),t}),i+="';\n",t.variable||(i="with(obj||{}){\n"+i+"}\n"),i="var __t,__p='',__j=Array.prototype.join,"+"print=function(){__p+=__j.call(arguments,'');};\n"+i+"return __p;\n";try{var o=new Function(t.variable||"obj","_",i)}catch(a){throw a.source=i,a}var c=function(n){return o.call(this,n,m)},l=t.variable||"obj";return c.source="function("+l+"){\n"+i+"}",c},m.chain=function(n){var t=m(n);return t._chain=!0,t};var z=function(n,t){return n._chain?m(t).chain():t};m.mixin=function(n){m.each(m.functions(n),function(t){var r=m[t]=n[t];m.prototype[t]=function(){var n=[this._wrapped];return c.apply(n,arguments),z(this,r.apply(m,n))}})},m.mixin(m),m.each(["pop","push","reverse","shift","sort","splice","unshift"],function(n){var t=i[n];m.prototype[n]=function(){var r=this._wrapped;return t.apply(r,arguments),"shift"!==n&&"splice"!==n||0!==r.length||delete r[0],z(this,r)}}),m.each(["concat","join","slice"],function(n){var t=i[n];m.prototype[n]=function(){return z(this,t.apply(this._wrapped,arguments))}}),m.prototype.value=function(){return this._wrapped},m.prototype.valueOf=m.prototype.toJSON=m.prototype.value,m.prototype.toString=function(){return""+this._wrapped},"function"==typeof define&&define.amd&&define("underscore",[],function(){return m})}).call(this);
|
data/framework_components/monitoring-interface/css/Monitoring Interface_files/view-controller.js
ADDED
@@ -0,0 +1,68 @@
|
|
1
|
+
var ViewController = function(view) {
|
2
|
+
var self = {};
|
3
|
+
|
4
|
+
// Protected variables
|
5
|
+
self._view = undefined;
|
6
|
+
self._uis = [];
|
7
|
+
|
8
|
+
//#GETTER AND SETTER
|
9
|
+
self.__defineSetter__("view", function(view){
|
10
|
+
self._view = view;
|
11
|
+
});
|
12
|
+
|
13
|
+
self.__defineGetter__("view", function(){
|
14
|
+
return self._view;
|
15
|
+
});
|
16
|
+
|
17
|
+
self.render = function() {
|
18
|
+
self._uis.forEach(function(ui) {
|
19
|
+
ui.render(self._view);
|
20
|
+
});
|
21
|
+
};
|
22
|
+
|
23
|
+
// Add ui components
|
24
|
+
self.addUIApplication = function() {
|
25
|
+
var uiApplication = UIApplication(self);
|
26
|
+
self.addUiComponent(uiApplication);
|
27
|
+
return uiApplication;
|
28
|
+
};
|
29
|
+
|
30
|
+
self.addUIConnectionView = function() {
|
31
|
+
var uiConnectionView = UIConnectionView(self);
|
32
|
+
self.addUiComponent(uiConnectionView);
|
33
|
+
return uiConnectionView;
|
34
|
+
};
|
35
|
+
|
36
|
+
self.addUITab = function(name) {
|
37
|
+
var uiTab = UITab(self, name);
|
38
|
+
self.addUiComponent(uiTab);
|
39
|
+
return uiTab;
|
40
|
+
};
|
41
|
+
|
42
|
+
self.addUINotification = function(notificationName) {
|
43
|
+
var uiNotification = UINotification(self);
|
44
|
+
uiNotification.name = notificationName;
|
45
|
+
self.addUiComponent(uiNotification);
|
46
|
+
return uiNotification;
|
47
|
+
};
|
48
|
+
|
49
|
+
self.addUiComponent = function(ui) {
|
50
|
+
self._uis.push(ui);
|
51
|
+
};
|
52
|
+
|
53
|
+
self.newView = function() {
|
54
|
+
return self._view.newView();
|
55
|
+
};
|
56
|
+
|
57
|
+
// Constructor
|
58
|
+
self.init = function() {
|
59
|
+
self._view = view;
|
60
|
+
}();
|
61
|
+
|
62
|
+
// Destructor
|
63
|
+
self.deinit = function() {
|
64
|
+
self._view.remove();
|
65
|
+
};
|
66
|
+
|
67
|
+
return self;
|
68
|
+
};
|
@@ -0,0 +1,169 @@
|
|
1
|
+
var WindowViewController = function(view) {
|
2
|
+
var self = ViewController(view);
|
3
|
+
|
4
|
+
// Static variables
|
5
|
+
WindowViewController.style = {
|
6
|
+
margin: 10
|
7
|
+
};
|
8
|
+
|
9
|
+
// Protected variables
|
10
|
+
self._width = undefined;
|
11
|
+
self._height = undefined;
|
12
|
+
self._applicationViewControllers = {}; // UIApplication array
|
13
|
+
self._center = undefined;
|
14
|
+
|
15
|
+
|
16
|
+
// Private variables
|
17
|
+
var rectGrid = undefined;
|
18
|
+
|
19
|
+
self.updateViewBoxAnimated = function() {
|
20
|
+
self._width = window.innerWidth;
|
21
|
+
self._height = window.innerHeight;
|
22
|
+
if(self._center == undefined)
|
23
|
+
self._view.transition().attr("viewBox", "0 0 " + self._width + " " + self._height);
|
24
|
+
else
|
25
|
+
self._view.transition().attr("viewBox", (-self._width/2 + self._center.x) + " " + (-self._height/2 + self._center.y) + " " + self._width + " " + self._height);
|
26
|
+
};
|
27
|
+
|
28
|
+
self.updateViewBox = function() {
|
29
|
+
self._width = window.innerWidth;
|
30
|
+
self._height = window.innerHeight;
|
31
|
+
if(self._center == undefined)
|
32
|
+
self._view.attr("viewBox", "0 0 " + self._width + " " + self._height);
|
33
|
+
else
|
34
|
+
self._view.attr("viewBox", (-self._width/2 + self._center.x) + " " + (-self._height/2 + self._center.y) + " " + self._width + " " + self._height);
|
35
|
+
};
|
36
|
+
|
37
|
+
self.updateRectGrid = function() {
|
38
|
+
rectGrid = d3.layout.grid()
|
39
|
+
.bands()
|
40
|
+
.size([window.innerWidth - WindowViewController.style.margin,
|
41
|
+
window.innerHeight- WindowViewController.style.margin])
|
42
|
+
.padding([0.1, 0.1]);
|
43
|
+
};
|
44
|
+
|
45
|
+
self.resizeWindow = function() {
|
46
|
+
|
47
|
+
self.updateViewBox();
|
48
|
+
|
49
|
+
self.updateRectGrid();
|
50
|
+
|
51
|
+
if(applicationModel.data != undefined) {
|
52
|
+
self.renderData(applicationModel.data.applications)
|
53
|
+
}
|
54
|
+
|
55
|
+
//TODO: Send notification
|
56
|
+
};
|
57
|
+
|
58
|
+
//#GETTER AND SETTER
|
59
|
+
self.__defineGetter__("height", function(){
|
60
|
+
return self._height;
|
61
|
+
});
|
62
|
+
|
63
|
+
self.__defineGetter__("width", function(){
|
64
|
+
return self._width;
|
65
|
+
});
|
66
|
+
|
67
|
+
|
68
|
+
|
69
|
+
// Render function of the component
|
70
|
+
self.renderData = function(data) {
|
71
|
+
|
72
|
+
// Create application view controllers
|
73
|
+
self._view.selectAll(".applicationView")
|
74
|
+
.data(data)
|
75
|
+
.enter()
|
76
|
+
.append("g")
|
77
|
+
.class("applicationView")
|
78
|
+
.translate(self._width / 2, self._height / 2)
|
79
|
+
.each(function(data) {
|
80
|
+
var applicationViewController = ApplicationViewController(data.name, d3.select(this));
|
81
|
+
this.applicationViewController = applicationViewController;
|
82
|
+
self._applicationViewControllers[data.name] = applicationViewController;
|
83
|
+
});
|
84
|
+
|
85
|
+
// Update data in applications
|
86
|
+
self._view.selectAll(".applicationView")
|
87
|
+
.data(rectGrid(data))
|
88
|
+
.transition()
|
89
|
+
.duration(Animations.application.GRID_LAYOUT_REPOSITION.duration)
|
90
|
+
//.attr("transform", function(d) { return "translate(" + (d.x + rectGrid.nodeSize()[0]/2) + "," + (d.y + rectGrid.nodeSize()[1]/2) + ")"; })
|
91
|
+
.each(function(data) {
|
92
|
+
var applicationViewController = this.applicationViewController;
|
93
|
+
applicationViewController.name = data.name;
|
94
|
+
applicationViewController.coordinates = {
|
95
|
+
x: data.x + rectGrid.nodeSize()[0] / 2,
|
96
|
+
y: data.y + rectGrid.nodeSize()[1] / 2
|
97
|
+
};
|
98
|
+
|
99
|
+
// Render the application
|
100
|
+
applicationViewController.render();
|
101
|
+
});
|
102
|
+
|
103
|
+
// Update the application position
|
104
|
+
if(applicationModel.viewControllerApplicationSelected == undefined) {
|
105
|
+
// Update the position of all appllications
|
106
|
+
self._view.selectAll(".applicationView")
|
107
|
+
.data(rectGrid(data))
|
108
|
+
.transition()
|
109
|
+
.duration(Animations.application.GRID_LAYOUT_REPOSITION.duration)
|
110
|
+
.attr("transform", function (d) {
|
111
|
+
return "translate(" + (d.x + rectGrid.nodeSize()[0] / 2) + "," + (d.y + rectGrid.nodeSize()[1] / 2) + ")";
|
112
|
+
});
|
113
|
+
}
|
114
|
+
|
115
|
+
|
116
|
+
// Delete old applications
|
117
|
+
self._view.selectAll(".applicationView")
|
118
|
+
.data(data)
|
119
|
+
.exit()
|
120
|
+
.each(function(data) {
|
121
|
+
var applicationViewController = this.applicationViewController;
|
122
|
+
applicationViewController.deinit();
|
123
|
+
delete self._applicationViewControllers[data.name];
|
124
|
+
})
|
125
|
+
.remove();
|
126
|
+
};
|
127
|
+
|
128
|
+
self.center = function(x, y) {
|
129
|
+
self._center = {x: x, y: y};
|
130
|
+
self.updateViewBoxAnimated();
|
131
|
+
};
|
132
|
+
|
133
|
+
self.resetCenter = function() {
|
134
|
+
self._center = undefined;
|
135
|
+
self.updateViewBoxAnimated();
|
136
|
+
};
|
137
|
+
|
138
|
+
// Constructor
|
139
|
+
self.init = function() {
|
140
|
+
|
141
|
+
// Subscribe to data notification
|
142
|
+
notificationCenter.subscribe(Notifications.data.APPLICATION_DATA_CHANGE,
|
143
|
+
function() {
|
144
|
+
self.updateRectGrid();
|
145
|
+
self.renderData(applicationModel.data.applications);
|
146
|
+
});
|
147
|
+
|
148
|
+
notificationCenter.subscribe(Notifications.ui.APPLICATION_REDUCTION_FINISHED,
|
149
|
+
function() {
|
150
|
+
self.updateRectGrid();
|
151
|
+
self.renderData(applicationModel.data.applications);
|
152
|
+
});
|
153
|
+
|
154
|
+
window.addEventListener("resize", self.resizeWindow);
|
155
|
+
|
156
|
+
// Init the grid layout
|
157
|
+
self.updateRectGrid();
|
158
|
+
}();
|
159
|
+
|
160
|
+
// Destructor
|
161
|
+
self.deinit = function() {
|
162
|
+
// Place here the code for dealloc eventual objects
|
163
|
+
};
|
164
|
+
|
165
|
+
return self;
|
166
|
+
|
167
|
+
};
|
168
|
+
|
169
|
+
var windowViewController = WindowViewController();
|