Skip to content

Commit

Permalink
fix: not restoring position when unmounted
Browse files Browse the repository at this point in the history
  • Loading branch information
zernonia committed Jun 16, 2024
1 parent 9ecd93b commit 638e9f5
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 5 deletions.
8 changes: 6 additions & 2 deletions packages/vaul-vue/src/controls.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { computed, ref, watch, watchEffect } from 'vue'
import { computed, onUnmounted, ref, watch, watchEffect } from 'vue'
import type { ComponentPublicInstance, Ref } from 'vue'
import { isClient } from '@vueuse/core'
import { dampenValue, getTranslateY, reset, set } from './helpers'
Expand Down Expand Up @@ -410,7 +410,6 @@ export function useDrawer(props: UseDrawerProps & DialogEmitHandlers): DrawerRoo
})

scaleBackground(false)
restorePositionSetting()

window.setTimeout(() => {
isVisible.value = false
Expand All @@ -434,6 +433,11 @@ export function useDrawer(props: UseDrawerProps & DialogEmitHandlers): DrawerRoo
}
})

onUnmounted(() => {
scaleBackground(false)
restorePositionSetting()
})

function onRelease(event: PointerEvent) {
if (!isDragging.value || !drawerRef.value)
return
Expand Down
15 changes: 12 additions & 3 deletions packages/vaul-vue/src/usePositionFixed.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,19 +40,24 @@ export function usePositionFixed(options: PositionFixedOptions) {

setTimeout(() => {
requestAnimationFrame(() => {
// Attempt to check if the bottom bar appeared due to the position change
const bottomBarHeight = innerHeight - window.innerHeight
if (bottomBarHeight && scrollPos.value >= innerHeight)
if (bottomBarHeight && scrollPos.value >= innerHeight) {
// Move the content further up so that the bottom bar doesn't hide it
document.body.style.top = `-${scrollPos.value + bottomBarHeight}px`
}
})
}, 300)
}
}

function restorePositionSetting(): void {
if (previousBodyPosition !== null) {
// Convert the position from "px" to Int
const y = -Number.parseInt(document.body.style.top, 10)
const x = -Number.parseInt(document.body.style.left, 10)

// Restore styles
Object.assign(document.body.style, previousBodyPosition)

requestAnimationFrame(() => {
Expand Down Expand Up @@ -84,10 +89,14 @@ export function usePositionFixed(options: PositionFixedOptions) {
watch([isOpen, hasBeenOpened, activeUrl], () => {
if (nested.value || !hasBeenOpened.value)
return

// This is needed to force Safari toolbar to show **before** the drawer starts animating to prevent a gnarly shift from happening
if (isOpen.value) {
setPositionFixed()
// avoid for standalone mode (PWA)
const isStandalone = window.matchMedia('(display-mode: standalone)').matches
!isStandalone && setPositionFixed()

if (!modal) {
if (!modal.value) {
setTimeout(() => {
restorePositionSetting()
}, 500)
Expand Down

0 comments on commit 638e9f5

Please sign in to comment.