aboutsummaryrefslogtreecommitdiff
path: root/js/stage/binding-view.reel/binding-view.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/stage/binding-view.reel/binding-view.js')
-rwxr-xr-xjs/stage/binding-view.reel/binding-view.js440
1 files changed, 440 insertions, 0 deletions
diff --git a/js/stage/binding-view.reel/binding-view.js b/js/stage/binding-view.reel/binding-view.js
new file mode 100755
index 00000000..1fc4d583
--- /dev/null
+++ b/js/stage/binding-view.reel/binding-view.js
@@ -0,0 +1,440 @@
1/* <copyright>
2This file contains proprietary software owned by Motorola Mobility, Inc.<br/>
3No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/>
4(c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
5</copyright> */
6
7/**
8@requires montage/core/core
9@requires montage/ui/component
10*/
11var Montage = require("montage/core/core").Montage,
12 Component = require("montage/ui/component").Component;
13
14exports.BindingView = Montage.create(Component, {
15 //private Properties
16 _canvas: { value:null },
17 _context : { value: null },
18 _targetedElement: {value: null},
19 componentsList: { value: {} },
20
21 hudRepeater: { value: null },
22
23 //Public Properties
24 _width :{ value: 0 },
25 width: {
26 get:function() {
27 return this._width;
28 },
29 set: function(val) {
30 if(this._width !== val) {
31 this._width = val;
32 this.needsDraw = true;
33 }
34 }
35 },
36
37 _height :{ value: 0 },
38 height: {
39 get:function() {
40 return this._height;
41 },
42 set: function(val) {
43 if(this._height !== val) {
44 this._height = val;
45 this.needsDraw = true;
46 }
47 }
48 },
49
50 _connectionElementStart: { value: null },
51 connectionElementStart: {
52 get: function() {
53 return this._connectionElementStart;
54 },
55 set: function(val) {
56 this._connectionElementStart = val;
57 }
58 },
59
60 _connectionElementEnd: { value: null },
61 connectionElementEnd: {
62 get: function() {
63 return this._connectionElementEnd;
64 },
65 set: function(val) {
66 this._connectionElementEnd = val;
67 }
68 },
69
70 _connectionPropertyStart: { value: null },
71 connectionPropertyStart: {
72 get: function() {
73 return this._connectionPropertyStart;
74 },
75 set: function(val) {
76 this._connectionPropertyStart = val;
77 }
78 },
79
80 _connectionPropertyEnd: { value: null },
81 connectionPropertyEnd: {
82 get: function() {
83 return this._connectionPropertyEnd;
84 },
85 set: function(val) {
86 this._connectionPropertyEnd = val;
87 }
88 },
89
90 _boundComponents: { value: [] },
91 boundComponents: {
92 get: function() {
93 return this._boundComponents;
94 },
95 set: function(val) {
96 this._boundComponents = val;
97 }
98 },
99
100 _selectedComponent: { value: null },
101 selectedComponent: {
102 get: function() {
103 return this._selectedComponent;
104 },
105 set: function(val) {
106 this.boundComponents = [];
107 if(this._selectedComponent !== val) {
108 this.clearCanvas();
109 this._selectedComponent = val;
110 if(this._selectedComponent !== null) {
111 this.application.ninja.objectsController.currentObject = this.selectedComponent;
112 if (this.selectedComponent !== null) {
113 this.boundComponents.push(this.selectedComponent);
114 }
115 }
116 this.needsDraw = true;
117 }
118 }
119 },
120
121 handleShowBinding: {
122 value: function(bindingMeta) {
123 if(bindingMeta === null) return;
124 for(var j=0; j< bindingMeta.length; j++) {
125 var bindingExists = false;
126 for(var i =0; i < this.boundComponents; i++) {
127 if(this.boundComponents[i] === bindingMeta[j].boundObject) {
128 bindingExists = true;
129 }
130 }
131 if(!bindingExists) {
132 //this.boundComponents.push(bindingMeta[j].boundObject);
133 }
134 }
135 }
136 },
137
138 _nonVisualComponents: { value:[] },
139 nonVisualComponents: {
140 get: function() {
141 return this._nonVisualComponents;
142 },
143 set: function(val) {
144 this._nonVisualComponents = val;
145 }
146 },
147
148 bindingViewCanvas: {
149 get: function() {
150 return this._bindingViewCanvas;
151 },
152 set: function(val) {
153 this._bindingViewCanvas = val;
154 }
155 },
156
157 //Methods
158 canvas: {
159 get: function() {
160 return this._canvas;
161 },
162 set: function(val) {
163 this._canvas = val;
164 }
165 },
166
167 //Montage Draw Cycle
168 prepareForDraw: {
169 value: function() {
170 this._canvas = this.application.ninja.stage.drawingCanvas;
171 this._context = this.application.ninja.stage.drawingCanvas.getContext('2d');
172 this.application.ninja.stage._iframeContainer.addEventListener("scroll", this, false);
173 this.element.addEventListener("mousedown", this, false);
174 this.element.addEventListener("mousemove", this, false);
175
176 Object.defineBinding(this, 'currentDocument', {
177 boundObject : this.application.ninja,
178 boundObjectPropertyPath : "documentList.selectedObjects.0",
179 oneway: true
180 });
181
182 }
183 },
184
185 _currentDocument : { value: null },
186 currentDocument : {
187 get : function() { return this._currentDocument; },
188 set : function(value) {
189 if(value === this._currentDocument) { return; }
190
191
192 this._currentDocument = value;
193 if(value) {
194 this.hide = (value.currentView === 'code');
195 }
196
197 this.needsDraw = true;
198 }
199 },
200
201 _hide : { value: null },
202 hide : {
203 get : function() { return this._hide; },
204 set : function(value) {
205 if(value === this._hide) { return; }
206
207 this._hide = value;
208
209 this.needsDraw = true;
210 }
211 },
212
213 draw: {
214 value: function() {
215
216 if(this.hide) {
217 this.element.style.setProperty('display', 'none');
218 } else {
219 this.element.style.removeProperty('display');
220 this.element.style.width = this.width + "px";
221 this.element.style.height = this.height + "px";
222 if(this.selectedComponent !== null && typeof(this.selectedComponent) !== "undefined") {
223 this.canvas.width = this.application.ninja.stage.drawingCanvas.offsetWidth;
224 this.canvas.height = this.application.ninja.stage.drawingCanvas.offsetHeight;
225 this.clearCanvas();
226 for(var i= 0; i < this.hudRepeater.childComponents.length; i++) {
227 this.drawLine(this.hudRepeater.objects[i].element.offsetLeft,this.hudRepeater.objects[i].element.offsetTop, this.hudRepeater.childComponents[i].element.offsetLeft +3, this.hudRepeater.childComponents[i].element.offsetTop +3, "#CCC", 2);
228 }
229 if(this._isDrawingConnection) {
230 if (this.hudRepeater.childComponents.length > 1) {
231 // Make things disappear
232 }
233 this.drawLine(this._currentMousePosition.x,this._currentMousePosition.y,this._connectionPositionStart.x,this._connectionPositionStart.y,"#5e9eff", 4);