diff options
Diffstat (limited to 'js/panels/Timeline/Layer.reel/Layer.js')
-rw-r--r-- | js/panels/Timeline/Layer.reel/Layer.js | 172 |
1 files changed, 13 insertions, 159 deletions
diff --git a/js/panels/Timeline/Layer.reel/Layer.js b/js/panels/Timeline/Layer.reel/Layer.js index 2980842f..81bd1867 100644 --- a/js/panels/Timeline/Layer.reel/Layer.js +++ b/js/panels/Timeline/Layer.reel/Layer.js | |||
@@ -372,17 +372,18 @@ var Layer = exports.Layer = Montage.create(Component, { | |||
372 | } | 372 | } |
373 | } | 373 | } |
374 | }, | 374 | }, |
375 | _animateCollapser : { | 375 | _bypassAnimation : { |
376 | serializable: true, | 376 | serializable: true, |
377 | value: false | 377 | value: false |
378 | }, | 378 | }, |
379 | animateCollapser : { | 379 | bypassAnimation : { |
380 | serializable: true, | 380 | serializable: true, |
381 | get: function() { | 381 | get: function() { |
382 | return this._animateCollapser; | 382 | return this._bypassAnimation; |
383 | }, | 383 | }, |
384 | set: function(newVal) { | 384 | set: function(newVal) { |
385 | this._animateCollapser = newVal; | 385 | //console.log("layer.js _bypassAnimation setter " + newVal) |
386 | this._bypassAnimation = newVal; | ||
386 | } | 387 | } |
387 | }, | 388 | }, |
388 | 389 | ||
@@ -397,11 +398,7 @@ var Layer = exports.Layer = Montage.create(Component, { | |||
397 | this.init(); | 398 | this.init(); |
398 | 399 | ||
399 | var that = this; | 400 | var that = this; |
400 | 401 | ||
401 | this.positionCollapser = Collapser.create(); | ||
402 | this.transformCollapser = Collapser.create(); | ||
403 | this.styleCollapser = Collapser.create(); | ||
404 | |||
405 | // Make it editable! | 402 | // Make it editable! |
406 | this._layerEditable = Hintable.create(); | 403 | this._layerEditable = Hintable.create(); |
407 | this._layerEditable.element = this.titleSelector; | 404 | this._layerEditable.element = this.titleSelector; |
@@ -417,128 +414,12 @@ var Layer = exports.Layer = Montage.create(Component, { | |||
417 | this._layerEditable.editingClass = "editable2"; | 414 | this._layerEditable.editingClass = "editable2"; |
418 | this._layerEditable.value = this.layerName; | 415 | this._layerEditable.value = this.layerName; |
419 | this._layerEditable.needsDraw = true; | 416 | this._layerEditable.needsDraw = true; |
420 | |||
421 | // Change the markup into collapsible sections using the nifty Collapser component! | ||
422 | this.mainCollapser = Collapser.create(); | ||
423 | this.mainCollapser.clicker = this.clicker; | ||
424 | this.mainCollapser.myContent = this.myContent; | ||
425 | this.mainCollapser.contentHeight = 60; | ||
426 | this.myContent.style.height = "0px"; | ||
427 | this.mainCollapser.element = this.myContent; | ||
428 | this.mainCollapser.isCollapsed = this.isMainCollapsed; | ||
429 | this.mainCollapser.isAnimated = true; | ||
430 | this.element.setAttribute("data-layerid", this.layerID); | ||
431 | // Bind the collapser's isToggling property to the isMainCollapsed property, | ||
432 | // so a change in one will affect the other. | ||
433 | Object.defineBinding(this.mainCollapser, "isToggling", { | ||
434 | boundObject: this, | ||
435 | boundObjectPropertyPath: "isMainCollapsed", | ||
436 | oneway: false | ||
437 | }); | ||
438 | this.mainCollapser.clicker.addEventListener("click", this.handleMainCollapserClick.bind(this), false); | ||
439 | |||
440 | /* | ||
441 | this.mainCollapser.labelClickEvent = function(boolBypass) { | ||
442 | var newEvent = document.createEvent("CustomEvent"); | ||
443 | newEvent.initCustomEvent("layerEvent", false, true); | ||
444 | newEvent.layerEventLocale = "content-main"; | ||
445 | newEvent.layerEventType = "labelClick"; | ||
446 | newEvent.layerID = that.layerID; | ||
447 | newEvent.bypassAnimation = boolBypass; | ||
448 | defaultEventManager.dispatchEvent(newEvent); | ||
449 | that.isMainCollapsed = that.mainCollapser.isCollapsed; | ||
450 | } | ||
451 | */ | ||
452 | //this.mainCollapser.needsDraw = true; | ||
453 | 417 | ||
454 | this.positionCollapser.clicker = this.clickerPosition; | 418 | this.mainCollapser.clicker.addEventListener("click", this.handleMainCollapserClick.bind(this), false); |
455 | this.positionCollapser.myContent = this.contentPosition; | ||
456 | this.positionCollapser.element = this.contentPosition; | ||
457 | this.positionCollapser.contentHeight = 40; | ||
458 | this.positionCollapser.isCollapsed = this.isPositionCollapsed; | ||
459 | this.positionCollapser.isAnimated = false; | ||
460 | // Bind the collapser's isToggling property to the isPositionCollapsed property, | ||
461 | // so a change in one will affect the other. | ||
462 | Object.defineBinding(this.positionCollapser, "isToggling", { | ||
463 | boundObject: this, | ||
464 | boundObjectPropertyPath: "isPositionCollapsed", | ||
465 | oneway: false | ||
466 | }); | ||
467 | this.positionCollapser.clicker.addEventListener("click", this.handlePositionCollapserClick.bind(this), false); | 419 | this.positionCollapser.clicker.addEventListener("click", this.handlePositionCollapserClick.bind(this), false); |
468 | |||
469 | /* | ||
470 | this.positionCollapser.labelClickEvent = function(boolBypass) { | ||
471 | var newEvent = document.createEvent("CustomEvent"); | ||
472 | newEvent.initCustomEvent("layerEvent", false, true); | ||
473 | newEvent.layerEventLocale = "content-position"; | ||
474 | newEvent.layerEventType = "labelClick"; | ||
475 | newEvent.layerID = that.layerID; | ||
476 | newEvent.bypassAnimation = boolBypass; | ||
477 | defaultEventManager.dispatchEvent(newEvent); | ||
478 | that.isPositionCollapsed = that.positionCollapser.isCollapsed; | ||
479 | } | ||
480 | */ | ||
481 | //this.positionCollapser.needsDraw = true; | ||
482 | |||
483 | this.transformCollapser.clicker = this.clickerTransform; | ||
484 | this.transformCollapser.myContent = this.contentTransform; | ||
485 | this.transformCollapser.element = this.contentTransform; | ||
486 | this.transformCollapser.contentHeight = 100; | ||
487 | this.transformCollapser.isCollapsed = this.isTransformCollapsed; | ||
488 | this.transformCollapser.isAnimated = false; | ||
489 | // Bind the collapser's isToggling property to the isTransformCollapsed property, | ||
490 | // so a change in one will affect the other. | ||
491 | Object.defineBinding(this.transformCollapser, "isToggling", { | ||
492 | boundObject: this, | ||
493 | boundObjectPropertyPath: "isTransformCollapsed", | ||
494 | oneway: false | ||
495 | }); | ||
496 | this.transformCollapser.clicker.addEventListener("click", this.handleTransformCollapserClick.bind(this), false); | 420 | this.transformCollapser.clicker.addEventListener("click", this.handleTransformCollapserClick.bind(this), false); |
497 | |||
498 | |||
499 | /* | ||
500 | this.transformCollapser.labelClickEvent = function(boolBypass) { | ||
501 | var newEvent = document.createEvent("CustomEvent"); | ||
502 | newEvent.initCustomEvent("layerEvent", false, true); | ||
503 | newEvent.layerEventLocale = "content-transform"; | ||
504 | newEvent.layerEventType = "labelClick"; | ||
505 | newEvent.layerID = that.layerID; | ||
506 | newEvent.bypassAnimation = boolBypass; | ||
507 | defaultEventManager.dispatchEvent(newEvent); | ||
508 | that.isTransformCollapsed = that.transformCollapser.isCollapsed; | ||
509 | } | ||
510 | */ | ||
511 | //this.transformCollapser.needsDraw = true; | ||
512 | |||
513 | this.styleCollapser.clicker = this.clickerStyle; | ||
514 | this.styleCollapser.myContent = this.contentStyle; | ||
515 | this.styleCollapser.element = this.contentStyle; | ||
516 | this.styleCollapser.isCollapsed = this.isStyleCollapsed; | ||
517 | this.styleCollapser.contentHeight = 0; | ||
518 | this.styleCollapser.isAnimated = false; | ||
519 | // Bind the collapser's isToggling property to the isStyleCollapsed property, | ||
520 | // so a change in one will affect the other. | ||
521 | Object.defineBinding(this.styleCollapser, "isToggling", { | ||
522 | boundObject: this, | ||
523 | boundObjectPropertyPath: "isStyleCollapsed", | ||
524 | oneway: false | ||
525 | }); | ||
526 | this.styleCollapser.clicker.addEventListener("click", this.handleStyleCollapserClick.bind(this), false); | 421 | this.styleCollapser.clicker.addEventListener("click", this.handleStyleCollapserClick.bind(this), false); |
527 | 422 | ||
528 | |||
529 | /* | ||
530 | this.styleCollapser.labelClickEvent = function(boolBypass) { | ||
531 | var newEvent = document.createEvent("CustomEvent"); | ||
532 | newEvent.initCustomEvent("layerEvent", false, true); | ||
533 | newEvent.layerEventLocale = "content-style"; | ||
534 | newEvent.layerEventType = "labelClick"; | ||
535 | newEvent.layerID = that.layerID; | ||
536 | newEvent.bypassAnimation = boolBypass; | ||
537 | defaultEventManager.dispatchEvent(newEvent); | ||
538 | that.isStyleCollapsed = that.styleCollapser.isCollapsed; | ||
539 | } | ||
540 | */ | ||
541 | //this.styleCollapser.needsDraw = true; | ||
542 | 423 | ||
543 | // Add event listeners to add and delete style buttons | 424 | // Add event listeners to add and delete style buttons |
544 | this.buttonAddStyle.identifier = "addStyle"; | 425 | this.buttonAddStyle.identifier = "addStyle"; |
@@ -555,26 +436,6 @@ var Layer = exports.Layer = Montage.create(Component, { | |||
555 | }, | 436 | }, |
556 | draw: { | 437 | draw: { |
557 | value: function() { | 438 | value: function() { |
558 | |||
559 | // Coordinate the collapsers | ||
560 | this.log('layer.js draw') | ||
561 | if (this.mainCollapser.isCollapsed !== this.isMainCollapsed) { | ||
562 | this.log('layer.js draw: this.animateCollapser ' + this.animateCollapser) | ||
563 | this.mainCollapser.bypassAnimation = this.animateCollapser; | ||
564 | this.mainCollapser.toggle(); | ||
565 | } | ||
566 | if (this.positionCollapser.isCollapsed !== this.isPositionCollapsed) { | ||
567 | this.positionCollapser.bypassAnimation = this.animateCollapser; | ||
568 | this.positionCollapser.toggle(); | ||
569 | } | ||
570 | if (this.transformCollapser.isCollapsed !== this.isTransformCollapsed) { | ||
571 | this.transformCollapser.bypassAnimation = this.animateCollapser; | ||
572 | this.transformCollapser.toggle(); | ||
573 | } | ||
574 | if (this.styleCollapser.isCollapsed !== this.isStyleCollapsed) { | ||
575 | this.styleCollapser.bypassAnimation = this.animateCollapser; | ||
576 | this.styleCollapser.toggle(); | ||
577 | } | ||
578 | if (this.isSelected) { | 439 | if (this.isSelected) { |
579 | this.element.classList.add("selected"); | 440 | this.element.classList.add("selected"); |
580 | } else { | 441 | } else { |
@@ -595,16 +456,9 @@ var Layer = exports.Layer = Montage.create(Component, { | |||
595 | // Get some selectors. | 456 | // Get some selectors. |
596 | this.label = this.element.querySelector(".label-layer"); | 457 | this.label = this.element.querySelector(".label-layer"); |
597 | this.titleSelector = this.label.querySelector(".collapsible-label"); | 458 | this.titleSelector = this.label.querySelector(".collapsible-label"); |
598 | this.clicker = this.element.querySelector(".coll |