import React, { Component } from 'react';
import { connect } from 'react-redux';
import { bindActionCreators } from 'redux';
import firebase from 'firebase';
import { Text, View, ImageBackground } from 'react-native';
import MaterialIcons from 'react-native-vector-icons/MaterialIcons';
import { fetchUser } from '../redux/actions/index'
import Loading from '../components/Loading'
import { styles } from '../config/styles'
export class HomeScreen extends Component {
constructor(props){
super(props);
this.state = {
interpreter: false,
};
this.onLogout = this.onLogout.bind(this)
};
componentDidMount(){
this.props.fetchUser();
firebase.firestore()
.collection("Interpreters")
.doc(firebase.auth().currentUser.uid)
.get()
.then((snapshot) => {
if(snapshot.exists){
this.setState({interpreter: true})
}
})
}
onLogout(){
firebase.auth().signOut();
}
render() {
const { currentUser } = this.props;
if(currentUser == undefined){
return
}
if(this.state.interpreter){
return(
this.onLogout()}/>
this.props.navigation.navigate('Availability')}/>
this.props.navigation.navigate('Mail')}/>
);
}
else{
return(
You are a user
);
}
}
}
const mapStateProps = (store) => ({currentUser: store.userState.currentUser})
const mapDispatchProps = (dispatch) => bindActionCreators({fetchUser}, dispatch)
export default connect(mapStateProps, mapDispatchProps)(HomeScreen)
/*export default function HomeScreen({navigation}) {
const [threads, setThreads] = useState([]);
const [loading, setLoading] = useState(true);
useEffect(() => {
const fire = firebase.firestore()
.collection('THREADS')
.onSnapshot(querySnapshot => {
const threads = querySnapshot.docs.map(documentSnapshot => {
return{
_id:documentSnapshot.id,
name:'',
...documentSnapshot.data()
};
});
setThreads(threads);
if(loading){
setLoading(false);
}
});
return () => fire();
}, []);
if (loading) {
return ;
}
return (
item._id}
ItemSeparatorComponent={() => }
renderItem = {({item}) => (
navigation.navigate('Room', {thread: item})}
>
)}
/>
);
}
*/