diff options
Diffstat (limited to 'js/ninja.reel/ninja.js')
-rwxr-xr-x | js/ninja.reel/ninja.js | 84 |
1 files changed, 45 insertions, 39 deletions
diff --git a/js/ninja.reel/ninja.js b/js/ninja.reel/ninja.js index d0eb1557..ac883923 100755 --- a/js/ninja.reel/ninja.js +++ b/js/ninja.reel/ninja.js | |||
@@ -18,16 +18,28 @@ exports.Ninja = Montage.create(Component, { | |||
18 | value: null | 18 | value: null |
19 | }, | 19 | }, |
20 | 20 | ||
21 | toolsData: { value: null }, | 21 | toolsData: { |
22 | appData: { value: AppData }, | ||
23 | |||
24 | currentDocument: { | ||
25 | value: null | 22 | value: null |
26 | }, | 23 | }, |
27 | 24 | ||
28 | _isResizing: { | 25 | appData: { |
26 | value: AppData | ||
27 | }, | ||
28 | |||
29 | documentList: { | ||
29 | value: null | 30 | value: null |
30 | }, | 31 | }, |
32 | |||
33 | currentDocument: { | ||
34 | get: function() { | ||
35 | if(this.documentList.selectedObjects) { | ||
36 | return this.documentList.selectedObjects[0]; | ||
37 | } else { | ||
38 | return null; | ||
39 | } | ||
40 | } | ||
41 | }, | ||
42 | |||
31 | _resizedHeight : { | 43 | _resizedHeight : { |
32 | value: 0 | 44 | value: 0 |
33 | }, | 45 | }, |
@@ -55,9 +67,10 @@ exports.Ninja = Montage.create(Component, { | |||
55 | } | 67 | } |
56 | }, | 68 | }, |
57 | 69 | ||
58 | _resizedWidth : { | 70 | _resizedWidth: { |
59 | value: 0 | 71 | value: 0 |
60 | }, | 72 | }, |
73 | |||
61 | _width: { | 74 | _width: { |
62 | value: null | 75 | value: null |
63 | }, | 76 | }, |
@@ -129,7 +142,6 @@ exports.Ninja = Montage.create(Component, { | |||
129 | } | 142 | } |
130 | }, | 143 | }, |
131 | 144 | ||
132 | |||
133 | selectedElements: { | 145 | selectedElements: { |
134 | value: [] | 146 | value: [] |
135 | }, | 147 | }, |
@@ -174,14 +186,10 @@ exports.Ninja = Montage.create(Component, { | |||
174 | 186 | ||
175 | this.eventManager.addEventListener("selectTool", this, false); | 187 | this.eventManager.addEventListener("selectTool", this, false); |
176 | this.eventManager.addEventListener("selectSubTool", this, false); | 188 | this.eventManager.addEventListener("selectSubTool", this, false); |
177 | this.eventManager.addEventListener("onOpenDocument", this, false); | ||
178 | this.eventManager.addEventListener("onSwitchDocument", this, false); | ||
179 | 189 | ||
180 | this.addPropertyChangeListener("appModel.livePreview", this.executeLivePreview, false); | 190 | this.addPropertyChangeListener("appModel.livePreview", this.executeLivePreview, false); |
181 | this.addPropertyChangeListener("appModel.chromePreview", this.executeChromePreview, false); | 191 | this.addPropertyChangeListener("appModel.chromePreview", this.executeChromePreview, false); |
182 | this.addPropertyChangeListener("appModel.debug", this.toggleDebug, false); | 192 | this.addPropertyChangeListener("appModel.debug", this.toggleDebug, false); |
183 | |||
184 | NJevent("appLoading"); | ||
185 | } | 193 | } |
186 | }, | 194 | }, |
187 | 195 | ||
@@ -190,7 +198,7 @@ exports.Ninja = Montage.create(Component, { | |||
190 | //TODO: Expand method to allow other browsers for preview | 198 | //TODO: Expand method to allow other browsers for preview |
191 | executeChromePreview: { | 199 | executeChromePreview: { |
192 | value: function () { | 200 | value: function () { |
193 | this.application.ninja.documentController.activeDocument.model.browserPreview('chrome'); | 201 | this.currentDocument.model.browserPreview('chrome'); |
194 | } | 202 | } |
195 | }, | 203 | }, |
196 | //////////////////////////////////////////////////////////////////// | 204 | //////////////////////////////////////////////////////////////////// |
@@ -275,31 +283,39 @@ exports.Ninja = Montage.create(Component, { | |||
275 | } | 283 | } |
276 | }, | 284 | }, |
277 | 285 | ||
278 | handleOnOpenDocument: { | 286 | openDocument: { |
279 | value: function(event) { | 287 | value: function(doc) { |
280 | this.currentDocument = event.detail; | 288 | this.documentList.content.push(doc); |
289 | // This is not needed with the latest 0.10 montage. | ||
290 | // TODO: Remove this when integrating the next montage | ||
291 | this.documentList.selectedObjects = [doc]; | ||
281 | 292 | ||
282 | if(this.currentDocument.model.documentRoot) { | 293 | if(doc.currentView === "design") { |
283 | this.currentSelectedContainer = this.currentDocument.model.documentRoot; | 294 | // TODO: Bind directly to the model of the document in components instead of this property |
284 | } else { | 295 | this.currentSelectedContainer = doc.model.documentRoot; |
285 | alert("The current document has not loaded yet"); | ||
286 | return; | ||
287 | } | 296 | } |
288 | |||
289 | this.appModel.show3dGrid = this.currentDocument.draw3DGrid; | ||
290 | NJevent("openDocument"); | ||
291 | } | 297 | } |
292 | }, | 298 | }, |
293 | 299 | ||
294 | handleOnSwitchDocument: { | 300 | closeFile: { |
295 | value: function() { | 301 | value: function(document) { |
296 | this.currentDocument = this.documentController.activeDocument; | 302 | var doc = this.documentList.content[this.documentList.content.indexOf(document)], activeDocument; |
297 | 303 | ||
298 | if(this.currentDocument.model.documentRoot) { | 304 | if(this.documentList.selectedObjects[0] !== doc) { |
299 | this._currentSelectedContainer = this.selectionController._selectionContainer = this.currentDocument.model.documentRoot; | 305 | activeDocument = this.documentList.selectedObjects[0]; |
306 | } else { | ||
307 | activeDocument = null; | ||
300 | } | 308 | } |
301 | 309 | ||
302 | NJevent("switchDocument"); | 310 | this.documentList.removeObjects(doc); |
311 | |||
312 | if(activeDocument) { | ||
313 | this.documentList.selectedObjects = [activeDocument]; | ||
314 | } else { | ||
315 | if(this.documentList.content.length) { | ||
316 | this.documentList.selectedObjects = this.documentList.content[0]; | ||
317 | } | ||
318 | } | ||
303 | } | 319 | } |
304 | }, | 320 | }, |
305 | 321 | ||
@@ -360,16 +376,6 @@ exports.Ninja = Montage.create(Component, { | |||
360 | } | 376 | } |
361 | }, | 377 | }, |
362 | 378 | ||
363 | getCurrentToolInstance: { | ||
364 | value: function() { | ||
365 | if(this.toolsData.selectedTool.container) { | ||
366 | return this.toolsList[this.toolsData.selectedSubTool.action]; | ||
367 | } else { | ||
368 | return this.toolsList[this.toolsData.selectedTool.action]; | ||
369 | } | ||
370 | } | ||
371 | }, | ||
372 | |||
373 | setupGlobalHelpers: { | 379 | setupGlobalHelpers: { |
374 | value: function() { | 380 | value: function() { |
375 | 381 | ||