aboutsummaryrefslogtreecommitdiff
path: root/js/panels/Timeline/Style.reel/Style.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/panels/Timeline/Style.reel/Style.js')
-rw-r--r--js/panels/Timeline/Style.reel/Style.js706
1 files changed, 415 insertions, 291 deletions
diff --git a/js/panels/Timeline/Style.reel/Style.js b/js/panels/Timeline/Style.reel/Style.js
index 5c1c9eeb..03d674a5 100644
--- a/js/panels/Timeline/Style.reel/Style.js
+++ b/js/panels/Timeline/Style.reel/Style.js
@@ -17,6 +17,8 @@
17 17
18var Montage = require("montage/core/core").Montage; 18var Montage = require("montage/core/core").Montage;
19var Component = require("montage/ui/component").Component; 19var Component = require("montage/ui/component").Component;
20var ElementsMediator = require("js/mediators/element-mediator").ElementMediator
21
20 22
21var LayerStyle = exports.LayerStyle = Montage.create(Component, { 23var LayerStyle = exports.LayerStyle = Montage.create(Component, {
22 24
@@ -169,7 +171,43 @@ var LayerStyle = exports.LayerStyle = Montage.create(Component, {
169 this.needsDraw = true; 171 this.needsDraw = true;
170 } 172 }
171 }, 173 },
172 174
175 addedColorChips:
176 { value: false },
177
178 _colorelement: {
179 writable:true
180 },
181
182 colorelement: {
183 enumerable: true,
184 get: function () {
185 return this._colorelement;
186 },
187 set: function (value) {
188 if (value !== this._colorelement) {
189 this._colorelement = value;
190 }
191 }
192 },
193
194 _fill: {
195 enumerable: false,
196 value: { colorMode: 'rgb', color: { r: 255, g: 255, b: 255, a: 1, css: 'rgb(255,255,255)', mode: 'rgb', wasSetByCode: true, type: 'change' }, webGlColor: [1, 1, 1, 1] }
197 },
198
199 fill: {
200 enumerable: true,
201 get: function () {
202 return this._fill;
203 },
204 set: function (value) {
205 if (value !== this._fill) {
206 this._fill = value;
207 }
208 }
209 },
210
173 handleMousedown: { 211 handleMousedown: {
174 value: function(event) { 212 value: function(event) {
175 this.isActive = true; 213 this.isActive = true;
@@ -196,6 +234,8 @@ var LayerStyle = exports.LayerStyle = Montage.create(Component, {
196 } else { 234 } else {
197 this.element.classList.remove("style-selected"); 235 this.element.classList.remove("style-selected");
198 } 236 }
237
238
199 } 239 }
200 }, 240 },
201 didDraw: { 241 didDraw: {
@@ -222,7 +262,6 @@ var LayerStyle = exports.LayerStyle = Montage.create(Component, {
222 value: function(event) { 262 value: function(event) {
223 // this should be handled via binding, but somehow is not. Setting manually for now. 263 // this should be handled via binding, but somehow is not. Setting manually for now.
224 this.editorProperty = this.myHintable.value; 264 this.editorProperty = this.myHintable.value;
225
226 // Change views. 265 // Change views.
227 this.whichView = "propval"; 266 this.whichView = "propval";
228 } 267 }
@@ -287,6 +326,12 @@ var LayerStyle = exports.LayerStyle = Montage.create(Component, {
287 // First, get the appropriate editor type from the data structure. 326 // First, get the appropriate editor type from the data structure.
288 var tweenable = {}, 327 var tweenable = {},
289 i = 0; 328 i = 0;
329
330 if (this.ruleTweener === true) {
331 return;
332 } else {
333 this.ruleTweener = true;
334 }
290 335
291 tweenable.tweener = "input"; 336 tweenable.tweener = "input";
292 337
@@ -304,17 +349,45 @@ var LayerStyle = exports.LayerStyle = Montage.create(Component, {
304 this.valueEditorHottext.units = tweenable.units; 349 this.valueEditorHottext.units = tweenable.units;
305 this.valueEditorHottext.minValue = tweenable.min; 350 this.valueEditorHottext.minValue = tweenable.min;
306 this.valueEditorHottext.maxValue = tweenable.max; 351 this.valueEditorHottext.maxValue = tweenable.max;
352 this.valueEditorHottext.identifier="hottext";
353 el = this.parentComponent.parentComponent.parentComponent.parentComponent.layerData.stageElement;
354 this.editorValue = parseFloat(ElementsMediator.getProperty(el, this.editorProperty));
355 this.valueEditorHottext.value = this.editorValue
356 this.valueEditorHottext.addEventListener("change",this,false);
357 this.valueEditorHottext.addEventListener("changing",this,false);
307 this.valueEditorHottext.needsDraw = true; 358 this.valueEditorHottext.needsDraw = true;
308 } else if (tweenable.tweener === "color" ) { 359 } else if (tweenable.tweener === "color" ) {
309 this.editorInputContainer.classList.add("hidden"); 360 this.editorInputContainer.classList.add("hidden");
310 this.editorColorContainer.classList.remove("hidden"); 361 this.editorColorContainer.classList.remove("hidden");
311 this.editorHottextContainer.classList.add("hidden"); 362 this.editorHottextContainer.classList.add("hidden");
363
364 if(tweenable.colorType === "fill"){
365 this._isFill = true;
366 }else{
367 if(tweenable.colorType === "stroke"){
368 this._isFill = false;
369 this._borderSide = tweenable.strokePosition
370 }
371 }
372
373 if (this.addedColorChips === false && this.application.ninja.colorController.colorPanelDrawn) {
374 // setup fill color
375 this._fillColorCtrl.props = { side: 'top', align: 'center', wheel: true, palette: true, gradient: false, image: false, nocolor: true, offset: -80 };
376 this.application.ninja.colorController.addButton("chip", this._fillColorCtrl);
377 this.colorelement = this._fillColorCtrl;
378 var currentValue = ElementsMediator.getColor(this.parentComponent.parentComponent.parentComponent.parentComponent.layerData.stageElement,this._isFill,this._borderSide)
379 this.application.ninja.timeline.selectedStyle = this.editorProperty;
380 this._fillColorCtrl.addEventListener("change", this.handleFillColorChange.bind(this), false);
381 this._fillColorCtrl.color(currentValue.colorMode, currentValue.color);
382 this.addedColorChips = true;
383 }
312 // TODO: set up color chip here. 384 // TODO: set up color chip here.
313 } else if (tweenable.tweener === "input"){ 385 } else if (tweenable.tweener === "input"){
314 this.editorInputContainer.classList.remove("hidden"); 386 this.editorInputContainer.classList.remove("hidden");
315 this.editorColorContainer.classList.add("hidden"); 387 this.editorColorContainer.classList.add("hidden");
316 this.editorHottextContainer.classList.add("hidden"); 388 this.editorHottextContainer.classList.add("hidden");
317 this.valueEditorInput.value = this.editorValue; 389 this.valueEditorInput.value = this.editorValue;
390 this.valueEditorInput.addEventListener("blur",this,false);
318 } else { 391 } else {
319 this.log("Warning: unknown tweenable -"+tweenable.tweener+"- specified in style.js.") 392 this.log("Warning: unknown tweenable -"+tweenable.tweener+"- specified in style.js.")
320 } 393 }
@@ -324,296 +397,347 @@ var LayerStyle = exports.LayerStyle = Montage.create(Component, {
324 /* === END: Controllers === */ 397 /* === END: Controllers === */
325 398
326 _myTweenables: { 399 _myTweenables: {
327 value: [ 400 value: [
328 { 401 {
329 "property" : "background-color", 402 "property" : "background-color",
330 "tweener" : "color", 403 "tweener" : "color",
331 "units" : "", 404 "units" : "",
332 "min" : "", 405 "min" : "",
333 "max" : "", 406 "max" : "",
334 "default" :"#FFFFFF" 407 "default" :"#FFFFFF",
335 }, 408 "colorType" :"fill"
336 { 409 },
337 "property" : "background-position-x", 410 {
338 "tweener" : "hottext", 411 "property" : "background-position-x",
339 "units" : "px", 412 "tweener" : "hottext",
340 "min" : -9999, 413 "units" : "px",
341 "max" : 9999, 414 "min" : -9999,
342 "default" : 0 415 "max" : 9999,
343 }, 416 "default" : 0
344 { 417 },
345 "property" : "background-position-y", 418 {
346 "tweener" : "hottext", 419 "property" : "background-position-y",
347 "units" : "px", 420 "tweener" : "hottext",
348 "min" : -9999, 421 "units" : "px",
349 "max" : 9999, 422 "min" : -9999,
350 "default" : 0 423 "max" : 9999,
351 }, 424 "default" : 0
352 { 425 },
353 "property" : "border-color", 426 {
354 "tweener" : "color", 427 "property" : "border-color",
355 "units" : "", 428 "tweener" : "color",
356 "min" : "", 429 "units" : "",
357 "max" : "", 430 "min" : "",
358 "default" : "#FFFFFF" 431 "max" : "",
359 }, 432 "default" : "#FFFFFF",
360 { 433 "colorType" : "stroke",
361 "property" : "border-width", 434 "strokePosition" : false
362 "tweener" : "hottext", 435 },
363 "units" : "px", 436 {
364 "min" : 0, 437 "property" : "border-width",
365 "max" : 9999, 438 "tweener" : "hottext",
366 "default" : 0 439 "units" : "px",
367 }, 440 "min" : 0,