2015-03-12 03:48:43 +00:00
|
|
|
/**
|
2015-03-23 20:35:08 +00:00
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
2015-03-12 03:48:43 +00:00
|
|
|
*
|
|
|
|
* @providesModule AppStateIOS
|
2015-03-24 20:26:29 +00:00
|
|
|
* @flow
|
2015-03-12 03:48:43 +00:00
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var NativeModules = require('NativeModules');
|
|
|
|
var RCTDeviceEventEmitter = require('RCTDeviceEventEmitter');
|
2015-03-18 05:22:03 +00:00
|
|
|
var RCTAppState = NativeModules.AppState;
|
2015-03-12 03:48:43 +00:00
|
|
|
|
|
|
|
var logError = require('logError');
|
|
|
|
|
|
|
|
var DEVICE_APPSTATE_EVENT = 'appStateDidChange';
|
|
|
|
|
|
|
|
var _appStateHandlers = {};
|
|
|
|
|
2015-03-25 21:34:57 +00:00
|
|
|
/**
|
|
|
|
* `AppStateIOS` can tell you if the app is in the foreground or background,
|
|
|
|
* and notify you when the state changes.
|
|
|
|
*
|
|
|
|
* AppStateIOS is frequently used to determine the intent and proper behavior when
|
|
|
|
* handling push notifications.
|
|
|
|
*
|
|
|
|
* ### iOS App States
|
|
|
|
*
|
|
|
|
* - `active` - The app is running in the foreground
|
|
|
|
* - `background` - The app is running in the background. The user is either
|
|
|
|
* in another app or on the home screen
|
|
|
|
* - `inactive` - This is a transition state that currently never happens for
|
|
|
|
* typical React Native apps.
|
|
|
|
*
|
|
|
|
* For more information, see
|
|
|
|
* [Apple's documentation](https://developer.apple.com/library/ios/documentation/iPhone/Conceptual/iPhoneOSProgrammingGuide/TheAppLifeCycle/TheAppLifeCycle.html)
|
|
|
|
*
|
|
|
|
* ### Basic Usage
|
|
|
|
*
|
|
|
|
* To see the current state, you can check `AppStateIOS.currentState`, which
|
|
|
|
* will be kept up-to-date. However, `currentState` will be null at launch
|
|
|
|
* while `AppStateIOS` retrieves it over the bridge.
|
|
|
|
*
|
|
|
|
* ```
|
|
|
|
* getInitialState: function() {
|
|
|
|
* return {
|
|
|
|
* currentAppState: AppStateIOS.currentState,
|
|
|
|
* };
|
|
|
|
* },
|
|
|
|
* componentDidMount: function() {
|
|
|
|
* AppStateIOS.addEventListener('change', this._handleAppStateChange);
|
|
|
|
* },
|
|
|
|
* componentWillUnmount: function() {
|
|
|
|
* AppStateIOS.removeEventListener('change', this._handleAppStateChange);
|
|
|
|
* },
|
|
|
|
* _handleAppStateChange: function(currentAppState) {
|
|
|
|
* this.setState({ currentAppState, });
|
|
|
|
* },
|
|
|
|
* render: function() {
|
|
|
|
* return (
|
|
|
|
* <Text>Current state is: {this.state.currentAppState}</Text>
|
|
|
|
* );
|
|
|
|
* },
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* This example will only ever appear to say "Current state is: active" because
|
|
|
|
* the app is only visible to the user when in the `active` state, and the null
|
|
|
|
* state will happen only momentarily.
|
|
|
|
*/
|
2015-03-12 03:48:43 +00:00
|
|
|
|
2015-03-25 21:34:57 +00:00
|
|
|
var AppStateIOS = {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a handler to AppState changes by listening to the `change` event type
|
|
|
|
* and providing the handler
|
|
|
|
*/
|
|
|
|
addEventListener: function(
|
|
|
|
type: string,
|
|
|
|
handler: Function
|
|
|
|
) {
|
2015-03-12 03:48:43 +00:00
|
|
|
_appStateHandlers[handler] = RCTDeviceEventEmitter.addListener(
|
|
|
|
DEVICE_APPSTATE_EVENT,
|
|
|
|
(appStateData) => {
|
|
|
|
handler(appStateData.app_state);
|
|
|
|
}
|
|
|
|
);
|
2015-03-25 21:34:57 +00:00
|
|
|
},
|
2015-03-12 03:48:43 +00:00
|
|
|
|
2015-03-25 21:34:57 +00:00
|
|
|
/**
|
|
|
|
* Remove a handler by passing the `change` event type and the handler
|
|
|
|
*/
|
|
|
|
removeEventListener: function(
|
|
|
|
type: string,
|
|
|
|
handler: Function
|
|
|
|
) {
|
2015-03-12 03:48:43 +00:00
|
|
|
if (!_appStateHandlers[handler]) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
_appStateHandlers[handler].remove();
|
|
|
|
_appStateHandlers[handler] = null;
|
2015-03-25 21:34:57 +00:00
|
|
|
},
|
2015-03-12 03:48:43 +00:00
|
|
|
|
2015-03-25 21:34:57 +00:00
|
|
|
currentState: (null : ?String),
|
2015-03-12 03:48:43 +00:00
|
|
|
|
2015-03-25 21:34:57 +00:00
|
|
|
};
|
2015-03-12 03:48:43 +00:00
|
|
|
|
|
|
|
RCTDeviceEventEmitter.addListener(
|
|
|
|
DEVICE_APPSTATE_EVENT,
|
|
|
|
(appStateData) => {
|
|
|
|
AppStateIOS.currentState = appStateData.app_state;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2015-03-17 10:08:46 +00:00
|
|
|
RCTAppState.getCurrentAppState(
|
2015-03-12 03:48:43 +00:00
|
|
|
(appStateData) => {
|
|
|
|
AppStateIOS.currentState = appStateData.app_state;
|
|
|
|
},
|
|
|
|
logError
|
|
|
|
);
|
|
|
|
|
|
|
|
module.exports = AppStateIOS;
|