aboutsummaryrefslogtreecommitdiff
path: root/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js')
-rw-r--r--js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js109
1 files changed, 62 insertions, 47 deletions
diff --git a/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js b/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js
index a1730b37..8ae801fc 100644
--- a/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js
+++ b/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js
@@ -126,9 +126,18 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
126 } 126 }
127 }, 127 },
128 128
129 currentLayerSelected:{ 129 _currentLayerSelected:{
130 value: null 130 value: null
131 }, 131 },
132 currentLayerSelected : {
133 get: function() {
134 return this._currentLayerSelected;
135 },
136 set: function(newVal) {
137 this._currentLayerSelected = newVal;
138 this.application.ninja.currentDocument.tlCurrentLayerSelected = newVal;
139 }
140 },
132 141
133 millisecondsOffset:{ 142 millisecondsOffset:{
134 value:1000 143 value:1000
@@ -391,10 +400,29 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
391 this._boolCacheArrays = false; 400 this._boolCacheArrays = false;
392 this.arrLayers = this.application.ninja.currentDocument.tlArrLayers; 401 this.arrLayers = this.application.ninja.currentDocument.tlArrLayers;
393 this.currentLayerNumber = this.application.ninja.currentDocument.tllayerNumber; 402 this.currentLayerNumber = this.application.ninja.currentDocument.tllayerNumber;
403 this.currentLayerSelected = this.application.ninja.currentDocument.tlCurrentLayerSelected;
394 this.hashInstance = this.application.ninja.currentDocument.tlLayerHashTable; 404 this.hashInstance = this.application.ninja.currentDocument.tlLayerHashTable;
395 this.hashElementMapToLayer = this.application.ninja.currentDocument.tlElementHashTable; 405 this.hashElementMapToLayer = this.application.ninja.currentDocument.tlElementHashTable;
396 this.hashKey = this.application.ninja.currentDocument.hashKey; 406 this.hashKey = this.application.ninja.currentDocument.hashKey;
397 this._boolCacheArrays = true; 407 this._boolCacheArrays = true;
408
409 // Search through the arrLayers and select the layer that's already selected
410 var i = 0,
411 selectMe = 0,
412 arrLayersLength = this.arrLayers.length;
413 for (i = 0; i < arrLayersLength; i++) {
414 if (this.arrLayers[i].isSelected === true) {
415 selectMe = i;
416 }
417 }
418
419
420 this._captureSelection = true;
421 // TODO: Better solution than a timer.
422 var that = this;
423 setTimeout(function() {
424 that.selectLayer(selectMe, true);
425 }, 300)
398 } 426 }
399 } 427 }
400 }, 428 },
@@ -651,7 +679,6 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
651 // layer on top of it. 679 // layer on top of it.
652 myIndex = this.layerRepetition.selectedIndexes[0]; 680 myIndex = this.layerRepetition.selectedIndexes[0];
653 thingToPush.layerData.layerPosition = myIndex; 681 thingToPush.layerData.layerPosition = myIndex;
654 thingToPush.layerData.isSelected = true;
655 thingToPush.layerData.trackPosition = myIndex; 682 thingToPush.layerData.trackPosition = myIndex;
656 this.arrLayers.splice(myIndex, 0, thingToPush); 683 this.arrLayers.splice(myIndex, 0, thingToPush);
657 this._LayerUndoPosition = myIndex; 684 this._LayerUndoPosition = myIndex;
@@ -665,13 +692,21 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
665 this._LayerUndoPosition = this.arrLayers.length - 1; 692 this._LayerUndoPosition = this.arrLayers.length - 1;
666 //this.hashLayerNumber.setItem(this.hashKey, thingToPush.layerData); 693 //this.hashLayerNumber.setItem(this.hashKey, thingToPush.layerData);
667 this.hashInstance.setItem(this.hashKey, thingToPush.layerData, thingToPush.layerData.layerPosition); 694 this.hashInstance.setItem(this.hashKey, thingToPush.layerData, thingToPush.layerData.layerPosition);
695 indexToSelect = this.arrLayers.length -1;
668 } 696 }
669 697
670 this._LayerUndoObject = thingToPush; 698 this._LayerUndoObject = thingToPush;
671 this._LayerUndoIndex = thingToPush.layerData.layerID; 699 this._LayerUndoIndex = thingToPush.layerData.layerID;
672 this._LayerUndoStatus = true; 700 this._LayerUndoStatus = true;
673 701
674 this.selectLayer(indexToSelect, true); 702 this._captureSelection = true;
703
704 // TODO: Find a better solution than a timout here.
705 var that = this;
706 setTimeout(function() {
707 that.selectLayer(indexToSelect, true);
708 }, 500);
709
675 } 710 }
676 711
677 } 712 }
@@ -768,36 +803,23 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
768 hashVariable++; 803 hashVariable++;
769 } 804 }
770 } 805 }
771 } 806 } else {
772 else { 807 // Only delete a selected layer. If no layer is selected, do nothing.
773 if (!!this.layerRepetition.selectedIndexes) { 808 if (this.layerRepetition.selectedIndexes.length > 0) {
774 809 // Delete the selected item.
775 var myIndex = this.layerRepetition.selectedIndexes[0]; 810 var myIndex = this.layerRepetition.selectedIndexes[0];
776 this._LayerUndoObject = this.arrLayers[myIndex]; 811 this._LayerUndoObject = this.arrLayers[myIndex];
777 812
778 dLayer = this.hashInstance.getItem(this.hashKey); 813 // Deleting a layer should delete associated elements,
779 dLayer[myIndex].layerData.deleted = true; 814 // But the hash tables are messed up.
815 // TODO: Kruti can you fix this?
816 //dLayer = this.hashInstance.getItem(this.hashKey);
817 //dLayer[myIndex].layerData.deleted = true;
818 // ElementMediator.deleteElements(dLayer[myIndex].layerData.elementsList);
780 819
781 this.arrLayers.splice(myIndex, 1); 820 this.arrLayers.splice(myIndex, 1);
782 this._LayerUndoIndex = this._LayerUndoObject.layerData.layerID; 821 this._LayerUndoIndex = this._LayerUndoObject.layerData.layerID;
783 this._LayerUndoPosition = myIndex; 822 this._LayerUndoPosition = myIndex;
784
785 if(myIndex===0){
786 this.selectLayer(0);
787 }
788 else{
789 this.selectLayer(myIndex-1);
790 }
791 ElementMediator.deleteElements(dLayer[myIndex].layerData.elementsList);
792
793 } else {
794 dLayer = this.hashInstance.getItem(this.hashKey);
795 dLayer[this.arrLayers.length - 1].layerData.deleted = true;
796 ElementMediator.deleteElements(dLayer[this.arrLayers.length - 1].layerData.elementsList);
797 this._LayerUndoPosition = this.arrLayers.length - 1;
798 this._LayerUndoObject = this.arrLayers.pop();
799 this._LayerUndoIndex = this._LayerUndoObject.layerData.layerID;
800
801 } 823 }
802 } 824 }
803 } 825 }
@@ -981,38 +1003,31 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
981 value:function (layerIndex, userSelection) { 1003 value:function (layerIndex, userSelection) {
982 var i = 0; 1004 var i = 0;
983 var arrLayersLength = this.arrLayers.length; 1005 var arrLayersLength = this.arrLayers.length;
984 1006
985 if(this.selectedKeyframes){ 1007 if(this.selectedKeyframes){
986 this.deselectTweens(); 1008 this.deselectTweens();
987 } 1009 }
988 for (i = 0; i < arrLayersLength; i++) { 1010 for (i = 0; i < arrLayersLength; i++) {
989 if (i === layerIndex) { 1011 if (i === layerIndex) {
990 this.arrLayers[i].layerData.isSelected = true; 1012 this.arrLayers[i].isSelected = true;
991 } else { 1013 } else {
992 this.arrLayers[i].layerData.isSelected = false; 1014 this.arrLayers[i].isSelected = false;
993 } 1015 }
994 } 1016 }
995 1017
996 //if (layerIndex !== false) { 1018
997 this.layerRepetition.selectedIndexes = [layerIndex]; 1019 this.layerRepetition.selectedIndexes = [layerIndex];
998 this.currentLayerSelected = this.arrLayers[layerIndex]; 1020 this.currentLayerSelected = this.arrLayers[layerIndex];
999 if(userSelection){ 1021 if(userSelection){
1000 if(this._captureSelection){ 1022 if(this._captureSelection){
1001 if(this.currentLayerSelected.layerData.elementsList.length >= 1) { 1023 if(this.currentLayerSelected.layerData.elementsList.length >= 1) {
1002 this.application.ninja.selectionController.selectElements(this.currentLayerSelected.layerData.elementsList); 1024 this.application.ninja.selectionController.selectElements(this.currentLayerSelected.layerData.elementsList);
1003 } else { 1025 } else {
1004 this.application.ninja.selectionController.executeSelectElement(); 1026 this.application.ninja.selectionController.executeSelectElement();
1005 }
1006 } 1027 }
1007 this._captureSelection = true;
1008 } 1028 }
1009 /* 1029 this._captureSelection = true;
1010 } else {
1011 this.layerRepetition.selectedIndexes = null;
1012 this.trackRepetition.selectedIndexes = null;
1013 this.currentLayerSelected = null;
1014 } 1030 }