aboutsummaryrefslogtreecommitdiff
path: root/js/panels/Timeline/TimelinePanel.reel
diff options
context:
space:
mode:
Diffstat (limited to 'js/panels/Timeline/TimelinePanel.reel')
-rw-r--r--js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js329
1 files changed, 294 insertions, 35 deletions
diff --git a/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js b/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js
index f6e0e252..1ddb3977 100644
--- a/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js
+++ b/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js
@@ -326,6 +326,9 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
326 } 326 }
327 } 327 }
328 }, 328 },
329 _dragLayerIndexes: {
330 value: []
331 },
329 _dropLayerID : { 332 _dropLayerID : {
330 value: null 333 value: null
331 }, 334 },
@@ -337,6 +340,38 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
337 if (newVal !== this._dropLayerID) { 340 if (newVal !== this._dropLayerID) {
338 this._dropLayerID = newVal; 341 this._dropLayerID = newVal;
339 342
343 var dropLayerIndex = this.getLayerIndexByID(this.dropLayerID),
344 arrDragLayers = [],
345 i = 0,
346 dragLayerIndexesLength = this._dragLayerIndexes.length;
347
348 // TODO: possibly we'll need to sort dragLayerIndexes so things don't get out of order?
349
350 for (i = 0; i < dragLayerIndexesLength; i++) {
351 var myDraggingLayer = this.arrLayers[this._dragLayerIndexes[i]];
352 arrDragLayers.push(myDraggingLayer);
353 this.arrLayers.splice(this._dragLayerIndexes[i], 1);
354 this.arrLayers.splice(dropLayerIndex, 0, myDraggingLayer);
355 }
356 console.log(arrDragLayers);
357 //this.arrLayers.splice(dropLayerIndex, 0, arrDragLayers);
358 this.layersDragged = arrDragLayers;
359 console.log(this.layersDragged);
360 console.log(this.arrLayers);
361 this._layerDroppedInPlace = this.arrLayers[dropLayerIndex];
362 this.cacheTimeline();
363
364 this._dropLayerID = null;
365 this.dragLayerIndexes = [];
366 this._dragLayerIndexes = [];
367 this.lastLayerClicked = 0;
368
369 // Sometimes, just to be fun, the drop and dragend events don't fire.
370 // So just in case, set the draw routine to delete the helper.
371 this._deleteHelper = true;
372 this.needsDraw = true;
373
374/*
340 var dragLayerIndex = this.getLayerIndexByID(this.dragLayerID), 375 var dragLayerIndex = this.getLayerIndexByID(this.dragLayerID),
341 dropLayerIndex = this.getLayerIndexByID(this.dropLayerID), 376 dropLayerIndex = this.getLayerIndexByID(this.dropLayerID),
342 dragLayer = this.arrLayers[dragLayerIndex]; 377 dragLayer = this.arrLayers[dragLayerIndex];
@@ -355,6 +390,7 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
355 // So just in case, set the draw routine to delete the helper. 390 // So just in case, set the draw routine to delete the helper.
356 this._deleteHelper = true; 391 this._deleteHelper = true;
357 this.needsDraw = true; 392 this.needsDraw = true;
393*/
358 } 394 }
359 } 395 }
360 }, 396 },
@@ -480,6 +516,7 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
480 returnObj.layerData = {}; 516 returnObj.layerData = {};
481 returnObj.layerData.layerName = null; 517 returnObj.layerData.layerName = null;
482 returnObj.layerData.layerID = null; 518 returnObj.layerData.layerID = null;
519 returnObj.layerData.stageElement = null;
483 returnObj.layerData.isMainCollapsed = true; 520 returnObj.layerData.isMainCollapsed = true;
484 returnObj.layerData.isPositionCollapsed = true; 521 returnObj.layerData.isPositionCollapsed = true;
485 returnObj.layerData.isTransformCollapsed = true; 522 returnObj.layerData.isTransformCollapsed = true;
@@ -584,7 +621,7 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
584 // Bind all document-specific events (pass in true to unbind) 621 // Bind all document-specific events (pass in true to unbind)
585 _bindDocumentEvents : { 622 _bindDocumentEvents : {
586 value: function(boolUnbind) { 623 value: function(boolUnbind) {
587 var arrEvents = [ "newLayer", 624 var arrEvents = [ "stageElement",
588 "deleteLayer", 625 "deleteLayer",
589 "elementAdded", 626 "elementAdded",
590 "elementsRemoved", 627 "elementsRemoved",
@@ -895,13 +932,16 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
895 } 932 }
896 }, 933 },
897 934
898 handleSelectionChange:{ 935 // Event handler for changes in stage selection.
899 value:function () { 936 handleSelectionChange: {
937 value:function (event) {
938 this.updateLayerSelection();
939 /*
900 var layerIndex, 940 var layerIndex,
901 i = 0, 941 i = 0,
902 j = 0, 942 j = 0,
903 arrLayersLength = this.arrLayers.length, 943 arrLayersLength = this.arrLayers.length,
904 intNumSelected = this.application.ninja.selectedElements.length, 944 intNumSelected = event.detail.elements.length,
905 checkIndex = 0; 945 checkIndex = 0;
906 946
907 //console.log("TimelinePanel.handleSelectionChange, intNumSelected is ", intNumSelected) 947 //console.log("TimelinePanel.handleSelectionChange, intNumSelected is ", intNumSelected)
@@ -919,12 +959,17 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
919 // Build an array of indexes of selected layers to give to the selectLayers method 959 // Build an array of indexes of selected layers to give to the selectLayers method
920 var arrSelectedIndexes = []; 960 var arrSelectedIndexes = [];
921 //this.currentLayerSelected = false; 961 //this.currentLayerSelected = false;
962
963 //console.log(event.detail.elements);
964 //console.log(this.layerRepetition.childComponents);
965
922 for (i = 0; i < intNumSelected; i++) { 966 for (i = 0; i < intNumSelected; i++) {
923 var currentCheck = this.application.ninja.selectedElements[i].uuid; 967 var currentCheck = event.detail.elements[i];
924 //console.log("checking ", currentCheck); 968 //console.log("checking ", currentCheck);
925 for (j = 0; j < arrLayersLength; j++) { 969 for (j = 0; j < arrLayersLength; j++) {
926 //console.log(".......... ", this.arrLayers[j].layerData.elementsList[0].uuid) 970 //console.log(".......... ", this.arrLayers[j].layerData.stageElement)
927 if (currentCheck === this.arrLayers[j].layerData.elementsList[0].uuid) { 971 // if (currentCheck === this.arrLayers[j].layerData.elementsList[0].uuid) {
972 if (currentCheck === this.arrLayers[j].layerData.stageElement) {
928 //console.log("...............Yes!") 973 //console.log("...............Yes!")
929 arrSelectedIndexes.push(j); 974 arrSelectedIndexes.push(j);
930 } 975 }
@@ -932,17 +977,120 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, {
932 } 977 }
933 this.selectLayers(arrSelectedIndexes); 978 this.selectLayers(arrSelectedIndexes);
934 } 979 }
980 */
935 } 981 }
936 }, 982 },
937 983
984 // Select the layers whose indexes are passed in as arrSelectedIndexes.
985 // Pass in an empty array to clear all selections.
938 selectLayers:{ 986 selectLayers:{
939 value:function (arrSelectedIndexes, userSelection) { 987 value:function (arrSelectedIndexes) {
988 var i = 0,
989 j = 0,
990 arrLayersLength = this.arrLayers.length,
991 arrSelectedIndexesLength = arrSelectedIndexes.length,
992 currentLayersSelectedLength = this.currentLayersSelected.length,
993 boolContinue = false,
994 arrSelectedLayers = false,
995 arrCurrentElementsSelected = [];
996 /*
997 console.log(arrSelectedIndexes);
998 console.log(this.currentLayersSelected);
999 // Compare arrSelectedIndexes with this.currentLayersSelected
1000 // If the items are the same, we do not need to do anything.
1001 if (arrSelectedIndexesLength !== currentLayersSelectedLength) {
1002 // Different length in the arrays, we definitely need to continue.
1003 console.log('diferent length')
1004 boolContinue = true;
1005 } else {
1006 // Check each selected index and see if it's in this.currentLayersSelected
1007 // If we find one that isn't, we need to continue
1008
1009 for (i = 0; i < arrSelectedIndexesLength; i++) {
1010 console.log('checking for ', arrSelectedIndexes[i]);
1011 if (this.currentLayersSelected.indexOf(arrSelectedIndexes[i]) === -1) {
1012 // Ooops, one of them was not found.
1013 boolContinue = true;
1014 }
1015 }
1016 }
1017 if (boolContinue === false) {
1018 console.log('exiting')
1019 return;
1020 }
1021 */
1022
940 1023
1024 // Deselect all layers.
1025 for (i = 0; i < arrLayersLength; i++) {
1026 if (this.arrLayers[i].layerData.isSelected === true) {
1027 this.arrLayers[i].layerData.isSelected = false;
1028 this.triggerLayerBinding(i);
1029 }
1030 }
1031 if (this.currentLayersSelected !== false) {
1032 this.currentLayersSelected = false;
1033 }
1034