useWakeLock ​
Reactive Screen Wake Lock API. Provides a way to prevent devices from dimming or locking the screen when an application needs to keep running.
Demo ​
Usage ​
js
import { useWakeLock } from '@vueuse/core'
const { isSupported, isActive, forceRequest, request, release } = useWakeLock()
When request
is called, the wake lock will be requested if the document is visible. Otherwise, the request will be queued until the document becomes visible. If the request is successful, isActive
will be true. Whenever the document is hidden, the isActive
will be false.
When release
is called, the wake lock will be released. If there is a queued request, it will be canceled.
To request a wake lock immediately, even if the document is hidden, use forceRequest
. Note that this may throw an error if the document is hidden.
Type Declarations ​
typescript
type WakeLockType = "screen"
export interface WakeLockSentinel extends EventTarget {
type: WakeLockType
released: boolean
release: () => Promise<void>
}
export type UseWakeLockOptions = ConfigurableNavigator & ConfigurableDocument
/**
* Reactive Screen Wake Lock API.
*
* @see https://vueuse.org/useWakeLock
* @param options
*/
export declare function useWakeLock(options?: UseWakeLockOptions): {
sentinel: ShallowRef<WakeLockSentinel | null, WakeLockSentinel | null>
isSupported: ComputedRef<boolean>
isActive: ComputedRef<boolean>
request: (type: WakeLockType) => Promise<void>
forceRequest: (type: WakeLockType) => Promise<void>
release: () => Promise<void>
}
export type UseWakeLockReturn = ReturnType<typeof useWakeLock>
Source ​
Contributors ​
Anthony Fu
Jelf
Anthony Fu
_Kerman
vuff
HannesOberreiter
wheat
koheing
Changelog ​
v11.0.0-beta.2
on 7/17/2024