aboutsummaryrefslogtreecommitdiff
path: root/js/document/document-html.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/document/document-html.js')
-rwxr-xr-xjs/document/document-html.js136
1 files changed, 68 insertions, 68 deletions
diff --git a/js/document/document-html.js b/js/document/document-html.js
index 566e5078..a7a0f03a 100755
--- a/js/document/document-html.js
+++ b/js/document/document-html.js
@@ -30,40 +30,40 @@ POSSIBILITY OF SUCH DAMAGE.
30 30
31//////////////////////////////////////////////////////////////////////// 31////////////////////////////////////////////////////////////////////////
32// 32//
33var Montage = require("montage/core/core").Montage, 33var Montage = require("montage/core/core").Montage,
34 Component = require("montage/ui/component").Component, 34 Component = require("montage/ui/component").Component,
35 HtmlDocumentModel = require("js/document/models/html").HtmlDocumentModel, 35 HtmlDocumentModel = require("js/document/models/html").HtmlDocumentModel,
36 DesignDocumentView = require("js/document/views/design").DesignDocumentView; 36 DesignDocumentView = require("js/document/views/design").DesignDocumentView;
37//////////////////////////////////////////////////////////////////////// 37////////////////////////////////////////////////////////////////////////
38// 38//
39exports.HtmlDocument = Montage.create(Component, { 39exports.HtmlDocument = Montage.create(Component, {
40 //////////////////////////////////////////////////////////////////// 40 ////////////////////////////////////////////////////////////////////
41 // 41 //
42 hasTemplate: { 42 hasTemplate: {
43 value: false 43 value: false
44 }, 44 },
45 //////////////////////////////////////////////////////////////////// 45 ////////////////////////////////////////////////////////////////////
46 // 46 //
47 model: { 47 model: {
48 value: null 48 value: null
49 }, 49 },
50 //////////////////////////////////////////////////////////////////// 50 ////////////////////////////////////////////////////////////////////
51 // 51 //
52 loaded: { 52 loaded: {
53 value: {callback: null, context: null} 53 value: {callback: null, context: null}
54 }, 54 },
55 //////////////////////////////////////////////////////////////////// 55 ////////////////////////////////////////////////////////////////////
56 // 56 //
57 _observer: { 57 _observer: {
58 value: null 58 value: null
59 }, 59 },
60 //////////////////////////////////////////////////////////////////// 60 ////////////////////////////////////////////////////////////////////
61 // 61 //
62 exclusionList: { 62 exclusionList: {
63 value: ["HTML", "BODY", "NINJA-CONTENT", "NINJA-VIEWPORT"] 63 value: ["HTML", "BODY", "NINJA-CONTENT", "NINJA-VIEWPORT"]
64 }, 64 },
65 //////////////////////////////////////////////////////////////////// 65 ////////////////////////////////////////////////////////////////////
66 // 66 //
67 inExclusion: { 67 inExclusion: {
68 value: function(element) { 68 value: function(element) {
69 if(this.exclusionList.indexOf(element.nodeName) === -1) { 69 if(this.exclusionList.indexOf(element.nodeName) === -1) {
@@ -72,62 +72,62 @@ exports.HtmlDocument = Montage.create(Component, {
72 return 1; 72 return 1;
73 } 73 }
74 }, 74 },
75 //////////////////////////////////////////////////////////////////// 75 ////////////////////////////////////////////////////////////////////
76 // 76 //
77 init: { 77 init: {
78 value:function(file, context, callback, view, template) { 78 value:function(file, context, callback, view, template) {
79 //Storing callback data for loaded dispatch 79 //Storing callback data for loaded dispatch
80 this.loaded.callback = callback; 80 this.loaded.callback = callback;
81 this.loaded.context = context; 81 this.loaded.context = context;
82 //Creating instance of HTML Document Model 82 //Creating instance of HTML Document Model
83 this.model = Montage.create(HtmlDocumentModel,{ 83 this.model = Montage.create(HtmlDocumentModel,{
84 file: {value: file}, 84 file: {value: file},
85 fileTemplate: {value: template}, 85 fileTemplate: {value: template},
86 parentContainer: {value: document.getElementById("iframeContainer")}, //Saving reference to parent container of all views (should be changed to buckets approach 86 parentContainer: {value: document.getElementById("iframeContainer")}, //Saving reference to parent container of all views (should be changed to buckets approach
87 views: {value: {'design': DesignDocumentView.create(), 'code': null}} //TODO: Add code view logic 87 views: {value: {'design': DesignDocumentView.create(), 'code': null}} //TODO: Add code view logic
88 }); 88 });
89 //Calling the any init routines in the model 89 //Calling the any init routines in the model
90 this.model.init(); 90 this.model.init();
91 //Initiliazing views and hiding 91 //Initiliazing views and hiding
92 if (this.model.views.design.initialize(this.model.parentContainer)) { 92 if (this.model.views.design.initialize(this.model.parentContainer)) {
93 //Hiding iFrame, just initiliazing 93 //Hiding iFrame, just initiliazing
94 this.model.views.design.hide(); 94 this.model.views.design.hide();
95 //Setting the iFrame property for reference in helper class 95 //Setting the iFrame property for reference in helper class
96 this.model.webGlHelper.iframe = this.model.views.design.iframe; 96 this.model.webGlHelper.iframe = this.model.views.design.iframe;
97 } else { 97 } else {
98 //ERROR: Design View not initialized 98 //ERROR: Design View not initialized
99 } 99 }
100 // 100 //
101 if (view === 'design') { 101 if (view === 'design') {
102 //TODO: Remove reference and use as part of model 102 //TODO: Remove reference and use as part of model
103 this.currentView = 'design'; 103 this.currentView = 'design';
104 //Setting current view object to design 104 //Setting current view object to design
105 this.model.currentView = this.model.views.design; 105 this.model.currentView = this.model.views.design;
106 //Showing design iFrame 106 //Showing design iFrame
107 this.model.views.design.show(); 107 this.model.views.design.show();
108 this.model.views.design.iframe.style.opacity = 0; 108 this.model.views.design.iframe.style.opacity = 0;
109 this.model.views.design.content = this.model.file.content; 109 this.model.views.design.content = this.model.file.content;
110 //TODO: Improve reference (probably through binding values) 110 //TODO: Improve reference (probably through binding values)
111 this.model.views.design._webGlHelper = this.model.webGlHelper; 111 this.model.views.design._webGlHelper = this.model.webGlHelper;
112 //Rendering design view, using observers to know when template is ready 112 //Rendering design view, using observers to know when template is ready
113 this.model.views.design.render(function () { 113 this.model.views.design.render(function () {
114 //Adding observer to know when template is ready 114 //Adding observer to know when template is ready
115 this._observer = new WebKitMutationObserver(this.handleTemplateReady.bind(this)); 115 this._observer = new WebKitMutationObserver(this.handleTemplateReady.bind(this));
116 this._observer.observe(this.model.views.design.document.head, {childList: true}); 116 this._observer.observe(this.model.views.design.document.head, {childList: true});
117 }.bind(this), template, {viewCallback: this.handleViewReady, context: this}); 117 }.bind(this), template, {viewCallback: this.handleViewReady, context: this});
118 } else { 118 } else {
119 //TODO: Identify default view (probably code) 119 //TODO: Identify default view (probably code)
120 } 120 }
121 } 121 }
122 }, 122 },
123 //////////////////////////////////////////////////////////////////// 123 ////////////////////////////////////////////////////////////////////
124 // 124 //
125 handleTemplateReady: { 125 handleTemplateReady: {
126 value: function (e) { 126 value: function (e) {
127 //Removing observer, only needed on initial load 127 //Removing observer, only needed on initial load
128 this._observer.disconnect(); 128 this._observer.disconnect();
129 this._observer = null; 129 this._observer = null;
130 } 130 }
131 }, 131 },
132 handleViewReady: { 132 handleViewReady: {
133 value: function(mObjects) { 133 value: function(mObjects) {
@@ -143,17 +143,17 @@ exports.HtmlDocument = Montage.create(Component, {
143 } 143 }
144 }, 144 },
145 //////////////////////////////////////////////////////////////////// 145 ////////////////////////////////////////////////////////////////////
146 // 146 //
147 closeDocument: { 147 closeDocument: {
148 value: function (context, callback) { 148 value: function (context, callback) {
149 //Closing document (sending null to close all views) 149 //Closing document (sending null to close all views)
150 this.model.close(null, function () {if (callback) callback.call(context, this);}.bind(this)); 150 this.model.close(null, function () {if (callback) callback.call(context, this);}.bind(this));
151 } 151 }
152 }, 152 },
153 //////////////////////////////////////////////////////////////////// 153 ////////////////////////////////////////////////////////////////////
154 // 154 //
155 serializeDocument: { 155 serializeDocument: {
156 value: function () { 156 value: function () {
157 // Serialize the current scroll position 157 // Serialize the current scroll position
158 //TODO: Move these properties to the design view class 158 //TODO: Move these properties to the design view class
159 this.model.scrollLeft = this.application.ninja.stage._scrollLeft; 159 this.model.scrollLeft = this.application.ninja.stage._scrollLeft;
@@ -169,12 +169,12 @@ exports.HtmlDocument = Montage.create(Component, {
169 // Pause the videos 169 // Pause the videos
170 //TODO: Move these to be handled on the show/hide methods in the view 170 //TODO: Move these to be handled on the show/hide methods in the view
171 this.model.views.design.pauseVideos(); 171 this.model.views.design.pauseVideos();
172 } 172 }
173 }, 173 },
174 //////////////////////////////////////////////////////////////////// 174 ////////////////////////////////////////////////////////////////////
175 // 175 //
176 deserializeDocument: { 176 deserializeDocument: {
177 value: function () { 177 value: function () {
178 // Deserialize the current scroll position 178 // Deserialize the current scroll position
179 //TODO: Move these properties to the design view class 179 //TODO: Move these properties to the design view class
180 this.application.ninja.stage._scrollLeft = this.model.scrollLeft; 180 this.application.ninja.stage._scrollLeft = this.model.scrollLeft;
@@ -184,7 +184,7 @@ exports.HtmlDocument = Montage.create(Component, {
184 184
185 // Serialize the undo 185 // Serialize the undo
186 // TODO: Save the montage undo queue 186 // TODO: Save the montage undo queue
187 } 187 }
188 } 188 }
189 //////////////////////////////////////////////////////////////////// 189 ////////////////////////////////////////////////////////////////////
190 //////////////////////////////////////////////////////////////////// 190 ////////////////////////////////////////////////////////////////////