/** * Sample React Native App * https://github.com/facebook/react-native */ 'use strict'; var React = require('react-native'); var { AppRegistry, StyleSheet, Text, TextInput, View, TouchableHighlight, } = React; var Keychain = require('Keychain'); var KeychainExample = React.createClass({ getInitialState: function() { return { server: 'http://localhost/', username: '', password: '', status: '', }; }, _save: function() { Keychain .setInternetCredentials(this.state.server, this.state.username, this.state.password) .then(function() { this.setState({status: 'Credentials saved!'}); }.bind(this)) .catch(function(err) { this.setState({status: 'Could not save credentials, ' + err}); }.bind(this)); }, _load: function() { Keychain .getInternetCredentials(this.state.server) .then(function(credentials) { this.setState(credentials); this.setState({status: 'Credentials loaded!'}); }.bind(this)) .catch(function(err) { this.setState({status: 'Could not load credentials. ' + err}); }.bind(this)); }, _reset: function() { Keychain .resetInternetCredentials(this.state.server) .then(function() { this.setState({status: 'Credentials Reset!', username: '', password: '' }); }.bind(this)) .catch(function(err) { this.setState({status: 'Could not save credentials, ' + err}); }.bind(this)); }, render: function() { return ( React Native Keychain Example Server this.setState({ server: event.nativeEvent.text })} /> Username this.setState({ username: event.nativeEvent.text })} /> Password this.setState({ password: event.nativeEvent.text })} /> {this.state.status} Save Load Reset ); } }); var styles = StyleSheet.create({ container: { flex: 1, justifyContent: 'center', alignItems: 'center', backgroundColor: '#F5FCFF', }, welcome: { fontSize: 20, textAlign: 'center', margin: 10, }, field: { marginVertical: 5, }, label: { fontWeight: '500', }, input: { borderWidth: 1, borderColor: '#ccc', height: 30, fontSize: 14, padding: 4, width: 250, }, status: { width: 250, }, buttons: { flexDirection: 'row', marginTop: 15, }, button: { marginHorizontal: 5, paddingHorizontal: 8, borderRadius: 4, backgroundColor: '#333', overflow: 'hidden', }, save: { backgroundColor: '#0c0', }, reset: { backgroundColor: '#c00', }, buttonText: { color: 'white', padding: 5, } }); AppRegistry.registerComponent('KeychainExample', () => KeychainExample);