346 lines
9.3 KiB
JavaScript
Executable File
346 lines
9.3 KiB
JavaScript
Executable File
import React, {Component} from 'react';
|
|
import {
|
|
Platform,
|
|
StyleSheet,
|
|
Text,
|
|
View,
|
|
StatusBar,
|
|
Dimensions,
|
|
Image,
|
|
ActivityIndicator,
|
|
Button,
|
|
TouchableHighlight,
|
|
Keyboard
|
|
|
|
} from 'react-native';
|
|
|
|
import {bindActionCreators} from 'redux';
|
|
import {connect} from 'react-redux';
|
|
|
|
import QRCodeScanner from 'react-native-qrcode-scanner';
|
|
import {UtilStyles} from './assets/styles'
|
|
|
|
import * as Actions from './store/actions'; //Import your actions
|
|
|
|
import {RkButton, RkTheme, RkText, RkTextInput} from 'react-native-ui-kitten';
|
|
|
|
import Modal from "react-native-modal";
|
|
|
|
import Router from './Router'
|
|
|
|
import Icon from "react-native-vector-icons/Ionicons"
|
|
|
|
const SCREEN_HEIGHT = Dimensions.get("window").height;
|
|
const SCREEN_WIDTH = Dimensions.get("window").width;
|
|
|
|
|
|
class App extends Component {
|
|
|
|
_activate=()=>{
|
|
|
|
this.setState({ isModalVisible: !this.state.isModalVisible});
|
|
this.scanner.reactivate();
|
|
|
|
}
|
|
_tryLogin=()=>{
|
|
|
|
console.log(this.state.text)
|
|
this.scanner.reactivate();
|
|
this.props.login(this.state.username, this.state.text);
|
|
|
|
|
|
|
|
}
|
|
|
|
_toggleModal = () =>
|
|
this.setState({ isModalVisible: !this.state.isModalVisible });
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
this.state = {
|
|
|
|
token: {valid: false},
|
|
tokenData: '',
|
|
onHold: true,
|
|
logged: false,
|
|
isModalVisible: false,
|
|
state : {text: ''},
|
|
username:'',
|
|
failedAttempt: false,
|
|
push:4
|
|
|
|
};
|
|
|
|
}
|
|
_print=()=>{
|
|
console.log("hello")
|
|
this.setState({push:0})
|
|
}
|
|
checkValue=(e)=>{
|
|
console.log("check"+e)
|
|
}
|
|
componentDidMount() {
|
|
this.setState({isModalVisible: false})
|
|
//verifica se o utilizador tem token guardado
|
|
this.props.checkUser();
|
|
this.keyboardDidShowListener = Keyboard.addListener('keyboardDidShow', this._keyboardDidShow);
|
|
this.keyboardDidHideListener = Keyboard.addListener('keyboardDidHide', this._keyboardDidHide);
|
|
|
|
|
|
}
|
|
_keyboardDidShow () {
|
|
//alert('Keyboard Shown');
|
|
// this.setState({push:0})
|
|
|
|
}
|
|
|
|
_keyboardDidHide () {
|
|
|
|
//this.setState({push:4})
|
|
|
|
}
|
|
onSuccess = (e) => {
|
|
|
|
this.setState({ isModalVisible: !this.state.isModalVisible });
|
|
// this.props.login(e.data, 'f8908cc0');
|
|
this.setState({username:e.data})
|
|
|
|
console.log("tentativa de login");
|
|
|
|
|
|
};
|
|
|
|
render() {
|
|
|
|
if (this.props.onHold && !this.props.logged) {
|
|
|
|
|
|
return (
|
|
<View style={UtilStyles.containerLoading}>
|
|
<Text>CARREGANDO {this.props.onHold}</Text>
|
|
<ActivityIndicator size="large" color="#0000ff"/>
|
|
</View>
|
|
)
|
|
|
|
}
|
|
{
|
|
|
|
//console.log('token... '+ this.props.logged)
|
|
|
|
//se existir token
|
|
|
|
if (this.props.logged) {
|
|
|
|
return (
|
|
|
|
<Router></Router>
|
|
)
|
|
}
|
|
else {
|
|
|
|
|
|
//se não existir vai para o ecrã de scan QR
|
|
return (
|
|
|
|
<QRCodeScanner
|
|
ref={(node) => { this.scanner = node }}
|
|
showMarker
|
|
|
|
onRead={this.onSuccess.bind(this)}
|
|
cameraStyle={{height: SCREEN_HEIGHT}}
|
|
|
|
customMarker={
|
|
|
|
|
|
<View style={styles.rectangleContainer}>
|
|
|
|
<Modal
|
|
isVisible={this.state.isModalVisible}
|
|
style={
|
|
{
|
|
backgroundColor:'#E8E8E8',
|
|
borderRadius:10,
|
|
marginTop:SCREEN_HEIGHT /this.state.push,
|
|
height:SCREEN_HEIGHT/2
|
|
|
|
}
|
|
}
|
|
animationInTiming={1000}
|
|
animationOutTiming={1000}
|
|
>
|
|
<View style={{ flex: 1}}>
|
|
|
|
<Text></Text>
|
|
<Text> Introduza a password</Text>
|
|
|
|
<RkTextInput
|
|
onFocus={this._print}
|
|
maxLength={10}
|
|
blurOnSubmit ={true}
|
|
secureTextEntry={true}
|
|
rkType='rounded'
|
|
onChangeText={(text) => this.setState({text})}
|
|
clearButtonMode='always'
|
|
value={this.state.text}
|
|
clearTextOnFocus={true}
|
|
onSubmitEditing={Keyboard.dismiss}
|
|
/>
|
|
|
|
<Button onPress={this._tryLogin} title="Login" color="#841584" />
|
|
|
|
{ this.props.failedAttempt &&
|
|
<Text> Password ou QR incorrecto</Text>
|
|
}
|
|
|
|
|
|
<Text></Text>
|
|
<Button onPress={this._activate} title="Scan again!" color="green" accessibilityLabel="Learn more about this purple button"/>
|
|
|
|
|
|
|
|
|
|
</View>
|
|
|
|
</Modal>
|
|
<View style={styles.logo}>
|
|
<Image style={UtilStyles.loginImage}
|
|
source={require('./assets/img/logo.png')}
|
|
/>
|
|
</View>
|
|
|
|
|
|
<View style={{flexDirection: "row"}}>
|
|
<View style={styles.leftAndRightOverlay}>
|
|
</View>
|
|
|
|
<View style={styles.rectangle}>
|
|
|
|
</View>
|
|
|
|
|
|
<View style={styles.leftAndRightOverlay}>
|
|
</View>
|
|
</View>
|
|
|
|
<View style={styles.bottomOverlay}>
|
|
|
|
<View style={{flex: 1, alignItems: 'center', alignContent: 'center'}}>
|
|
<RkText rkType='primary' style={styles.recover}>Recuperar pin de acesso</RkText>
|
|
<RkButton rkType='dark' style={styles.manual}>lols</RkButton>
|
|
</View>
|
|
|
|
</View>
|
|
</View>
|
|
}
|
|
/>
|
|
|
|
)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
RkTheme.setType('RkButton', 'dark', {
|
|
container: {
|
|
paddingTop: 10,
|
|
backgroundColor: 'gray',
|
|
|
|
borderRadius: 90,
|
|
}
|
|
});
|
|
|
|
|
|
const rectDimensions = SCREEN_WIDTH * 0.85; // this is equivalent to 255 from a 393 device width
|
|
|
|
const overlayColor = 'rgba(0,0,0,0.30)';
|
|
|
|
const styles = {
|
|
|
|
recover: {
|
|
paddingTop: 10,
|
|
color: "red",
|
|
paddingBottom: 10
|
|
},
|
|
manual: {},
|
|
|
|
logo: {
|
|
|
|
height: SCREEN_HEIGHT * 0.35,
|
|
width: SCREEN_WIDTH,
|
|
backgroundColor: overlayColor,
|
|
},
|
|
rectangleContainer: {
|
|
|
|
flex: 1,
|
|
alignItems: "center",
|
|
justifyContent: "center",
|
|
backgroundColor: "transparent",
|
|
|
|
},
|
|
|
|
rectangle: {
|
|
|
|
height: rectDimensions,
|
|
width: rectDimensions,
|
|
alignItems: "center",
|
|
justifyContent: "center",
|
|
backgroundColor: "transparent"
|
|
},
|
|
|
|
topOverlay: {
|
|
flex: 1,
|
|
backgroundColor: overlayColor,
|
|
justifyContent: "center",
|
|
alignItems: "center"
|
|
},
|
|
|
|
bottomOverlay: {
|
|
flex: 1,
|
|
height: SCREEN_HEIGHT,
|
|
width: SCREEN_WIDTH,
|
|
backgroundColor: overlayColor,
|
|
paddingBottom: SCREEN_WIDTH * 0.2
|
|
},
|
|
|
|
leftAndRightOverlay: {
|
|
height: rectDimensions,
|
|
width: SCREEN_WIDTH,
|
|
backgroundColor: overlayColor
|
|
},
|
|
};
|
|
RkTheme.setType('RkTextInput', 'frame', {
|
|
input: {
|
|
backgroundColor: 'white',
|
|
marginLeft: 0,
|
|
marginHorizontal: 0,
|
|
borderRadius: 5
|
|
},
|
|
color: 'gray',
|
|
backgroundColor: 'gray',
|
|
borderRadius: 10,
|
|
container: {
|
|
paddingHorizontal: 20
|
|
}
|
|
});
|
|
|
|
mapStateToProps = (state, props) => {
|
|
|
|
return {
|
|
token: state.apiReducer.token,
|
|
loggedIn: state.apiReducer.loggedIn,
|
|
onHold: state.apiReducer.onHold,
|
|
logged: state.apiReducer.logged,
|
|
failedAttempt:state.apiReducer.failedAttempt,
|
|
}
|
|
};
|
|
|
|
mapDispatchToProps = (dispatch) => {
|
|
|
|
return bindActionCreators(Actions, dispatch);
|
|
};
|
|
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(App); |