aboutsummaryrefslogtreecommitdiff
path: root/js/panels/Timeline/Layer.reel/Layer.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/panels/Timeline/Layer.reel/Layer.js')
-rw-r--r--js/panels/Timeline/Layer.reel/Layer.js132
1 files changed, 83 insertions, 49 deletions
diff --git a/js/panels/Timeline/Layer.reel/Layer.js b/js/panels/Timeline/Layer.reel/Layer.js
index 629b118c..4773489c 100644
--- a/js/panels/Timeline/Layer.reel/Layer.js
+++ b/js/panels/Timeline/Layer.reel/Layer.js
@@ -86,10 +86,12 @@ var Layer = exports.Layer = Montage.create(Component, {
86 if (newVal !== this._selectedStyleIndex) { 86 if (newVal !== this._selectedStyleIndex) {
87 this._selectedStyleIndex = newVal; 87 this._selectedStyleIndex = newVal;
88 this.layerData.selectedStyleIndex = newVal; 88 this.layerData.selectedStyleIndex = newVal;
89 this.needsDraw = true;
90 } 89 }
91 } 90 }
92 }, 91 },
92 _storedStyleIndex : {
93 value: false
94 },
93 95
94 /* Layer models: the name, ID, and selected and animation booleans for the layer */ 96 /* Layer models: the name, ID, and selected and animation booleans for the layer */
95 _layerName:{ 97 _layerName:{
@@ -276,6 +278,10 @@ var Layer = exports.Layer = Montage.create(Component, {
276 if (value === false) { 278 if (value === false) {
277 // If changing from true to false, we need to deselect any associated styles 279 // If changing from true to false, we need to deselect any associated styles
278 this.selectStyle(false); 280 this.selectStyle(false);
281 } else {
282 if (this._storedStyleIndex !== false) {
283 this.selectStyle(this._storedStyleIndex);
284 }
279 } 285 }
280 this._isSelected = value; 286 this._isSelected = value;
281 this.layerData.isSelected = value; 287 this.layerData.isSelected = value;
@@ -342,6 +348,19 @@ var Layer = exports.Layer = Montage.create(Component, {
342 _layerEditable : { 348 _layerEditable : {
343 value: false 349 value: false
344 }, 350 },
351
352 _dynamicLayerName:{
353 value:true
354 },
355 dynamicLayerName:{
356 serializable:true,
357 get:function () {
358 return this._dynamicLayerName;
359 },
360 set:function (newVal) {
361 this._dynamicLayerName = newVal;
362 }
363 },
345 364
346 // Are the various collapsers collapsed or not 365 // Are the various collapsers collapsed or not
347 _isMainCollapsed : { 366 _isMainCollapsed : {
@@ -565,7 +584,7 @@ var Layer = exports.Layer = Montage.create(Component, {
565 } 584 }
566 // Enable or disable the delete style button as appropriate 585 // Enable or disable the delete style button as appropriate
567 if (this.isSelected) { 586 if (this.isSelected) {
568 if (this.selectedStyleIndex !== "false") { 587 if (this.selectedStyleIndex !== false) {
569 this.selectStyle(this.selectedStyleIndex); 588 this.selectStyle(this.selectedStyleIndex);
570 this.buttonDeleteStyle.classList.remove("disabled"); 589 this.buttonDeleteStyle.classList.remove("disabled");
571 } 590 }
@@ -620,7 +639,7 @@ var Layer = exports.Layer = Montage.create(Component, {
620 } 639 }
621 }, 640 },
622 addStyle : { 641 addStyle : {
623 value: function(styleProperty) { 642 value: function(styleProperty, existingRule) {
624 // Add a new style rule. It should be added above the currently selected rule, 643 // Add a new style rule. It should be added above the currently selected rule,
625 // Or at the end, if no rule is selected. 644 // Or at the end, if no rule is selected.
626 645
@@ -649,13 +668,16 @@ var Layer = exports.Layer = Montage.create(Component, {
649 newStyle.editorProperty = styleProperty; 668 newStyle.editorProperty = styleProperty;
650 newEvent.layerEventType = "restoreStyle"; 669 newEvent.layerEventType = "restoreStyle";
651 newEvent.trackEditorProperty = styleProperty; 670 newEvent.trackEditorProperty = styleProperty;
652 newEvent.trackEditorProperty = styleProperty; 671 if(existingRule){
672 newEvent.existingRule = existingRule;
673 }
653 } 674 }
654 newStyle.editorValue = ""; 675 newStyle.editorValue = "";
655 newStyle.ruleTweener = false; 676 newStyle.ruleTweener = false;
656 newStyle.isSelected = false; 677 newStyle.isSelected = false;
657 newStyle.colorelement = ""; 678 newStyle.colorelement = "";
658 this.arrLayerStyles.push(newStyle); 679 this.arrLayerStyles.push(newStyle);
680 this.selectStyle(this.arrLayerStyles.length -1);
659 681
660 // Set up the event info and dispatch the event 682 // Set up the event info and dispatch the event
661 this.styleCounter += 1; 683 this.styleCounter += 1;
@@ -666,56 +688,64 @@ var Layer = exports.Layer = Montage.create(Component, {
666 688
667 deleteStyle : { 689 deleteStyle : {
668 value: function() { 690 value: function() {
669 var newEvent = document.createEvent("CustomEvent"), 691
670 selectedIndex = 0; 692 // Only delete a style if we have one or more styles, and one of them is selected
671 if (this.arrLayerStyles.length > 0) { 693 if ((this.arrLayerStyles.length > 0) && (this.selectedStyleIndex !== false)) {
672 if (!!this.styleRepetition.selectedIndexes) { 694 var newEvent = document.createEvent("CustomEvent");
673 695
674 selectedIndex = this.styleRepetition.selectedIndexes[0]; 696 // Set up the event info and dispatch the event
675 697 newEvent.initCustomEvent("layerEvent", false, true);
676 // Set up the event info and dispatch the event 698 newEvent.layerEventLocale = "styles";
677 newEvent.initCustomEvent("layerEvent", false, true); 699 newEvent.layerEventType = "deleteStyle";
678 newEvent.layerEventLocale = "styles"; 700 newEvent.layerID = this.layerID;
679 newEvent.layerEventType = "deleteStyle"; 701 newEvent.styleID = this.selectedStyleIndex;
680 newEvent.layerID = this.layerID; 702 newEvent.selectedStyleIndex = this.selectedStyleIndex;
681 newEvent.styleID = this.arrLayerStyles[selectedIndex].styleID; 703 defaultEventManager.dispatchEvent(newEvent);
682 newEvent.styleSelection = selectedIndex; 704
683 defaultEventManager.dispatchEvent(newEvent); 705 // Delete the style from the view
684 706 this.arrLayerStyles.splice(this.selectedStyleIndex, 1);
685 // Delete the style from the view 707
686 this.arrLayerStyles.splice(selectedIndex, 1); 708 // Set selection to none
687 709 this.selectedStyleIndex = false;
688 // Was that the last style? 710
689 if (this.arrLayerStyles.length === 0) { 711 // Disable the delete style button, because now nothing is selected
690 this.buttonDeleteStyle.classList.add("disabled"); 712 this.buttonDeleteStyle.classList.add("disabled");
691 } 713 }
692
693 }
694 }
695 } 714 }
696 }, 715 },
697 selectStyle : { 716 selectStyle : {
698 value: function(styleIndex) { 717 value: function(styleIndex) {
699 //console.log("Layer.selectStyle ", styleIndex);
700
701 // Select a style based on its index. 718 // Select a style based on its index.
702 // use layerIndex = false to deselect all styles. 719 // use layerIndex = false to deselect all styles.
703 var i = 0, 720 var i = 0,
704 arrLayerStylesLength = this.arrLayerStyles.length; 721 arrLayerStylesLength = this.arrLayerStyles.length;
705 722
706 723 if (styleIndex === false) {
707 // First, update this.arrStyles[].isSelected 724 if (arrLayerStylesLength === 0) {
708 for (i = 0; i < arrLayerStylesLength; i++) { 725 // No styles selected, so do nothing.
709 if (i === styleIndex) { 726 return;
710 this.arrLayerStyles[i].isSelected = true; 727 }
711 } else { 728 for (i = 0; i < arrLayerStylesLength; i++) {
712 if (this.arrLayerStyles[i].isSelected === true) { 729 if (this.arrLayerStyles[i].isSelected === true) {
713 this.arrLayerStyles[i].isSelected = false; 730 this.arrLayerStyles[i].isSelected = false;
714 } 731 }
715 } 732 }
716 } 733 } else {
717 734 for (i = 0; i < arrLayerStylesLength; i++) {
718 735 if (i === styleIndex) {
736 this.arrLayerStyles[i].isSelected = true;
737 } else {
738 if (this.arrLayerStyles[i].isSelected === true) {
739 this.arrLayerStyles[i].isSelected = false;
740 }
741 }
742 }
743 this.selectedStyleIndex = styleIndex;
744 this._storedStyleIndex = styleIndex;
745 }
746
747
748
719 /* 749 /*
720 // Next, update this.styleRepetition.selectedIndexes. 750 // Next, update this.styleRepetition.selectedIndexes.
721 if (styleIndex !== false) { 751 if (styleIndex !== false) {
@@ -757,7 +787,7 @@ var Layer = exports.Layer = Montage.create(Component, {
757 787
758 if (this._layerEditable.value !== this.layerName) { 788 if (this._layerEditable.value !== this.layerName) {
759 this.layerName = this._layerEditable.value; 789 this.layerName = this._layerEditable.value;
760 this.application.ninja.documentController.activeDocument.needsSave = true; 790 this.application.ninja.currentDocument.model.needsSave = true;
761 this.layerData.stageElement.setAttribute("id",this._layerEditable.value); 791 this.layerData.stageElement.setAttribute("id",this._layerEditable.value);
762 } 792 }
763 } 793 }
@@ -775,6 +805,9 @@ var Layer = exports.Layer = Montage.create(Component, {
775 }, 805 },
776 handleDeleteStyleClick: { 806 handleDeleteStyleClick: {