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.
Files changed (148) hide show
  1. checksums.yaml +4 -4
  2. data/VERSION +1 -1
  3. data/framework_components/monitoring-bot/monitoring-bot.rb +11 -2
  4. data/framework_components/monitoring-interface/.gitignore +2 -0
  5. data/framework_components/monitoring-interface/README.md +1 -0
  6. data/framework_components/monitoring-interface/bower.json +29 -0
  7. data/framework_components/monitoring-interface/bower_components/bower-mqttws/.bower.json +23 -0
  8. data/framework_components/monitoring-interface/bower_components/bower-mqttws/bower.json +14 -0
  9. data/framework_components/monitoring-interface/bower_components/bower-mqttws/mqttws31.js +2081 -0
  10. data/framework_components/monitoring-interface/bower_components/bower-mqttws/readme.md +4 -0
  11. data/framework_components/monitoring-interface/bower_components/nutella_lib/.bower.json +37 -0
  12. data/framework_components/monitoring-interface/bower_components/nutella_lib/LICENSE +21 -0
  13. data/framework_components/monitoring-interface/bower_components/nutella_lib/README.md +15 -0
  14. data/framework_components/monitoring-interface/bower_components/nutella_lib/bower.json +28 -0
  15. data/framework_components/monitoring-interface/bower_components/nutella_lib/examples/browser/mqtt_client_hello_world.html +23 -0
  16. data/framework_components/monitoring-interface/bower_components/nutella_lib/examples/browser/nutella_hello_world.html +52 -0
  17. data/framework_components/monitoring-interface/bower_components/nutella_lib/examples/node/mqtt_client_hello_world.js +14 -0
  18. data/framework_components/monitoring-interface/bower_components/nutella_lib/examples/node/nutella_hello_world.js +38 -0
  19. data/framework_components/monitoring-interface/bower_components/nutella_lib/nutella_lib.js +789 -0
  20. data/framework_components/monitoring-interface/bower_components/nutella_lib/package.json +30 -0
  21. data/framework_components/monitoring-interface/css/Monitoring Interface.html +215 -0
  22. data/framework_components/monitoring-interface/css/Monitoring Interface_files/animations.js +27 -0
  23. data/framework_components/monitoring-interface/css/Monitoring Interface_files/application-view-controller.js +232 -0
  24. data/framework_components/monitoring-interface/css/Monitoring Interface_files/applications-model.js +61 -0
  25. data/framework_components/monitoring-interface/css/Monitoring Interface_files/bootstrap.min.js +7 -0
  26. data/framework_components/monitoring-interface/css/Monitoring Interface_files/cursor.css +7 -0
  27. data/framework_components/monitoring-interface/css/Monitoring Interface_files/d3.v3.min.js +5 -0
  28. data/framework_components/monitoring-interface/css/Monitoring Interface_files/graphics.js +156 -0
  29. data/framework_components/monitoring-interface/css/Monitoring Interface_files/grid-layout.js +103 -0
  30. data/framework_components/monitoring-interface/css/Monitoring Interface_files/highlight.min.js +2 -0
  31. data/framework_components/monitoring-interface/css/Monitoring Interface_files/instance-view-controller.js +104 -0
  32. data/framework_components/monitoring-interface/css/Monitoring Interface_files/jquery-1.10.0.min.js +6 -0
  33. data/framework_components/monitoring-interface/css/Monitoring Interface_files/notification-center.js +63 -0
  34. data/framework_components/monitoring-interface/css/Monitoring Interface_files/notifications.js +14 -0
  35. data/framework_components/monitoring-interface/css/Monitoring Interface_files/page.css +33 -0
  36. data/framework_components/monitoring-interface/css/Monitoring Interface_files/radial-layout.js +175 -0
  37. data/framework_components/monitoring-interface/css/Monitoring Interface_files/tab-table.js +8 -0
  38. data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-application.css +0 -0
  39. data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-application.js +320 -0
  40. data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-connection-view.css +10 -0
  41. data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-connection-view.js +426 -0
  42. data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-element.js +205 -0
  43. data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-notification.js +94 -0
  44. data/framework_components/monitoring-interface/css/Monitoring Interface_files/ui-tab.js +229 -0
  45. data/framework_components/monitoring-interface/css/Monitoring Interface_files/underscore-min.js +5 -0
  46. data/framework_components/monitoring-interface/css/Monitoring Interface_files/view-controller.js +68 -0
  47. data/framework_components/monitoring-interface/css/Monitoring Interface_files/window-view-controller.js +169 -0
  48. data/framework_components/monitoring-interface/css/alerts.css +3 -0
  49. data/framework_components/monitoring-interface/css/bootstrap.min.css +5 -0
  50. data/framework_components/monitoring-interface/css/cursor.css +7 -0
  51. data/framework_components/monitoring-interface/css/highlight.default.min.css +1 -0
  52. data/framework_components/monitoring-interface/css/page.css +41 -0
  53. data/framework_components/monitoring-interface/css/ui-application.css +0 -0
  54. data/framework_components/monitoring-interface/css/ui-connection-view.css +10 -0
  55. data/framework_components/monitoring-interface/css/ui-legend-view.css +7 -0
  56. data/framework_components/monitoring-interface/data/alert.json +8 -0
  57. data/framework_components/monitoring-interface/data/data.json +2118 -0
  58. data/framework_components/monitoring-interface/data/data2.json +814 -0
  59. data/framework_components/monitoring-interface/data/data3.json +823 -0
  60. data/framework_components/monitoring-interface/data/data4.json +848 -0
  61. data/framework_components/monitoring-interface/data/message.json +999 -0
  62. data/framework_components/monitoring-interface/gulpfile.js +29 -0
  63. data/framework_components/monitoring-interface/img/arrow_white.svg +120 -0
  64. data/framework_components/monitoring-interface/img/arrow_white_right.svg +104 -0
  65. data/framework_components/monitoring-interface/img/back.svg +164 -0
  66. data/framework_components/monitoring-interface/img/cross_red_border_white.svg +143 -0
  67. data/framework_components/monitoring-interface/img/cross_red_border_white_mouseover.svg +143 -0
  68. data/framework_components/monitoring-interface/img/email.svg +89 -0
  69. data/framework_components/monitoring-interface/img/email_highlighted.svg +89 -0
  70. data/framework_components/monitoring-interface/index.html +144 -0
  71. data/framework_components/monitoring-interface/js/d3/layout/grid-layout.js +103 -0
  72. data/framework_components/monitoring-interface/js/d3/layout/radial-layout.js +184 -0
  73. data/framework_components/monitoring-interface/js/d3/plugin/graphics.js +156 -0
  74. data/framework_components/monitoring-interface/js/d3/plugin/tab-table.js +8 -0
  75. data/framework_components/monitoring-interface/js/d3/ui/animations.js +27 -0
  76. data/framework_components/monitoring-interface/js/d3/ui/ui-application.js +471 -0
  77. data/framework_components/monitoring-interface/js/d3/ui/ui-connection-view.js +847 -0
  78. data/framework_components/monitoring-interface/js/d3/ui/ui-element.js +245 -0
  79. data/framework_components/monitoring-interface/js/d3/ui/ui-legend.js +174 -0
  80. data/framework_components/monitoring-interface/js/d3/ui/ui-notification.js +90 -0
  81. data/framework_components/monitoring-interface/js/d3/ui/ui-tab.js +309 -0
  82. data/framework_components/monitoring-interface/js/lib/JSXTransformer-0.12.2.js +15199 -0
  83. data/framework_components/monitoring-interface/js/lib/bootstrap.min.js +7 -0
  84. data/framework_components/monitoring-interface/js/lib/d3.v3.min.js +5 -0
  85. data/framework_components/monitoring-interface/js/lib/highlight.min.js +2 -0
  86. data/framework_components/monitoring-interface/js/lib/jquery-1.10.0.min.js +6 -0
  87. data/framework_components/monitoring-interface/js/lib/nutella_lib.js +5121 -0
  88. data/framework_components/monitoring-interface/js/lib/react-with-addons-0.12.2.js +19822 -0
  89. data/framework_components/monitoring-interface/js/lib/underscore-min.js +5 -0
  90. data/framework_components/monitoring-interface/js/model/alerts-model.js +74 -0
  91. data/framework_components/monitoring-interface/js/model/applications-model.js +78 -0
  92. data/framework_components/monitoring-interface/js/model/messages-model.js +112 -0
  93. data/framework_components/monitoring-interface/js/notification/notification-center.js +63 -0
  94. data/framework_components/monitoring-interface/js/notification/notifications.js +21 -0
  95. data/framework_components/monitoring-interface/js/react/dist/ui-alerts.js +178 -0
  96. data/framework_components/monitoring-interface/js/react/dist/ui-message-send.js +389 -0
  97. data/framework_components/monitoring-interface/js/react/dist/ui-messages.js +103 -0
  98. data/framework_components/monitoring-interface/js/react/src/ui-alerts.js +178 -0
  99. data/framework_components/monitoring-interface/js/react/src/ui-message-send.js +389 -0
  100. data/framework_components/monitoring-interface/js/react/src/ui-messages.js +103 -0
  101. data/framework_components/monitoring-interface/js/view-controller/application-view-controller.js +256 -0
  102. data/framework_components/monitoring-interface/js/view-controller/instance-view-controller.js +112 -0
  103. data/framework_components/monitoring-interface/js/view-controller/view-controller.js +74 -0
  104. data/framework_components/monitoring-interface/js/view-controller/window-view-controller.js +169 -0
  105. data/framework_components/monitoring-interface/nutella.json +6 -0
  106. data/framework_components/order.json +1 -0
  107. data/framework_components/roomcast-bot/roomcast_bot.rb +139 -117
  108. data/framework_components/roomcast-channel-creator/dist/app.js +9 -7
  109. data/framework_components/roomcast-channel-creator/index.html +1 -1
  110. data/framework_components/roomcast-channel-creator/src/app/components/main.js +8 -6
  111. data/framework_components/roomcast-package-creator/dist/app.js +4 -4
  112. data/framework_components/roomcast-package-creator/index.html +1 -1
  113. data/framework_components/roomcast-package-creator/package.json +3 -3
  114. data/framework_components/roomcast-package-creator/src/app/components/ConfigurationsPanel.js +2 -2
  115. data/framework_components/roomcast-package-creator/src/app/components/PoolRow.js +1 -1
  116. data/framework_components/roomcast-teacher-controls/.gitignore +2 -0
  117. data/framework_components/roomcast-teacher-controls/README.md +9 -0
  118. data/framework_components/roomcast-teacher-controls/dist/app.js +38327 -0
  119. data/framework_components/roomcast-teacher-controls/dist/main.css +3052 -0
  120. data/framework_components/roomcast-teacher-controls/dist/nutella_lib.js +5121 -0
  121. data/framework_components/roomcast-teacher-controls/gulp/config.js +51 -0
  122. data/framework_components/roomcast-teacher-controls/gulp/tasks/browserify.js +77 -0
  123. data/framework_components/roomcast-teacher-controls/gulp/tasks/build.js +3 -0
  124. data/framework_components/roomcast-teacher-controls/gulp/tasks/css.js +7 -0
  125. data/framework_components/roomcast-teacher-controls/gulp/tasks/default.js +3 -0
  126. data/framework_components/roomcast-teacher-controls/gulp/tasks/fonts.js +7 -0
  127. data/framework_components/roomcast-teacher-controls/gulp/tasks/less.js +16 -0
  128. data/framework_components/roomcast-teacher-controls/gulp/tasks/mui-fonts.js +7 -0
  129. data/framework_components/roomcast-teacher-controls/gulp/tasks/nutella.js +7 -0
  130. data/framework_components/roomcast-teacher-controls/gulp/tasks/setWatch.js +5 -0
  131. data/framework_components/roomcast-teacher-controls/gulp/tasks/svgs.js +7 -0
  132. data/framework_components/roomcast-teacher-controls/gulp/tasks/watch.js +12 -0
  133. data/framework_components/roomcast-teacher-controls/gulp/util/bundleLogger.js +21 -0
  134. data/framework_components/roomcast-teacher-controls/gulp/util/handleErrors.js +15 -0
  135. data/framework_components/roomcast-teacher-controls/gulpfile.js +16 -0
  136. data/framework_components/roomcast-teacher-controls/index.html +51 -0
  137. data/framework_components/roomcast-teacher-controls/nutella.json +6 -0
  138. data/framework_components/roomcast-teacher-controls/package.json +38 -0
  139. data/framework_components/roomcast-teacher-controls/src/app/app.js +22 -0
  140. data/framework_components/roomcast-teacher-controls/src/app/components/ActivitiesGrid.js +87 -0
  141. data/framework_components/roomcast-teacher-controls/src/app/components/ActivityCard.js +141 -0
  142. data/framework_components/roomcast-teacher-controls/src/app/components/Channel.js +70 -0
  143. data/framework_components/roomcast-teacher-controls/src/app/components/Footer.js +34 -0
  144. data/framework_components/roomcast-teacher-controls/src/app/components/main.js +74 -0
  145. data/framework_components/roomcast-teacher-controls/src/less/main.less +186 -0
  146. data/framework_components/roomcast-teacher-controls/src/less/my_overrides.less +14 -0
  147. data/lib/commands/meta/run_command.rb +11 -9
  148. metadata +135 -2
@@ -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
+ };
@@ -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={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#x27;","`":"&#x60;"},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);
@@ -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();
@@ -0,0 +1,3 @@
1
+ .inline {
2
+ display:inline-block
3
+ }