1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
/* <copyright>
This file contains proprietary software owned by Motorola Mobility, Inc.<br/>
No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/>
(c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
</copyright> */
////////////////////////////////////////////////////////////////////////
//
var Montage = require("montage/core/core").Montage,
BaseDocumentView = require("js/document/views/base").BaseDocumentView;
////////////////////////////////////////////////////////////////////////
//
exports.DesignDocumentView = Montage.create(BaseDocumentView, {
////////////////////////////////////////////////////////////////////
//
hasTemplate: {
value: false
},
////////////////////////////////////////////////////////////////////
//
_callback: {
value: null
},
////////////////////////////////////////////////////////////////////
//
_document: {
value: null
},
////////////////////////////////////////////////////////////////////
//
_headFragment: {
value: null
},
////////////////////////////////////////////////////////////////////
//
content: {
value: null
},
////////////////////////////////////////////////////////////////////
//
document: {
get: function() {return this._document;},
set: function(value) {this._document = value;}
},
////////////////////////////////////////////////////////////////////
//
initiliaze: {
value: function (parent) {
//
this.iframe = document.createElement("iframe");
//
this.iframe.style.border = "none";
this.iframe.style.background = "#FFF";
this.iframe.style.height = "100%";
this.iframe.style.width = "100%";
//
return parent.appendChild(this.iframe);
}
},
////////////////////////////////////////////////////////////////////
//
render: {
value: function (callback) {
//
this._callback = callback;
this.iframe.addEventListener("load", this.onTemplateLoad.bind(this), true);
this.iframe.src = "js/document/templates/montage-web/index.html";
}
},
////////////////////////////////////////////////////////////////////
//
onTemplateLoad: {
value: function (e) {
//
this.document = this.iframe.contentWindow.document;
//
this._headFragment = this.document.createElement('head');
this._headFragment.addEventListener('DOMSubtreeModified', this.insertHeadContent.bind(this), false);
this._headFragment.innerHTML = this.content.head;
//
this.document.body.addEventListener('DOMSubtreeModified', this.bodyContentLoaded.bind(this), false);
this.document.body.innerHTML += this.content.body;
}
},
////////////////////////////////////////////////////////////////////
//
bodyContentLoaded: {
value: function (e) {
//
this.document.body.removeEventListener('DOMSubtreeModified', this.bodyContentLoaded.bind(this), false);
//
if (this._callback) this._callback();
}
},
////////////////////////////////////////////////////////////////////
//
insertHeadContent: {
value: function (e) {
//
this._headFragment.removeEventListener('DOMSubtreeModified', this.insertHeadContent, false);
//
for(var i in this._headFragment.childNodes) {
if(this._headFragment.childNodes[i].outerHTML) {
this.document.head.appendChild(this._headFragment.childNodes[i]);
}
}
}
},
////////////////////////////////////////////////////////////////////
//
initCss: {
value: function () {
//
}
},
////////////////////////////////////////////////////////////////////
//
initWebGl: {
value: function () {
//
}
},
////////////////////////////////////////////////////////////////////
//
initMontage: {
value: function () {
//
}
},
////////////////////////////////////////////////////////////////////
//
getElementFromPoint: {
value: function(x, y) {
return this.iframe.contentWindow.getElement(x,y);
}
},
////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////
});
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
|