2015-05-20 18:41:10 +00:00
|
|
|
/**
|
|
|
|
* 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;
|
|
|
|
|
2015-07-19 11:36:40 +00:00
|
|
|
var Keychain = require('react-native-keychain');
|
2015-05-20 18:41:10 +00:00
|
|
|
|
|
|
|
var KeychainExample = React.createClass({
|
|
|
|
getInitialState: function() {
|
|
|
|
return {
|
|
|
|
username: '',
|
|
|
|
password: '',
|
|
|
|
status: '',
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
_save: function() {
|
|
|
|
Keychain
|
2015-05-29 16:27:07 +00:00
|
|
|
.setGenericPassword(this.state.username, this.state.password)
|
|
|
|
.then(() => {
|
2015-05-20 18:41:10 +00:00
|
|
|
this.setState({status: 'Credentials saved!'});
|
2015-05-29 16:27:07 +00:00
|
|
|
})
|
|
|
|
.catch((err) => {
|
2015-05-20 18:41:10 +00:00
|
|
|
this.setState({status: 'Could not save credentials, ' + err});
|
2015-05-29 16:27:07 +00:00
|
|
|
});
|
2015-05-20 18:41:10 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
_load: function() {
|
|
|
|
Keychain
|
2015-05-29 16:27:07 +00:00
|
|
|
.getGenericPassword()
|
|
|
|
.then((credentials) => {
|
2015-05-20 18:41:10 +00:00
|
|
|
this.setState(credentials);
|
|
|
|
this.setState({status: 'Credentials loaded!'});
|
2015-05-29 16:27:07 +00:00
|
|
|
})
|
|
|
|
.catch((err) => {
|
2015-05-20 18:41:10 +00:00
|
|
|
this.setState({status: 'Could not load credentials. ' + err});
|
2015-05-29 16:27:07 +00:00
|
|
|
});
|
2015-05-20 18:41:10 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
_reset: function() {
|
|
|
|
Keychain
|
2015-05-29 16:27:07 +00:00
|
|
|
.resetGenericPassword()
|
|
|
|
.then(() => {
|
2015-05-20 18:41:10 +00:00
|
|
|
this.setState({status: 'Credentials Reset!', username: '', password: '' });
|
2015-05-29 16:27:07 +00:00
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
this.setState({status: 'Could not reset credentials, ' + err});
|
|
|
|
});
|
2015-05-20 18:41:10 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
render: function() {
|
|
|
|
return (
|
|
|
|
<View style={styles.container}>
|
|
|
|
<Text style={styles.welcome}>
|
|
|
|
React Native Keychain Example
|
|
|
|
</Text>
|
|
|
|
<View style={styles.field}>
|
|
|
|
<Text style={styles.label}>Username</Text>
|
2015-07-19 11:36:40 +00:00
|
|
|
<TextInput
|
|
|
|
style={styles.input}
|
|
|
|
autoFocus={true}
|
|
|
|
autoCapitalize="none"
|
2015-05-20 18:41:10 +00:00
|
|
|
value={this.state.username}
|
|
|
|
onChange={(event) => this.setState({ username: event.nativeEvent.text })}
|
|
|
|
/>
|
|
|
|
</View>
|
|
|
|
<View style={styles.field}>
|
|
|
|
<Text style={styles.label}>Password</Text>
|
2015-07-19 11:36:40 +00:00
|
|
|
<TextInput
|
|
|
|
style={styles.input}
|
|
|
|
password={true}
|
|
|
|
autoCapitalize="none"
|
2015-05-20 18:41:10 +00:00
|
|
|
value={this.state.password}
|
|
|
|
onChange={(event) => this.setState({ password: event.nativeEvent.text })}
|
|
|
|
/>
|
|
|
|
</View>
|
|
|
|
<Text style={styles.status}>{this.state.status}</Text>
|
|
|
|
<View style={styles.buttons}>
|
|
|
|
<TouchableHighlight onPress={this._save} style={[styles.button, styles.save]}>
|
|
|
|
<View>
|
|
|
|
<Text style={styles.buttonText}>Save</Text>
|
|
|
|
</View>
|
|
|
|
</TouchableHighlight>
|
|
|
|
<TouchableHighlight onPress={this._load} style={styles.button}>
|
|
|
|
<View>
|
|
|
|
<Text style={styles.buttonText}>Load</Text>
|
|
|
|
</View>
|
|
|
|
</TouchableHighlight>
|
|
|
|
<TouchableHighlight onPress={this._reset} style={[styles.button, styles.reset]}>
|
|
|
|
<View>
|
|
|
|
<Text style={styles.buttonText}>Reset</Text>
|
|
|
|
</View>
|
|
|
|
</TouchableHighlight>
|
|
|
|
</View>
|
|
|
|
</View>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
var styles = StyleSheet.create({
|
|
|
|
container: {
|
|
|
|
flex: 1,
|
|
|
|
alignItems: 'center',
|
|
|
|
backgroundColor: '#F5FCFF',
|
2015-05-29 16:27:07 +00:00
|
|
|
paddingTop: 30,
|
2015-05-20 18:41:10 +00:00
|
|
|
},
|
|
|
|
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);
|