diff --git a/src/components/bottomSheet/BottomSheet.tsx b/src/components/bottomSheet/BottomSheet.tsx index 1ecb94097..b0b1fda56 100644 --- a/src/components/bottomSheet/BottomSheet.tsx +++ b/src/components/bottomSheet/BottomSheet.tsx @@ -685,6 +685,7 @@ const BottomSheetComponent = forwardRef( currentPosition: animatedPosition.value, position, velocity, + animatedContainerHeight: animatedContainerHeight.value, }, }); @@ -1297,6 +1298,31 @@ const BottomSheetComponent = forwardRef( const _previousSnapPoints = _previousResult?.snapPoints; const _previousContainerHeight = _previousResult?.containerHeight; + let nextPosition; + let animationConfig; + let animationSource = ANIMATION_SOURCE.SNAP_POINT_CHANGE; + + /** + * if the bottom sheet is closing and the container gets resized, + * then we restart the closing animation to the new position. + */ + if ( + animatedAnimationState.value === ANIMATION_STATE.RUNNING && + animatedNextPositionIndex.value === -1 && + _previousContainerHeight !== containerHeight + ) { + animationSource = ANIMATION_SOURCE.CONTAINER_RESIZE; + animationConfig = { + duration: 0, + }; + animateToPosition( + containerHeight, + animationSource, + 0, + animationConfig + ); + } + if ( JSON.stringify(snapPoints) === JSON.stringify(_previousSnapPoints) || !isLayoutCalculated.value || @@ -1314,10 +1340,6 @@ const BottomSheetComponent = forwardRef( }, }); - let nextPosition; - let animationConfig; - let animationSource = ANIMATION_SOURCE.SNAP_POINT_CHANGE; - /** * if snap points changed while sheet is animating, then * we stop the animation and animate to the updated point.