Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/kayla-tech/react-native-privacy-snapshot

Obscure passwords and other sensitive personal information when a react-native app transitions to the background
https://github.com/kayla-tech/react-native-privacy-snapshot

Last synced: 6 days ago
JSON representation

Obscure passwords and other sensitive personal information when a react-native app transitions to the background

Awesome Lists containing this project

README

        

# Enable privacy snapshot for React Native

In the [App Programming Guide for iOS](https://developer.apple.com/library/ios/documentation/iPhone/Conceptual/iPhoneOSProgrammingGuide/BackgroundExecution/BackgroundExecution.html#//apple_ref/doc/uid/TP40007072-CH4-SW8), Apple says:

> When an app transitions to the background, the system takes a snapshot of the app’s main window, which it then presents briefly when transitioning your app back to the foreground. Before returning from your `applicationDidEnterBackground:` method, you should hide or obscure passwords and other sensitive personal information that might be captured as part of the snapshot.

This react-native module obscure passwords and other sensitive personal information when an app transitions to the background.

### `PrivacySnapshot.enabled(false)`

![Screenshot of the multi-tasking screen](screenshot1.png)

### `PrivacySnapshot.enabled(true)`

![Screenshot of the multi-tasking screen with privacy screenshot](screenshot2.png)

## Installation iOS

1. Run `npm install react-native-privacy-snapshot --save` in your project directory
1. Open your project in XCode, right click on `Libraries` and click `Add Files to "Your Project Name"`
1. Within `node_modules`, find `react-native-privacy-snapshot` and add RCTPrivacySnapshot.xcodeproj to your project.
1. Add `libRTCPrivacySnapshot.a` to `Build Phases -> Link Binary With Libraries`

## Usage

``` javascript
let PrivacySnapshot = require('react-native-privacy-snapshot');

...

componentWillMount() {
PrivacySnapshot.enabled(true);
},

componentWillUnmount() {
PrivacySnapshot.enabled(false);
},

```