diff options
Diffstat (limited to 'js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js')
-rw-r--r-- | js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js | 221 |
1 files changed, 100 insertions, 121 deletions
diff --git a/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js b/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js index 190f818c..dfc40c0a 100644 --- a/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js +++ b/js/panels/Timeline/TimelinePanel.reel/TimelinePanel.js | |||
@@ -277,7 +277,6 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
277 | this.layout_tracks.addEventListener("scroll", this.updateLayerScroll.bind(this), false); | 277 | this.layout_tracks.addEventListener("scroll", this.updateLayerScroll.bind(this), false); |
278 | this.user_layers.addEventListener("scroll", this.updateLayerScroll.bind(this), false); | 278 | this.user_layers.addEventListener("scroll", this.updateLayerScroll.bind(this), false); |
279 | this.end_hottext.addEventListener("changing", this.updateTrackContainerWidth.bind(this), false); | 279 | this.end_hottext.addEventListener("changing", this.updateTrackContainerWidth.bind(this), false); |
280 | |||
281 | } | 280 | } |
282 | }, | 281 | }, |
283 | 282 | ||
@@ -285,15 +284,12 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
285 | value:function () { | 284 | value:function () { |
286 | var myIndex; | 285 | var myIndex; |
287 | this.drawTimeMarkers(); | 286 | this.drawTimeMarkers(); |
288 | |||
289 | // Document switching | 287 | // Document switching |
290 | // Check to see if we have saved timeline information in the currentDocument. | 288 | // Check to see if we have saved timeline information in the currentDocument. |
291 | if (typeof(this.application.ninja.currentDocument.isTimelineInitialized) === "undefined") { | 289 | if (typeof(this.application.ninja.currentDocument.isTimelineInitialized) === "undefined") { |
292 | // No, we have no information stored. Create it. | 290 | // No, we have no information stored. Create it. |
293 | this.log('newfile ' + this.application.ninja.currentDocument.name) | ||
294 | this.application.ninja.currentDocument.isTimelineInitialized = true; | 291 | this.application.ninja.currentDocument.isTimelineInitialized = true; |
295 | this.application.ninja.currentDocument.tlArrLayers = []; | 292 | this.application.ninja.currentDocument.tlArrLayers = []; |
296 | this.application.ninja.currentDocument.tlArrTracks = []; | ||
297 | this.application.ninja.currentDocument.tllayerNumber = 0; | 293 | this.application.ninja.currentDocument.tllayerNumber = 0; |
298 | this.application.ninja.currentDocument.tlLayerHashTable=[]; | 294 | this.application.ninja.currentDocument.tlLayerHashTable=[]; |
299 | this.hashKey = this.application.ninja.currentSelectedContainer.uuid; | 295 | this.hashKey = this.application.ninja.currentSelectedContainer.uuid; |
@@ -325,29 +321,17 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
325 | this.application.ninja.currentDocument.tlLayerHashTable = this.hashInstance; | 321 | this.application.ninja.currentDocument.tlLayerHashTable = this.hashInstance; |
326 | this.application.ninja.currentDocument.tlElementHashTable = this.hashElementMapToLayer; | 322 | this.application.ninja.currentDocument.tlElementHashTable = this.hashElementMapToLayer; |
327 | this.application.ninja.currentDocument.hashKey=this.hashKey; | 323 | this.application.ninja.currentDocument.hashKey=this.hashKey; |
328 | |||
329 | |||
330 | |||
331 | } else { | 324 | } else { |
332 | // we do have information stored. Use it. | 325 | // we do have information stored. Use it. |
333 | this._boolCacheArrays = false; | 326 | this._boolCacheArrays = false; |
334 | //this.arrLayers = []; | ||
335 | this.arrLayers = this.application.ninja.currentDocument.tlArrLayers; | 327 | this.arrLayers = this.application.ninja.currentDocument.tlArrLayers; |
336 | this.arrTracks = this.application.ninja.currentDocument.tlArrTracks; | ||
337 | this.currentLayerNumber = this.application.ninja.currentDocument.tllayerNumber; | 328 | this.currentLayerNumber = this.application.ninja.currentDocument.tllayerNumber; |
338 | this.hashInstance = this.application.ninja.currentDocument.tlLayerHashTable; | 329 | this.hashInstance = this.application.ninja.currentDocument.tlLayerHashTable; |
339 | this.hashElementMapToLayer = this.application.ninja.currentDocument.tlElementHashTable; | 330 | this.hashElementMapToLayer = this.application.ninja.currentDocument.tlElementHashTable; |
340 | this.hashKey = this.application.ninja.currentDocument.hashKey; | 331 | this.hashKey = this.application.ninja.currentDocument.hashKey; |
341 | this.selectLayer(0); | 332 | this.selectLayer(0); |
342 | this._boolCacheArrays = true; | 333 | this._boolCacheArrays = true; |
343 | |||
344 | |||
345 | } | 334 | } |
346 | |||
347 | // Redraw all the things | ||
348 | //this.layerRepetition.needsDraw = true; | ||
349 | //this.trackRepetition.needsDraw = true; | ||
350 | //this.needsDraw = true; | ||
351 | } | 335 | } |
352 | }, | 336 | }, |
353 | 337 | ||
@@ -367,7 +351,6 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
367 | 351 | ||
368 | // Clear variables--including repetitions. | 352 | // Clear variables--including repetitions. |
369 | this.hashInstance = null; | 353 | this.hashInstance = null; |
370 | this.hashLayerNumber = null; | ||
371 | this.hashElementMapToLayer = null; | 354 | this.hashElementMapToLayer = null; |
372 | this.arrLayers = []; | 355 | this.arrLayers = []; |
373 | 356 | ||
@@ -391,7 +374,6 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
391 | this._bindDocumentEvents(); | 374 | this._bindDocumentEvents(); |
392 | 375 | ||
393 | this.hashInstance = this.createLayerHashTable(); | 376 | this.hashInstance = this.createLayerHashTable(); |
394 | this.hashLayerNumber = this.createLayerNumberHash(); | ||
395 | this.hashElementMapToLayer = this.createElementMapToLayer(); | 377 | this.hashElementMapToLayer = this.createElementMapToLayer(); |
396 | this.initTimelineForDocument(); | 378 | this.initTimelineForDocument(); |
397 | } | 379 | } |
@@ -501,7 +483,6 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
501 | this._firstTimeLoaded = false; | 483 | this._firstTimeLoaded = false; |
502 | } else { | 484 | } else { |
503 | this.arrLayers.length = 0; | 485 | this.arrLayers.length = 0; |
504 | this.arrTracks.length = 0; | ||
505 | this.hashKey = node.uuid; | 486 | this.hashKey = node.uuid; |
506 | 487 | ||
507 | if (this.returnedObject = this.hashInstance.getItem(this.hashKey)) { | 488 | if (this.returnedObject = this.hashInstance.getItem(this.hashKey)) { |
@@ -533,8 +514,8 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
533 | if (object._el.parentElementUUID !== this.application.ninja.currentSelectedContainer.uuid) { | 514 | if (object._el.parentElementUUID !== this.application.ninja.currentSelectedContainer.uuid) { |
534 | dLayer = this.hashInstance.getItem(object._el.parentElementUUID); | 515 | dLayer = this.hashInstance.getItem(object._el.parentElementUUID); |
535 | while (dLayer[hashVariable]) { | 516 | while (dLayer[hashVariable]) { |
536 | if (dLayer[hashVariable]._layerID === object._el._layerID) { | 517 | if (dLayer[hashVariable].layerData._layerID === object._el._layerID) { |
537 | dLayer[hashVariable].deleted = false; | 518 | dLayer[hashVariable].layerData.deleted = false; |
538 | parentNode = dLayer[hashVariable].parentElement; | 519 | parentNode = dLayer[hashVariable].parentElement; |
539 | break; | 520 | break; |
540 | } | 521 | } |
@@ -544,9 +525,9 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
544 | this.LayerBinding(parentNode); | 525 | this.LayerBinding(parentNode); |
545 | } else { | 526 | } else { |
546 | dLayer = this.hashInstance.getItem(object._el.parentElementUUID); | 527 | dLayer = this.hashInstance.getItem(object._el.parentElementUUID); |
547 | while (dLayer[hashVariable]) { | 528 | while (dLayer[hashVariable].layerData) { |
548 | if (dLayer[hashVariable]._layerID === object._el._layerID) { | 529 | if (dLayer[hashVariable].layerData._layerID === object._el._layerID) { |
549 | dLayer[hashVariable].deleted = false; | 530 | dLayer[hashVariable].layerData.deleted = false; |
550 | 531 | ||
551 | this.arrLayers.splice(object._layerPosition, 0, object._el); | 532 | this.arrLayers.splice(object._layerPosition, 0, object._el); |
552 | this.selectLayer(object._layerPosition); | 533 | this.selectLayer(object._layerPosition); |
@@ -561,58 +542,58 @@ var TimelinePanel = exports.TimelinePanel = Montage.create(Component, { | |||
561 | var newLayerName = "", | 542 | var newLayerName = "", |
562 | thingToPush = {}, | 543 | thingToPush = {}, |
563 | myIndex = 0; | 544 | myIndex = 0; |
545 | thingToPush.layerData = {}; | ||
564 | 546 | ||
565 | // this.currentLayerNumber = this.hashLayerNumber.getItem(this._hashKey); | ||
566 | // if (this.currentLayerNumber === undefined) { | ||
567 | // this.currentLayerNumber = 0; | ||
568 | // } | ||
569 | 547 | ||
570 | this.currentLayerNumber = this.currentLayerNumber + 1; | 548 | this.currentLayerNumber = this.currentLayerNumber + 1; |
571 | newLayerName = "Layer " + this.currentLayerNumber; | 549 | newLayerName = "Layer " + this.currentLayerNumber; |
572 | thingToPush.layerName = newLayerName; | 550 | thingToPush.layerData.layerName = newLayerName; |
573 | thingToPush.layerID = this.currentLayerNumber; | 551 | thingToPush.layerData.layerID = this.currentLayerNumber; |
574 | thingToPush.isMainCollapsed = true; | 552 | thingToPush.layerData.isMainCollapsed = true; |
575 | thingToPush.isPositionCollapsed = true; | 553 | thingToPush.layerData.isPositionCollapsed = true; |
576 | thingToPush.isTransformCollapsed = true; | 554 | thingToPush.layerData.isTransformCollapsed = true; |
577 | thingToPush.isStyleCollapsed = true; | 555 | thingToPush.layerData.isStyleCollapsed = true; |
578 | thingToPush.arrLayerStyles = []; | 556 | thingToPush.layerData.arrLayerStyles = []; |
579 | thingToPush.elementsList = []; | 557 | thingToPush.layerData.elementsList = []; |
580 | thingToPush.deleted = false; | 558 | thingToPush.layerData.deleted = false; |
581 | thingToPush.isSelected = false; | 559 | thingToPush.layerData.isSelected = false; |
582 | thingToPush.created=false; | 560 | |
583 | thingToPush.isTrackAnimated = false; | 561 | thingToPush.layerData.isActive = false; |
584 | thingToPush.currentKeyframeRule = null; | 562 | |
585 | thingToPush.trackPosition = 0; | 563 | thingToPush.layerData.created=false; |
586 | thingToPush.arrStyleTracks = []; | 564 | thingToPush.layerData.isTrackAnimated = false; |
587 | thingToPush.tweens = []; | 565 | thingToPush.layerData.currentKeyframeRule = null; |
566 | thingToPush.layerData.trackPosition = 0; | ||
567 | thingToPush.layerData.arrStyleTracks = []; | ||
568 | thingToPush.layerData.tweens = []; | ||
588 | 569 | ||
589 | thingToPush.parentElementUUID = this.hashKey; | 570 | thingToPush.parentElementUUID = this.hashKey; |
590 | thingToPush.parentElement = this.application.ninja.currentSelectedContainer; | 571 | thingToPush.parentElement = this.application.ninja.currentSelectedContainer; |
591 | 572 | ||
592 | if (!!this.layerRepetition.selectedIndexes) { | 573 | if (!!this.layerRepetition.selectedIndexes) { |
593 | myIndex = this.layerRepetition.selectedIndexes[0]; | 574 | myIndex = this.layerRepetition.selectedIndexes[0]; |
594 | thingToPush.layerPosition = myIndex; | 575 | thingToPush.layerData.layerPosition = myIndex; |
595 | thingToPush.isSelected = true; | 576 | thingToPush.layerData.isSelected = true; |
596 | thingToPush.trackPosition = myIndex; | 577 | thingToPush.layerData.trackPosition = myIndex; |
597 | this.arrLayers.splice(myIndex, 0, thingToPush); | 578 | this.arrLayers.splice(myIndex, 0, thingToPush); |
598 | this._LayerUndoPosition = myIndex; | 579 |