| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  | import React, { Component } from 'react'; | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  | import { StyleSheet, View, Image, StatusBar, Alert, ScrollView, TouchableOpacity, ActivityIndicator, Platform, ProgressBarAndroid, Text } from 'react-native'; | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  | import Icon from 'react-native-vector-icons/MaterialCommunityIcons'; | 
					
						
							|  |  |  | const route = require('./../../route.json'); | 
					
						
							|  |  |  | let slugify = require('slugify'); | 
					
						
							|  |  |  | import I18n from 'react-native-i18n' | 
					
						
							|  |  |  | import * as Utils from '../../utils/DeviceUtils'; | 
					
						
							|  |  |  | import { Images } from '../../config/Images'; | 
					
						
							|  |  |  | import { Color } from '../../config/Color'; | 
					
						
							|  |  |  | import { baseUrl } from '../../webservice/IlinkConstants'; | 
					
						
							|  |  |  | import { IlinkEmitter } from "../../utils/events"; | 
					
						
							|  |  |  | import { Provider, Appbar } from 'react-native-paper'; | 
					
						
							| 
									
										
										
										
											2020-05-03 09:16:24 +00:00
										 |  |  | import { getWalletActivated } from '../../webservice/WalletApi'; | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  | import { connect } from 'react-redux'; | 
					
						
							|  |  |  | import { readUser } from '../../webservice/AuthApi'; | 
					
						
							|  |  |  | import { bindActionCreators } from 'redux'; | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  | import { FontWeight, Typography } from '../../config/typography'; | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  | class WalletSelect extends Component { | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |      constructor(props) { | 
					
						
							|  |  |  |           super(props); | 
					
						
							|  |  |  |           slugify.extend({ '+': 'plus' }); | 
					
						
							|  |  |  |           IlinkEmitter.on("langueChange", this.updateLangue.bind(this)); | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |           this.state = { | 
					
						
							|  |  |  |                result: null, | 
					
						
							| 
									
										
										
										
											2020-04-28 09:22:36 +00:00
										 |  |  |                isDataLoaded: false, | 
					
						
							|  |  |  |                agentId: null | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-05-03 09:16:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      static navigationOptions = ({ navigation }) => ({ | 
					
						
							|  |  |  |           header: null, | 
					
						
							|  |  |  |           headerMode: 'none', | 
					
						
							|  |  |  |           headerTitle: null, | 
					
						
							|  |  |  |           activeColor: '#f0edf6', | 
					
						
							|  |  |  |           inactiveColor: '#3e2465', | 
					
						
							|  |  |  |           barStyle: { backgroundColor: '#694fad' }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           drawerLabel: I18n.t('CREDIT_MANAGE'), | 
					
						
							|  |  |  |           drawerIcon: ({ tintColor }) => ( | 
					
						
							|  |  |  |                <Icon | 
					
						
							|  |  |  |                     name={'credit-card'} | 
					
						
							|  |  |  |                     size={24} | 
					
						
							|  |  |  |                />) | 
					
						
							|  |  |  |      }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |      componentDidMount() { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           readUser().then((user) => { | 
					
						
							|  |  |  |                if (user) { | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                     if (user !== undefined) { | 
					
						
							| 
									
										
										
										
											2020-04-28 09:22:36 +00:00
										 |  |  |                          if (user.phone !== undefined) { | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                               this.props.getWalletActivated(user.agentId); | 
					
						
							| 
									
										
										
										
											2020-04-28 09:22:36 +00:00
										 |  |  |                               this.setState({ agentId: user.agentId }); | 
					
						
							|  |  |  |                          } | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |                } | 
					
						
							|  |  |  |           }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-06 11:04:26 +00:00
										 |  |  |      /*      refresh() { | 
					
						
							|  |  |  |                readUser().then((user) => { | 
					
						
							|  |  |  |                     if (user) { | 
					
						
							|  |  |  |                          if (user !== undefined) { | 
					
						
							|  |  |  |                               if (user.phone !== undefined) { | 
					
						
							|  |  |  |                                    this.props.getWalletActivated(user.agentId); | 
					
						
							|  |  |  |                                    this.setState({ agentId: user.agentId }); | 
					
						
							|  |  |  |                               } | 
					
						
							| 
									
										
										
										
											2020-05-03 09:16:24 +00:00
										 |  |  |                          } | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2020-05-06 11:04:26 +00:00
										 |  |  |                }); | 
					
						
							|  |  |  |           } */ | 
					
						
							| 
									
										
										
										
											2020-05-03 09:16:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  |      updateLangue() { | 
					
						
							|  |  |  |           this.props.navigation.setParams({ name: I18n.t('WALLET') }) | 
					
						
							|  |  |  |           this.forceUpdate() | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |      renderLoader = () => { | 
					
						
							|  |  |  |           return ( | 
					
						
							|  |  |  |                <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}> | 
					
						
							|  |  |  |                     {Platform.OS === 'android' | 
					
						
							|  |  |  |                          ? | 
					
						
							|  |  |  |                          ( | 
					
						
							|  |  |  |                               <> | 
					
						
							|  |  |  |                                    <ProgressBarAndroid /> | 
					
						
							|  |  |  |                                    <Text>{I18n.t('LOADING_DOTS')}</Text> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               </> | 
					
						
							|  |  |  |                          ) : | 
					
						
							|  |  |  |                          <> | 
					
						
							|  |  |  |                               <ActivityIndicator size="large" color={'#ccc'} /> | 
					
						
							|  |  |  |                               <Text>{I18n.t('LOADING_DOTS')}</Text> | 
					
						
							|  |  |  |                          </> | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                </View> | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      renderWalletItem = (item) => { | 
					
						
							|  |  |  |           let icon = `${baseUrl}/datas/img/network/${slugify(item.network, { lower: true })}-logo.png`; | 
					
						
							| 
									
										
										
										
											2020-04-28 09:22:36 +00:00
										 |  |  |           let itemToSend = item; | 
					
						
							|  |  |  |           itemToSend.agentId = this.state.agentId; | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |           return ( | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |                <TouchableOpacity | 
					
						
							|  |  |  |                     key={item.id} | 
					
						
							|  |  |  |                     style={[styles.paymentItem, { borderBottomColor: Color.borderColor }]} | 
					
						
							| 
									
										
										
										
											2020-05-03 09:16:24 +00:00
										 |  |  |                     onPress={() => this.props.navigation.navigate('walletDetail', { | 
					
						
							| 
									
										
										
										
											2020-05-06 11:04:26 +00:00
										 |  |  |                          wallet: itemToSend,/*  | 
					
						
							|  |  |  |                          onRefreshDetail: () => this.refresh() */ | 
					
						
							| 
									
										
										
										
											2020-05-03 09:16:24 +00:00
										 |  |  |                     })}> | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |                     <View style={{ flexDirection: 'row', alignItems: 'center' }}> | 
					
						
							|  |  |  |                          <View style={styles.iconContent}> | 
					
						
							|  |  |  |                               <Image style={{ width: 48, height: 48 }} source={{ uri: icon }} /> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                          <View> | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                               <Text style={Typography.body1}>{item.network}</Text> | 
					
						
							|  |  |  |                               <Text style={[Typography.footnote, Color.grayColor]} style={{ marginTop: 5 }}> | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |                                    {I18n.t('COUNTRY')}: {item.country} | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                               </Text> | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |                          </View> | 
					
						
							|  |  |  |                     </View> | 
					
						
							|  |  |  |                </TouchableOpacity> | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      renderWalletList = () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           const { result, error } = this.props; | 
					
						
							|  |  |  |           if (error !== null) { | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  |                if (typeof error.data !== 'undefined') { | 
					
						
							|  |  |  |                     return ( | 
					
						
							|  |  |  |                          <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}> | 
					
						
							|  |  |  |                               <Text style={Typography.body1}>{error.data.error}</Text> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |                else { | 
					
						
							|  |  |  |                     return ( | 
					
						
							|  |  |  |                          <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}> | 
					
						
							|  |  |  |                               <Text style={Typography.body1}>{error}</Text> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |           if (result !== null) { | 
					
						
							|  |  |  |                if (result.response !== null) { | 
					
						
							|  |  |  |                     return ( | 
					
						
							|  |  |  |                          Array.isArray(result.response) && (result.response.length) > 0 ? | 
					
						
							|  |  |  |                               (<ScrollView style={{ flex: 1, padding: 20 }}> | 
					
						
							|  |  |  |                                    { | 
					
						
							| 
									
										
										
										
											2020-05-03 09:16:24 +00:00
										 |  |  |                                         result.response.map((item) => ( | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                                              this.renderWalletItem(item) | 
					
						
							|  |  |  |                                         )) | 
					
						
							|  |  |  |                                    } | 
					
						
							|  |  |  |                               </ScrollView>) : | 
					
						
							|  |  |  |                               ( | 
					
						
							|  |  |  |                                    <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}> | 
					
						
							|  |  |  |                                         <Text style={Typography.body1}>{I18n.t('NO_WALLET_ACTIVED')}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |                               ) | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  |      render() { | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  |           console.log("WALLET PROPS", this.props); | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  |           return ( | 
					
						
							|  |  |  |                <Provider> | 
					
						
							|  |  |  |                     <View style={{ flex: 1 }}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <StatusBar | 
					
						
							|  |  |  |                               backgroundColor={Color.primaryDarkColor} | 
					
						
							|  |  |  |                               barStyle="light-content" | 
					
						
							|  |  |  |                               translucent={false} | 
					
						
							|  |  |  |                          /> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <Appbar.Header dark={true} style={{ backgroundColor: Color.primaryColor }}> | 
					
						
							|  |  |  |                               <Appbar.BackAction | 
					
						
							|  |  |  |                                    onPress={() => { this.props.navigation.pop() }} | 
					
						
							|  |  |  |                               /> | 
					
						
							|  |  |  |                               <Appbar.Content | 
					
						
							|  |  |  |                                    title={I18n.t('WALLET')} | 
					
						
							|  |  |  |                                    subtitle={I18n.t('SELECT_YOUR_WALLET')} | 
					
						
							|  |  |  |                               /> | 
					
						
							|  |  |  |                          </Appbar.Header> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  |                          { | 
					
						
							|  |  |  |                               this.props.loading ? | 
					
						
							|  |  |  |                                    this.renderLoader() : | 
					
						
							|  |  |  |                                    this.renderWalletList() | 
					
						
							|  |  |  |                          } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  |                     </View> | 
					
						
							|  |  |  |                </Provider> | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | const mapStateToProps = state => ({ | 
					
						
							| 
									
										
										
										
											2020-04-18 23:19:11 +00:00
										 |  |  |      loading: state.walletReducer.loading, | 
					
						
							|  |  |  |      result: state.walletReducer.result, | 
					
						
							|  |  |  |      error: state.walletReducer.error | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const mapDispatchToProps = dispatch => bindActionCreators({ | 
					
						
							|  |  |  |      getWalletActivated | 
					
						
							|  |  |  | }, dispatch); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 19:59:05 +00:00
										 |  |  | export default connect(mapStateToProps, mapDispatchToProps)(WalletSelect); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  | const styles = StyleSheet.create({ | 
					
						
							|  |  |  |      container: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           backgroundColor: Color.containerBackgroundColor, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      paymentItem: { | 
					
						
							|  |  |  |           flexDirection: "row", | 
					
						
							|  |  |  |           alignItems: "center", | 
					
						
							|  |  |  |           justifyContent: "space-between", | 
					
						
							|  |  |  |           borderBottomWidth: 1, | 
					
						
							|  |  |  |           paddingVertical: 5, | 
					
						
							|  |  |  |           width: "100%", | 
					
						
							|  |  |  |           marginBottom: 15 | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      iconContent: { | 
					
						
							|  |  |  |           width: 60, | 
					
						
							|  |  |  |           marginRight: 10, | 
					
						
							|  |  |  |           alignItems: "center" | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | }); |