feat(Notification): add pauseTimeoutOnHover prop (#2661)

This commit is contained in:
Harsh Patel
2024-11-26 02:39:40 +05:30
committed by GitHub
parent 419a24f703
commit 11b8c3d9db
2 changed files with 9 additions and 4 deletions

View File

@@ -137,9 +137,9 @@ excludedProps:
### Timeout
Use the `timeout` prop to configure how long the Notification will remain. The default value is `5000`, set it to `0` to disable the timeout.
Use the `timeout` prop to configure how long the Notification will remain. The default value is `5000`, set it to `0` to disable the timeout. The `pauseTimeoutOnHover` prop (`true` by default) controls whether hovering the notification should pause the timeout.
You will see a progress bar at the bottom of the Notification which will indicate the remaining time. When hovering the Notification, the progress bar will be paused.
You will see a progress bar at the bottom of the Notification which will indicate the remaining time. When hovering the Notification, the progress bar will be paused if `pauseTimeoutOnHover` is enabled; otherwise, it won't stop.
::component-card
---
@@ -149,6 +149,7 @@ baseProps:
description: 'This is a notification.'
props:
timeout: 60000
pauseTimeoutOnHover: true
---
::

View File

@@ -117,6 +117,10 @@ export default defineComponent({
ui: {
type: Object as PropType<DeepPartial<typeof config> & { strategy?: Strategy }>,
default: () => ({})
},
pauseTimeoutOnHover: {
type: Boolean,
default: true
}
},
emits: ['close'],
@@ -157,13 +161,13 @@ export default defineComponent({
})
function onMouseover() {
if (timer) {
if (props.pauseTimeoutOnHover && timer) {
timer.pause()
}
}
function onMouseleave() {
if (timer) {
if (props.pauseTimeoutOnHover && timer) {
timer.resume()
}
}