aboutsummaryrefslogtreecommitdiff
path: root/js/stage/stage.reel/stage.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/stage/stage.reel/stage.js')
-rwxr-xr-xjs/stage/stage.reel/stage.js265
1 files changed, 221 insertions, 44 deletions
diff --git a/js/stage/stage.reel/stage.js b/js/stage/stage.reel/stage.js
index 63339c57..33c4fd22 100755
--- a/js/stage/stage.reel/stage.js
+++ b/js/stage/stage.reel/stage.js
@@ -11,6 +11,11 @@ var Montage = require("montage/core/core").Montage,
11 11
12exports.Stage = Montage.create(Component, { 12exports.Stage = Montage.create(Component, {
13 13
14 appModel: {
15 value: null,
16 serializable: true
17 },
18
14 // TODO - Need to figure out how to remove this dependency 19 // TODO - Need to figure out how to remove this dependency
15 // Needed by some tools that depend on selectionDrawn event to set up some logic 20 // Needed by some tools that depend on selectionDrawn event to set up some logic
16 drawNow: { value : false }, 21 drawNow: { value : false },
@@ -25,7 +30,10 @@ exports.Stage = Montage.create(Component, {
25 value: null 30 value: null
26 }, 31 },
27 32
28 _iframeContainer: { value: null }, 33 _iframeContainer: {
34 value: null,
35 serializable: true
36 },
29 37
30 _scrollFlag: {value: true, writable: true}, 38 _scrollFlag: {value: true, writable: true},
31 outFlag: { value: false, writable: true }, 39 outFlag: { value: false, writable: true },
@@ -91,29 +99,82 @@ exports.Stage = Montage.create(Component, {
91 }, 99 },
92 100
93 /** MAIN CANVASES **/ 101 /** MAIN CANVASES **/
94 _canvas: { value: null }, // selection bounds, 3d normals and the overall 3d selection box use this canvas 102 // selection bounds, 3d normals and the overall 3d selection box use this canvas
95 canvas: { get: function() { return this._canvas; } }, 103 _canvas: {
104 value: null,
105 serializable: true
106 },
107
108 canvas: {
109 get: function() {
110 return this._canvas;
111 }
112 },
96 113
97 _context: { value: null }, 114 _context: { value: null },
98 context: { get: function() { return this._context; } }, 115 context: { get: function() { return this._context; } },
99 116
100 _layoutCanvas: { value: null }, 117 _layoutCanvas: {
101 layoutCanvas: { get: function() { return this._layoutCanvas; } }, 118 value: null,
119 serializable: true
120 },
102 121
103 _gridCanvas: { value: null }, 122 layoutCanvas: {
104 gridCanvas: { get: function() { return this._gridCanvas; } }, 123 get: function() {
124 return this._layoutCanvas;
125 }
126 },
127
128 _gridCanvas: {
129 value: null,
130 serializable: true
131 },
132
133 gridCanvas: {
134 get: function() {
135 return this._gridCanvas;
136 }
137 },
105 138
106 _gridContext: { value: null }, 139 _gridContext: { value: null },
107 gridContext: { get: function() { return this._gridContext; } }, 140 gridContext: { get: function() { return this._gridContext; } },
108 141
109 _drawingCanvas: { value: null }, 142 _drawingCanvas: {
110 drawingCanvas: { get: function() { return this._drawingCanvas; } }, 143 value: null,
144 serializable: true
145 },
146
147 drawingCanvas: {
148 get: function() {
149 return this._drawingCanvas;
150 }
151 },
111 152
112 _drawingContext: { value: null }, 153 _drawingContext: { value: null },
113 drawingContext: { get: function() { return this._drawingContext; } }, 154 drawingContext: { get: function() { return this._drawingContext; } },
114 155
115 _clickPoint: { value: { x: { value: null }, y: { value: null } } }, 156 _clickPoint: { value: { x: { value: null }, y: { value: null } } },
116 157
158 stageDeps: {
159 value: null,
160 serializable: true
161 },
162
163 layout: {
164 value: null,
165 serializable: true
166 },
167
168 textTool: {
169 value: null,
170 serializable: true
171 },
172
173 focusManager: {
174 value: null,
175 serializable: true
176 },
177
117 // We will set this to false while moving objects to improve performance 178 // We will set this to false while moving objects to improve performance
118 showSelectionBounds: { value: true }, 179 showSelectionBounds: { value: true },
119 180
@@ -185,6 +246,13 @@ exports.Stage = Montage.create(Component, {
185 if(this.currentDocument && (this.currentDocument.currentView === "design")) { 246 if(this.currentDocument && (this.currentDocument.currentView === "design")) {
186 this.currentDocument.model.scrollLeft = this._scrollLeft; 247 this.currentDocument.model.scrollLeft = this._scrollLeft;
187 this.currentDocument.model.scrollTop = this._scrollTop; 248 this.currentDocument.model.scrollTop = this._scrollTop;
249 this.currentDocument.model.userPaddingLeft = this._userPaddingLeft;
250 this.currentDocument.model.userPaddingTop = this._userPaddingTop;
251 this.currentDocument.model.documentOffsetLeft = this._documentOffsetLeft;
252 this.currentDocument.model.documentOffsetTop = this._documentOffsetTop;
253 this.currentDocument.model.userContentLeft = this._userContentLeft;
254 this.currentDocument.model.userContentTop = this._userContentTop;
255
188 //call configure false with the old document on the selected tool to tear down down any temp. stuff 256 //call configure false with the old document on the selected tool to tear down down any temp. stuff
189 this.application.ninja.toolsData.selectedToolInstance._configure(false); 257 this.application.ninja.toolsData.selectedToolInstance._configure(false);
190 } 258 }
@@ -279,9 +347,6 @@ exports.Stage = Montage.create(Component, {
279 347
280 this.eventManager.addEventListener( "appMouseUp", this, false); 348 this.eventManager.addEventListener( "appMouseUp", this, false);
281 349
282
283 this.eventManager.addEventListener( "openDocument", this, false);
284 this.eventManager.addEventListener( "switchDocument", this, false);
285 this.eventManager.addEventListener( "enableStageMove", this, false); 350 this.eventManager.addEventListener( "enableStageMove", this, false);
286 this.eventManager.addEventListener( "disableStageMove", this, false); 351 this.eventManager.addEventListener( "disableStageMove", this, false);
287 352
@@ -289,19 +354,9 @@ exports.Stage = Montage.create(Component, {
289 this.eventManager.addEventListener( "elementChanging", this, false); 354 this.eventManager.addEventListener( "elementChanging", this, false);
290 this.eventManager.addEventListener( "elementChange", this, false); 355 this.eventManager.addEventListener( "elementChange", this, false);
291 356
292 } 357 this.addPropertyChangeListener("currentDocument.model.domContainer", this, true);
293 }, 358// this.addPropertyChangeListener("currentDocument.model.domContainer", this);
294
295 // Event details will contain the active document prior to opening a new one
296 handleOpenDocument: {
297 value: function(evt) {
298 this.initWithDocument();
299 }
300 },
301 359
302 handleSwitchDocument: {
303 value: function(evt) {
304 this.initWithDocument(true);
305 } 360 }
306 }, 361 },
307 362
@@ -313,6 +368,23 @@ exports.Stage = Montage.create(Component, {
313 368
314 if(model.scrollLeft != null) { 369 if(model.scrollLeft != null) {
315 didSwitch = true; 370 didSwitch = true;
371 this._userPaddingLeft = this.currentDocument.model.userPaddingLeft;
372 this._userPaddingTop = this.currentDocument.model.userPaddingTop;
373 this._documentOffsetLeft = this.currentDocument.model.documentOffsetLeft;
374 this._documentOffsetTop = this.currentDocument.model.documentOffsetTop;
375 this._userContentLeft = this.currentDocument.model.userContentLeft;
376 this._userContentTop = this.currentDocument.model.userContentTop;
377 this._scrollLeft = this.currentDocument.model.scrollLeft;
378 this._scrollTop = this.currentDocument.model.scrollTop;
379 } else {
380 this._userPaddingLeft = 0;
381 this._userPaddingTop = 0;
382 this._documentOffsetLeft = 0;
383 this._documentOffsetTop = 0;
384 this._userContentLeft = 0;
385 this._userContentTop = 0;
386 this._scrollLeft = 0;
387 this._scrollTop = 0;
316 } 388 }
317 389
318 // Recalculate the canvas sizes because of splitter resizing 390 // Recalculate the canvas sizes because of splitter resizing
@@ -323,19 +395,7 @@ exports.Stage = Montage.create(Component, {
323 395
324 this.addPropertyChangeListener("appModel.show3dGrid", this, false); 396 this.addPropertyChangeListener("appModel.show3dGrid", this, false);
325 397
326 this._userPaddingLeft = 0; 398 this.initialize3DOnOpenDocument(!didSwitch);
327 this._userPaddingTop = 0;
328
329 this._documentOffsetLeft = 0;
330 this._documentOffsetTop = 0;
331
332 this._userContentLeft = 0;
333 this._userContentTop = 0;
334
335 this._scrollLeft = 0;
336 this._scrollTop = 0;
337
338 this.initialize3DOnOpenDocument();
339 399
340 if(designView._template) { 400 if(designView._template) {
341 var initialLeft = parseInt((this.canvas.width - designView._template.size.width)/2); 401 var initialLeft = parseInt((this.canvas.width - designView._template.size.width)/2);
@@ -380,6 +440,17 @@ exports.Stage = Montage.create(Component, {
380 this.updatedStage = true; 440 this.updatedStage = true;
381 } 441 }
382 } 442 }
443 /*
444 else if(notification.currentPropertyPath === "currentDocument.model.domContainer") {
445 if()
446 }
447 */
448 }
449 },