From c6e81242e0aad0218ddc763946212a7e53a8d561 Mon Sep 17 00:00:00 2001 From: chrisklus Date: Mon, 17 Feb 2020 18:33:22 -0500 Subject: [PATCH] Fix block ordering issue, see #216 --- js/intro/view/EFACIntroScreenView.js | 47 +++++++++++++--------------- 1 file changed, 21 insertions(+), 26 deletions(-) diff --git a/js/intro/view/EFACIntroScreenView.js b/js/intro/view/EFACIntroScreenView.js index e6d193eb..3f376144 100644 --- a/js/intro/view/EFACIntroScreenView.js +++ b/js/intro/view/EFACIntroScreenView.js @@ -604,40 +604,35 @@ define( require => { // updates the Z-order of the blocks when their position changes const blockChangeListener = position => { - let currentBlock = null; - let currentBlockNode = null; + const blocks = [ ...model.blocks.array ]; - model.blocks.forEach( block => { - if ( block.positionProperty.value === position ) { - currentBlock = block; + blocks.sort( ( a, b ) => { + // a block that's completely to the right of another block should always be in front + if ( a.bounds.minX >= b.bounds.maxX ) { + return 1; } - } ); - blockNodes.forEach( blockNode => { - if ( blockNode.block === currentBlock ) { - currentBlockNode = blockNode; + else if ( a.bounds.maxX <= b.bounds.minX ) { + return -1; } - } ); - model.blocks.forEach( otherBlock => { - if ( otherBlock === currentBlock ) { - return; + // a block that's above another should always be in front if they overlap in the x direction + if ( a.bounds.minY > b.bounds.minY ) { + return 1; + } + else if ( b.bounds.minY > a.bounds.minY ) { + return -1; + } + else { + return 0; } + } ); - let otherBlockNode = null; + blocks.forEach( block => { blockNodes.forEach( blockNode => { - if ( blockNode.block === otherBlock ) { - otherBlockNode = blockNode; + if ( blockNode.block === block ) { + blockNode.moveToFront(); } - } ); - - if ( currentBlock.getBounds().minX >= otherBlock.getBounds().maxX || - currentBlock.getBounds().minY >= otherBlock.getBounds().maxY ) { - currentBlockNode.moveToFront(); - } - else if ( otherBlock.getBounds().minX >= currentBlock.getBounds().maxX || - otherBlock.getBounds().minY >= currentBlock.getBounds().maxY ) { - otherBlockNode.moveToFront(); - } + } ) } ); };