aboutsummaryrefslogtreecommitdiff
path: root/js/panels/properties.reel/properties.js
diff options
context:
space:
mode:
authorNivesh Rajbhandari2012-06-12 15:13:09 -0700
committerNivesh Rajbhandari2012-06-12 15:13:09 -0700
commit509092ff335f74517a413cfb2deeb9d2de20f8e3 (patch)
tree86dddcb4b74f04c965da52180cab3c49529148cf /js/panels/properties.reel/properties.js
parent6854a72504f57903bd5de003e377f2aefb02d0da (diff)
downloadninja-509092ff335f74517a413cfb2deeb9d2de20f8e3.tar.gz
Fixing properties panel to support px and % for body and other elements.
Signed-off-by: Nivesh Rajbhandari <mqg734@motorola.com>
Diffstat (limited to 'js/panels/properties.reel/properties.js')
-rwxr-xr-xjs/panels/properties.reel/properties.js70
1 files changed, 56 insertions, 14 deletions
diff --git a/js/panels/properties.reel/properties.js b/js/panels/properties.reel/properties.js
index cc99ca6c..33e66515 100755
--- a/js/panels/properties.reel/properties.js
+++ b/js/panels/properties.reel/properties.js
@@ -143,6 +143,7 @@ exports.Properties = Montage.create(Component, {
143 143
144 handleElementChange: { 144 handleElementChange: {
145 value: function(event) { 145 value: function(event) {
146 var l, t, h, w, lvu, tvu, hvu, wvu;
146// console.log("Element Change PI ", event.detail.source); // If the event comes from the pi don't need to update 147// console.log("Element Change PI ", event.detail.source); // If the event comes from the pi don't need to update
147 if(event.detail.source && event.detail.source !== "pi") { 148 if(event.detail.source && event.detail.source !== "pi") {
148 var el = this.application.ninja.currentDocument.model.documentRoot; 149 var el = this.application.ninja.currentDocument.model.documentRoot;
@@ -151,10 +152,24 @@ exports.Properties = Montage.create(Component, {
151 } 152 }
152 153
153 // TODO - This should only update the properties that were changed. 154 // TODO - This should only update the properties that were changed.
154 this.positionSize.leftPosition = parseFloat(ElementsMediator.getProperty(el, "left")); 155 l = ElementsMediator.getProperty(el, "left");
155 this.positionSize.topPosition = parseFloat(ElementsMediator.getProperty(el, "top")); 156 t = ElementsMediator.getProperty(el, "top");
156 this.positionSize.heightSize = parseFloat(ElementsMediator.getProperty(el, "height")); 157 lvu = document.application.njUtils.getValueAndUnits(l);
157 this.positionSize.widthSize = parseFloat(ElementsMediator.getProperty(el, "width")); 158 tvu = document.application.njUtils.getValueAndUnits(t);
159 this.positionSize.leftUnits = lvu[1];
160 this.positionSize.leftPosition = lvu[0];
161 this.positionSize.topUnits = tvu[1];
162 this.positionSize.topPosition = tvu[0];
163
164 h = ElementsMediator.getProperty(el, "height");
165 w = ElementsMediator.getProperty(el, "width");
166 hvu = document.application.njUtils.getValueAndUnits(h);
167 wvu = document.application.njUtils.getValueAndUnits(w);
168
169 this.positionSize.heightUnits = hvu[1] || "px"; // canvas (and shapes) don't have units.
170 this.positionSize.heightSize = hvu[0];
171 this.positionSize.widthUnits = wvu[1] || "px";
172 this.positionSize.widthSize = wvu[0];
158 173
159 if(this.threeD.inGlobalMode) { 174 if(this.threeD.inGlobalMode) {
160 this.threeD.x3D = ElementsMediator.get3DProperty(el, "x3D"); 175 this.threeD.x3D = ElementsMediator.get3DProperty(el, "x3D");
@@ -209,7 +224,8 @@ exports.Properties = Montage.create(Component, {
209 224
210 displayElementProperties: { 225 displayElementProperties: {
211 value: function (el) { 226 value: function (el) {
212 var customPI, currentValue, isRoot = this.application.ninja.selectionController.isDocument; 227 var customPI, currentValue, isRoot = this.application.ninja.selectionController.isDocument,
228 l, t, h, w, lvu, tvu, hvu, wvu;
213 229
214 this.elementName.value = el.elementModel.selection; 230 this.elementName.value = el.elementModel.selection;
215 this.elementId.value = el.getAttribute("id") || ""; 231 this.elementId.value = el.getAttribute("id") || "";
@@ -219,11 +235,24 @@ exports.Properties = Montage.create(Component, {
219 this.threeD.disableTranslation = isRoot; 235 this.threeD.disableTranslation = isRoot;
220 this.threeD.flatten = ElementsMediator.getProperty(el, "-webkit-transform-style") !== "preserve-3d"; 236 this.threeD.flatten = ElementsMediator.getProperty(el, "-webkit-transform-style") !== "preserve-3d";
221 237
222 this.positionSize.leftPosition = parseFloat(ElementsMediator.getProperty(el, "left")); 238 l = ElementsMediator.getProperty(el, "left");
223 this.positionSize.topPosition = parseFloat(ElementsMediator.getProperty(el, "top")); 239 t = ElementsMediator.getProperty(el, "top");
224 this.positionSize.heightSize = parseFloat(ElementsMediator.getProperty(el, "height")); 240 lvu = document.application.njUtils.getValueAndUnits(l);
225 this.positionSize.widthSize = parseFloat(ElementsMediator.getProperty(el, "width")); 241 tvu = document.application.njUtils.getValueAndUnits(t);
226// this.positionSize.widthSize = ElementsMediator.getProperty(el, "width"); 242 this.positionSize.leftUnits = lvu[1];
243 this.positionSize.leftPosition = lvu[0];
244 this.positionSize.topUnits = tvu[1];
245 this.positionSize.topPosition = tvu[0];
246
247 h = ElementsMediator.getProperty(el, "height");
248 w = ElementsMediator.getProperty(el, "width");
249 hvu = document.application.njUtils.getValueAndUnits(h);
250 wvu = document.application.njUtils.getValueAndUnits(w);
251
252 this.positionSize.heightUnits = hvu[1] || "px"; // canvas (and shapes) don't have units.
253 this.positionSize.heightSize = hvu[0];
254 this.positionSize.widthUnits = wvu[1] || "px";
255 this.positionSize.widthSize = wvu[0];
227 256
228 if(this.threeD.inGlobalMode) 257 if(this.threeD.inGlobalMode)
229 { 258 {
@@ -277,10 +306,19 @@ exports.Properties = Montage.create(Component, {
277 306
278 if(control.type !== "color") { 307 if(control.type !== "color") {
279 currentValue = ElementsMediator.getProperty(el, control.prop, control.valueMutator); 308 currentValue = ElementsMediator.getProperty(el, control.prop, control.valueMutator);
280 if(currentValue === null) { 309 if(control.type === "hottext") {
281 currentValue = control.defaultValue; 310 if(currentValue == null) {
311 currentValue = control.defaultValue;
312 }
313 currentValue = document.application.njUtils.getValueAndUnits(currentValue);
314 this.customSections[i].content.controls[control.id + "Units"] = currentValue[1] || "px";
315 this.customSections[i].content.controls[control.id] = currentValue[0];
316 } else {
317 if(currentValue === null) {
318 currentValue = control.defaultValue;
319 }
320 this.customSections[i].content.controls[control.id] = currentValue;
282 } 321 }
283 this.customSections[i].content.controls[control.id] = currentValue;
284 } else { 322 } else {
285 if(control.prop === "border") { 323 if(control.prop === "border") {
286 // TODO - For now, always return the top border if multiple border sides 324 // TODO - For now, always return the top border if multiple border sides
@@ -402,7 +440,11 @@ exports.Properties = Montage.create(Component, {
402 value: function(e) { 440 value: function(e) {
403 if(e.wasSetByCode) return; 441 if(e.wasSetByCode) return;
404 442
405 ElementsMediator.setProperty(this.application.ninja.selectedElements, e.prop, [e.value + "px"], "Changing", "pi"); 443 var newValue;
444
445 e.units ? newValue = e.value + e.units : newValue = e.value;
446
447 ElementsMediator.setProperty(this.application.ninja.selectedElements, e.prop, [newValue], "Changing", "pi");
406 } 448 }
407 } 449 }
408 450