File: keep-awake.md | Updated: 11/15/2025
Hide navigation
Search
Ctrl K
Home Guides EAS Reference Learn
Reference version
SDK 54
Archive Expo Snack Discord and Forums Newsletter
Expo KeepAwakeA React component that prevents the screen from sleeping when rendered.
Android
iOS
tvOS
Web
Bundled version:
~15.0.7
Copy page
expo-keep-awake provides a React hook that prevents the screen from sleeping and a pair of functions to enable this behavior imperatively.
Terminal
Copy
- npx expo install expo-keep-awake
If you are installing this in an existing React Native app
, make sure to install expo
in your project.
Keep Awake hook
Copy
Open in Snack
import { useKeepAwake } from 'expo-keep-awake'; import React from 'react'; import { Text, View } from 'react-native'; export default function KeepAwakeExample() { useKeepAwake(); return ( <View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}> <Text>This screen will never sleep!</Text> </View> ); }
Keep Awake functions
Copy
Open in Snack
import { activateKeepAwake, deactivateKeepAwake } from 'expo-keep-awake'; import React from 'react'; import { Button, View } from 'react-native'; export default class KeepAwakeExample extends React.Component { render() { return ( <View style={{ flex: 1, alignItems: 'center', justifyContent: 'center' }}> <Button onPress={this._activate} title="Activate" /> <Button onPress={this._deactivate} title="Deactivate" /> </View> ); } _activate = () => { activateKeepAwake(); alert('Activated!'); }; _deactivate = () => { deactivateKeepAwake(); alert('Deactivated!'); }; }
Show More
import * as KeepAwake from 'expo-keep-awake';
KeepAwake.ExpoKeepAwakeTagType: 'ExpoKeepAwakeDefaultTag'
Default tag, used when no tag has been specified in keep awake method calls.
useKeepAwake(tag, options)| Parameter | Type | Description |
| --- | --- | --- |
| tag(optional) | string | Tag to lock screen sleep prevention. If not provided, an ID unique to the owner component is used. |
| options(optional) | [KeepAwakeOptions](https://docs.expo.dev/versions/v54.0.0/sdk/keep-awake#keepawakeoptions) | Additional options for the keep awake hook. |
A React hook to keep the screen awake for as long as the owner component is mounted. The optionally provided tag argument is used when activating and deactivating the keep-awake feature. If unspecified, an ID unique to the owner component is used. See the documentation for activateKeepAwakeAsync below to learn more about the tag argument.
Returns:
void
Deprecated use
activateKeepAwakeAsyncinstead.
KeepAwake.activateKeepAwake(tag)| Parameter | Type | Description |
| --- | --- | --- |
| tag(optional) | string | Tag to lock screen sleep prevention. If not provided, the default tag is used.<br><br>Default:ExpoKeepAwakeTag |
Prevents the screen from sleeping until deactivateKeepAwake is called with the same tag value.
If the tag argument is specified, the screen will not sleep until you call deactivateKeepAwake with the same tag argument. When using multiple tags for activation you'll have to deactivate each one in order to re-enable screen sleep. If tag is unspecified, the default tag is used.
Web support is limited .
Returns:
[Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) <void>
KeepAwake.activateKeepAwakeAsync(tag)| Parameter | Type | Description |
| --- | --- | --- |
| tag(optional) | string | Tag to lock screen sleep prevention. If not provided, the default tag is used.<br><br>Default:ExpoKeepAwakeTag |
Prevents the screen from sleeping until deactivateKeepAwake is called with the same tag value.
If the tag argument is specified, the screen will not sleep until you call deactivateKeepAwake with the same tag argument. When using multiple tags for activation you'll have to deactivate each one in order to re-enable screen sleep. If tag is unspecified, the default tag is used.
Web support is limited .
Returns:
[Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) <void>
KeepAwake.deactivateKeepAwake(tag)| Parameter | Type | Description |
| --- | --- | --- |
| tag(optional) | string | Tag to release the lock on screen sleep prevention. If not provided, the default tag is used.<br><br>Default:ExpoKeepAwakeTag |
Releases the lock on screen-sleep prevention associated with the given tag value. If tag is unspecified, it defaults to the same default tag that activateKeepAwake uses.
Returns:
[Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) <void>
KeepAwake.isAvailableAsync()Returns:
[Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise) <boolean>
true on all platforms except unsupported web browsers
.
KeepAwake.addListener(tagOrListener, listener)Only for:
Web
| Parameter | Type |
| --- | --- |
| tagOrListener | string \| [KeepAwakeListener](https://docs.expo.dev/versions/latest/sdk/keep-awake#keepawakelistenerevent) |
| listener(optional) | [KeepAwakeListener](https://docs.expo.dev/versions/latest/sdk/keep-awake#keepawakelistenerevent) |
Observe changes to the keep awake timer. On web, this changes when navigating away from the active window/tab. No-op on native.
Returns:
EventSubscription
Example
KeepAwake.addListener(({ state }) => { // ... });
KeepAwakeEvent| Property | Type | Description |
| --- | --- | --- |
| state | [KeepAwakeEventState](https://docs.expo.dev/versions/v54.0.0/sdk/keep-awake#keepawakeeventstate) | Keep awake state. |
KeepAwakeListener(event)Only for:
Web
| Parameter | Type |
| --- | --- |
| event | [KeepAwakeEvent](https://docs.expo.dev/versions/v54.0.0/sdk/keep-awake#keepawakeevent) |
Returns:
void
KeepAwakeOptions| Property | Type | Description |
| --- | --- | --- |
| listener(optional) | [KeepAwakeListener](https://docs.expo.dev/versions/latest/sdk/keep-awake#keepawakelistenerevent) | Only for: <br><br>Web<br><br> <br><br>A callback that is invoked when the keep-awake state changes. |
| suppressDeactivateWarnings(optional) | boolean | The call will throw an unhandled promise rejection on Android when the original Activity is dead or deactivated. Set the value to true for suppressing the uncaught exception. |
KeepAwakeEventStateRELEASEKeepAwakeEventState.RELEASE = "release"