From 5f451e3cf8864f4e2ec314fd43abf3be7a26a36a Mon Sep 17 00:00:00 2001 From: Vince Date: Sat, 8 Sep 2012 16:56:07 +0200 Subject: [PATCH] Fixing DnD when dragging from canvas elements --- js/controller/PreviewFilmController.js | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/js/controller/PreviewFilmController.js b/js/controller/PreviewFilmController.js index 4da2be07..829f0008 100644 --- a/js/controller/PreviewFilmController.js +++ b/js/controller/PreviewFilmController.js @@ -92,7 +92,10 @@ */ ns.PreviewFilmController.prototype.onDrop_ = function( event, ui ) { var activeFrame; - var originFrameId = parseInt($(event.srcElement).data("tile-number"), 10); + // When we drag from an element, the drag could start from a nested DOM element + // inside the drag target. We normalize that by taking the correct ancestor: + var originTile = $(event.srcElement).closest(".preview-tile"); + var originFrameId = parseInt(originTile.data("tile-number"), 10); var dropTarget = $(event.target); if(dropTarget.data("tile-type") == "interstitial") { @@ -101,7 +104,7 @@ if(isNaN(originFrameId) || isNaN(targetInsertionId)) { return; } - console.log("origin-frame: "+originFrameId+" - targetInsertionId: "+ targetInsertionId) + //console.log("origin-frame: "+originFrameId+" - targetInsertionId: "+ targetInsertionId) this.framesheet.moveFrame(originFrameId, targetInsertionId); activeFrame = targetInsertionId; @@ -119,7 +122,7 @@ if(isNaN(originFrameId) || isNaN(targetSwapId)) { return; } - console.log("origin-frame: "+originFrameId+" - targetSwapId: "+ targetSwapId) + //console.log("origin-frame: "+originFrameId+" - targetSwapId: "+ targetSwapId) this.framesheet.swapFrames(originFrameId, targetSwapId); activeFrame = targetSwapId; }