File: keep-awake.md | Updated: 11/15/2025
Hide navigation
Search
Ctrl K
Home Guides EAS Reference Learn
Reference version
SDK 54 (latest)
Archive Expo Snack Discord and Forums Newsletter
Expo KeepAwakeAsk AI
A React component that prevents the screen from sleeping when rendered.
Ask AI
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.ExpoKeepAwakeTagAndroid
iOS
tvOS
Web
Type: 'ExpoKeepAwakeDefaultTag'
Default tag, used when no tag has been specified in keep awake method calls.
useKeepAwake(tag, options)Android
iOS
tvOS
Web
| 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/latest/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)Android
iOS
tvOS
Web
| 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)Android
iOS
tvOS
Web
| 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)Android
iOS
tvOS
Web
| 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()Android
iOS
tvOS
Web
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)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 }) => { // ... });
KeepAwakeEventAndroid
iOS
tvOS
Web
| Property | Type | Description |
| --- | --- | --- |
| state | [KeepAwakeEventState](https://docs.expo.dev/versions/latest/sdk/keep-awake#keepawakeeventstate) | Keep awake state. |
KeepAwakeListener(event)Web
| Parameter | Type |
| --- | --- |
| event | [KeepAwakeEvent](https://docs.expo.dev/versions/latest/sdk/keep-awake#keepawakeevent) |
Returns:
void
KeepAwakeOptionsAndroid
iOS
tvOS
Web
| 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. |
KeepAwakeEventStateAndroid
iOS
tvOS
Web
RELEASEKeepAwakeEventState.RELEASE = "release"