mirror of
https://github.com/status-im/react-native.git
synced 2025-01-10 01:25:39 +00:00
ec9efb8a01
Summary:**Motivation** AppStateIOS never currently returns `inactive` as a possible state. I had a requirement that when inactive, certain portions of the app should be blacked out in accordance with compliance rules. This is not possible currently, due to `inactive` never being returned. This PR fixes that. **Test plan** All base tests are passing. Are there AppState specific tests in place at the moment that I'm missing? **Demonstration** ![appstate](https://cloud.githubusercontent.com/assets/286616/13640546/1cb6eeb0-e5e3-11e5-8d64-332ea3383a54.gif) Closes https://github.com/facebook/react-native/pull/6379 Differential Revision: D3035530 Pulled By: nicklockwood fb-gh-sync-id: 93deccc8184816809926dca8a95f2bebd1434987 shipit-source-id: 93deccc8184816809926dca8a95f2bebd1434987
115 lines
3.2 KiB
Objective-C
115 lines
3.2 KiB
Objective-C
/**
|
|
* 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.
|
|
*/
|
|
|
|
#import "RCTAppState.h"
|
|
|
|
#import "RCTAssert.h"
|
|
#import "RCTBridge.h"
|
|
#import "RCTEventDispatcher.h"
|
|
#import "RCTUtils.h"
|
|
|
|
static NSString *RCTCurrentAppBackgroundState()
|
|
{
|
|
static NSDictionary *states;
|
|
static dispatch_once_t onceToken;
|
|
dispatch_once(&onceToken, ^{
|
|
states = @{
|
|
@(UIApplicationStateActive): @"active",
|
|
@(UIApplicationStateBackground): @"background"
|
|
};
|
|
});
|
|
|
|
if (RCTRunningInAppExtension()) {
|
|
return @"extension";
|
|
}
|
|
|
|
return states[@(RCTSharedApplication().applicationState)] ?: @"unknown";
|
|
}
|
|
|
|
@implementation RCTAppState
|
|
{
|
|
NSString *_lastKnownState;
|
|
}
|
|
|
|
@synthesize bridge = _bridge;
|
|
|
|
RCT_EXPORT_MODULE()
|
|
|
|
#pragma mark - Lifecycle
|
|
|
|
- (void)setBridge:(RCTBridge *)bridge
|
|
{
|
|
_bridge = bridge;
|
|
|
|
// Is this thread-safe?
|
|
_lastKnownState = RCTCurrentAppBackgroundState();
|
|
|
|
for (NSString *name in @[UIApplicationDidBecomeActiveNotification,
|
|
UIApplicationDidEnterBackgroundNotification,
|
|
UIApplicationDidFinishLaunchingNotification,
|
|
UIApplicationWillResignActiveNotification,
|
|
UIApplicationWillEnterForegroundNotification]) {
|
|
|
|
[[NSNotificationCenter defaultCenter] addObserver:self
|
|
selector:@selector(handleAppStateDidChange:)
|
|
name:name
|
|
object:nil];
|
|
}
|
|
|
|
[[NSNotificationCenter defaultCenter] addObserver:self
|
|
selector:@selector(handleMemoryWarning)
|
|
name:UIApplicationDidReceiveMemoryWarningNotification
|
|
object:nil];
|
|
}
|
|
|
|
- (void)handleMemoryWarning
|
|
{
|
|
[_bridge.eventDispatcher sendDeviceEventWithName:@"memoryWarning"
|
|
body:nil];
|
|
}
|
|
|
|
- (void)dealloc
|
|
{
|
|
[[NSNotificationCenter defaultCenter] removeObserver:self];
|
|
}
|
|
|
|
#pragma mark - App Notification Methods
|
|
|
|
- (void)handleAppStateDidChange:(NSNotification *)notification
|
|
{
|
|
NSString *newState;
|
|
|
|
if ([notification.name isEqualToString:UIApplicationWillResignActiveNotification]) {
|
|
newState = @"inactive";
|
|
} else if ([notification.name isEqualToString:UIApplicationWillEnterForegroundNotification]) {
|
|
newState = @"active";
|
|
} else {
|
|
newState = RCTCurrentAppBackgroundState();
|
|
}
|
|
|
|
if (![newState isEqualToString:_lastKnownState]) {
|
|
_lastKnownState = newState;
|
|
[_bridge.eventDispatcher sendDeviceEventWithName:@"appStateDidChange"
|
|
body:@{@"app_state": _lastKnownState}];
|
|
}
|
|
}
|
|
|
|
#pragma mark - Public API
|
|
|
|
/**
|
|
* Get the current background/foreground state of the app
|
|
*/
|
|
RCT_EXPORT_METHOD(getCurrentAppState:(RCTResponseSenderBlock)callback
|
|
error:(__unused RCTResponseSenderBlock)error)
|
|
{
|
|
callback(@[@{@"app_state": _lastKnownState}]);
|
|
}
|
|
|
|
@end
|