diff --git a/src/renderer/notification-handler.ts b/src/renderer/notification-handler.ts index 58fa9c605..962b8f29c 100644 --- a/src/renderer/notification-handler.ts +++ b/src/renderer/notification-handler.ts @@ -429,26 +429,29 @@ export default class NotificationHandler { newX: number, ) { const [startX, startY] = notificationWindow.getPosition(); - const stepY = (newY - startY) / this.settings.animationSteps; - const stepX = (newX - startX) / this.settings.animationSteps; + const duration = this.settings.animationSteps; + const startTime = Date.now(); - let curStep = 1; - const animationInterval = setInterval(() => { - // Abort condition - if (curStep === this.settings.animationSteps) { + const animateStep = () => { + const elapsed = Date.now() - startTime; + const progress = Math.min(elapsed / duration, 1); + + const currentX = startX + (newX - startX) * progress; + const currentY = startY + (newY - startY) * progress; + + // Set new position + this.setWindowPosition(notificationWindow, currentX, currentY); + + if (progress < 1) { + setTimeout(animateStep, 16); + } else { + // Ensure final position is set this.setWindowPosition(notificationWindow, newX, newY); - clearInterval(animationInterval); - return; } + }; - // Move one step in both x and y directions - this.setWindowPosition( - notificationWindow, - startX + curStep * stepX, - startY + curStep * stepY, - ); - curStep++; - }, this.settings.animationStepMs); + // Start the animation + setTimeout(animateStep, 16); } /**