| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | import Button from 'apsl-react-native-button'; | 
					
						
							|  |  |  | import isEqual from 'lodash/isEqual'; | 
					
						
							|  |  |  | import isNil from 'lodash/isNil'; | 
					
						
							|  |  |  | import React, { Component } from 'react'; | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | import { Alert, ScrollView, StyleSheet, Text, View } from 'react-native'; | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | import * as Animatable from 'react-native-animatable'; | 
					
						
							|  |  |  | import I18n from 'react-native-i18n'; | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | import Dialog from "react-native-dialog"; | 
					
						
							| 
									
										
										
										
											2023-03-12 23:38:33 +00:00
										 |  |  | import { Dropdown } from 'react-native-material-dropdown-v2'; | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | import { responsiveHeight, responsiveWidth } from 'react-native-responsive-dimensions'; | 
					
						
							|  |  |  | import { ProgressDialog } from 'react-native-simple-dialogs'; | 
					
						
							|  |  |  | import { Fumi } from 'react-native-textinput-effects'; | 
					
						
							|  |  |  | import FontAwesomeIcon from 'react-native-vector-icons/FontAwesome'; | 
					
						
							|  |  |  | import { connect } from 'react-redux'; | 
					
						
							|  |  |  | import { bindActionCreators } from 'redux'; | 
					
						
							|  |  |  | import { Color } from '../../../config/Color'; | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | import { store } from "../../../redux/store"; | 
					
						
							|  |  |  | import { identityPieces, isIlinkWorldWallet, isNormalInteger, typeIdIDestinataire, thousandsSeparators } from '../../../utils/UtilsFunction'; | 
					
						
							|  |  |  | import { readUser } from '../../../webservice/AuthApi'; | 
					
						
							| 
									
										
										
										
											2020-07-08 19:01:56 +00:00
										 |  |  | import { envoieUserWalletToCashAction, envoieUserWalletToCashReset, getCommissionUserWalletToCashAction, getCommissionUserWalletToCashReset } from '../../../webservice/EnvoieUserApi'; | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | import { getActiveCountryAction, getActiveCountryByDialCodeAction, getActiveCountryByDialCodeReset, getActiveCountryReset, getPayCountryNetworkAction, getPayCountryNetworkReset } from '../../../webservice/CountryApi'; | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | import { Typography, FontWeight } from '../../../config/typography'; | 
					
						
							|  |  |  | import thousands from 'thousands'; | 
					
						
							|  |  |  | import { IlinkEmitter } from '../../../utils/events'; | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | let theme = require('../../../utils/theme.json'); | 
					
						
							|  |  |  | let route = require('../../../route.json'); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | class EnvoieWalletToCashUser extends Component { | 
					
						
							|  |  |  |      static navigatorStyle = { | 
					
						
							|  |  |  |           navBarBackgroundColor: Color.primaryColor, | 
					
						
							|  |  |  |           statusBarColor: Color.primaryDarkColor, | 
					
						
							|  |  |  |           navBarTextColor: '#FFFFFF', | 
					
						
							|  |  |  |           navBarButtonColor: '#FFFFFF' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      static navigationOptions = () => { | 
					
						
							|  |  |  |           return { | 
					
						
							|  |  |  |                drawerLabel: () => null, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |                headerTitle: I18n.t('ENVOIE_ARGENT'), | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                headerTintColor: 'white', | 
					
						
							|  |  |  |                headerStyle: { | 
					
						
							|  |  |  |                     backgroundColor: Color.primaryColor, | 
					
						
							|  |  |  |                     marginTop: 0, | 
					
						
							|  |  |  |                     color: 'white' | 
					
						
							|  |  |  |                }, | 
					
						
							|  |  |  |                headerTitleStyle: { | 
					
						
							|  |  |  |                     color: "white" | 
					
						
							|  |  |  |                }, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |                title: I18n.t('ENVOIE_ARGENT') | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |           } | 
					
						
							|  |  |  |      }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      constructor(props) { | 
					
						
							|  |  |  |           super(props); | 
					
						
							|  |  |  |           this.state = { | 
					
						
							|  |  |  |                identityPieces: identityPieces(), | 
					
						
							| 
									
										
										
										
											2020-11-04 20:02:23 +00:00
										 |  |  |                identityPiecesName: I18n.t((identityPieces()[0]).name), | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                paysDestination: [], | 
					
						
							|  |  |  |                paysDestinationSelect: null, | 
					
						
							|  |  |  |                walletActifs: [], | 
					
						
							|  |  |  |                walletActifSelect: null, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                noms: null, | 
					
						
							|  |  |  |                prenoms: null, | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                numeroTelephone: null, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                numeroIdentite: null, | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                montant: null, | 
					
						
							|  |  |  |                password: null, | 
					
						
							|  |  |  |                loading: false, | 
					
						
							|  |  |  |                user: null, | 
					
						
							|  |  |  |                modalVisible: true, | 
					
						
							|  |  |  |                hasLoadActiveCountryList: true, | 
					
						
							|  |  |  |                hasLoadActivePayCountryNetworkList: true, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                triggerSubmitClick: false, | 
					
						
							|  |  |  |                isDataSubmit: false, | 
					
						
							|  |  |  |                isModalConfirmVisible: false, | 
					
						
							|  |  |  |                wallet: store.getState().walletDetailReducer.result.response | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |           }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           this.props.getActiveCountryReset(); | 
					
						
							|  |  |  |           this.props.getActiveCountryByDialCodeReset(); | 
					
						
							|  |  |  |           this.props.getPayCountryNetworkReset(); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           this.props.envoieUserWalletToCashReset(); | 
					
						
							|  |  |  |           this.props.getCommissionUserWalletToCashReset(); | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           this.props.getActiveCountryAction(); | 
					
						
							|  |  |  |           console.log("ENVOIE WALLET PROPS", this.props); | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      componentDidMount() { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           readUser().then((user) => { | 
					
						
							|  |  |  |                if (user) { | 
					
						
							|  |  |  |                     if (user !== undefined) { | 
					
						
							|  |  |  |                          this.setState({ user }); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |      } | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |      componentWillReceiveProps(nextProps) { | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           if (nextProps.resultEnvoieWalletToCashGetCommission != null) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                if (typeof nextProps.resultEnvoieWalletToCashGetCommission.response !== 'undefined') { | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                     if (!nextProps.loadingEnvoieWalletToCashGetCommission) | 
					
						
							|  |  |  |                          this.setState({ | 
					
						
							|  |  |  |                               isModalConfirmVisible: true | 
					
						
							|  |  |  |                          }); | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      renderGetActionCountryList = () => { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           const { resultActiveCountryList, errorActiveCountryList } = this.props; | 
					
						
							|  |  |  |           if (resultActiveCountryList !== null) { | 
					
						
							|  |  |  |                if (typeof resultActiveCountryList.response !== 'undefined') { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     this.setState({ | 
					
						
							|  |  |  |                          hasLoadActiveCountryList: false, | 
					
						
							|  |  |  |                          paysDestination: resultActiveCountryList.response, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                          paysDestinationSelect: resultActiveCountryList.response[0].name, | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                     }); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                     if (this.state.hasLoadActivePayCountryNetworkList) | 
					
						
							|  |  |  |                          this.props.getPayCountryNetworkAction({ id_wallet_user: this.state.wallet.id, id_country: resultActiveCountryList.response[0].id }); | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (errorActiveCountryList !== null) { | 
					
						
							|  |  |  |                if (typeof errorActiveCountryList.data !== 'undefined') { | 
					
						
							|  |  |  |                     Alert.alert( | 
					
						
							|  |  |  |                          I18n.t('ERROR_LABEL'), | 
					
						
							|  |  |  |                          errorActiveCountryList.data.error, | 
					
						
							|  |  |  |                          [ | 
					
						
							|  |  |  |                               { | 
					
						
							|  |  |  |                                    text: I18n.t("OK"), onPress: () => { | 
					
						
							|  |  |  |                                         this.props.getActiveCountryReset(); | 
					
						
							|  |  |  |                                    } | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          ], | 
					
						
							|  |  |  |                          { cancelable: false } | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } else { | 
					
						
							|  |  |  |                     Alert.alert( | 
					
						
							|  |  |  |                          I18n.t('ERROR_LABEL'), | 
					
						
							|  |  |  |                          JSON.stringify(errorActiveCountryList), | 
					
						
							|  |  |  |                          [ | 
					
						
							|  |  |  |                               { | 
					
						
							|  |  |  |                                    text: I18n.t("OK"), onPress: () => { | 
					
						
							|  |  |  |                                         this.props.getActiveCountryReset(); | 
					
						
							|  |  |  |                                    } | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          ], | 
					
						
							|  |  |  |                          { cancelable: false } | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      renderGetPayCountryNetworkResponse = () => { | 
					
						
							|  |  |  |           const { resultPayCountryNetwork, errorPayCountryNetwork } = this.props; | 
					
						
							|  |  |  |           if (resultPayCountryNetwork !== null) { | 
					
						
							|  |  |  |                if (typeof resultPayCountryNetwork.response !== 'undefined') { | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                     if (resultPayCountryNetwork.response.length > 0) { | 
					
						
							|  |  |  |                          this.setState({ | 
					
						
							|  |  |  |                               hasLoadActivePayCountryNetworkList: false, | 
					
						
							|  |  |  |                               walletActifs: resultPayCountryNetwork.response, | 
					
						
							|  |  |  |                               walletActifSelect: resultPayCountryNetwork.response[0].name, | 
					
						
							|  |  |  |                               modalVisible: false | 
					
						
							|  |  |  |                          }); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     else if (resultPayCountryNetwork.response.length === 0) { | 
					
						
							|  |  |  |                          this.setState({ | 
					
						
							|  |  |  |                               walletActifs: [], | 
					
						
							|  |  |  |                               walletActifSelect: '', | 
					
						
							|  |  |  |                               modalVisible: false, | 
					
						
							|  |  |  |                               hasLoadActivePayCountryNetworkList: false, | 
					
						
							|  |  |  |                          }); | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (errorPayCountryNetwork !== null) { | 
					
						
							|  |  |  |                if (typeof errorPayCountryNetwork.data !== 'undefined') { | 
					
						
							|  |  |  |                     Alert.alert( | 
					
						
							|  |  |  |                          I18n.t('ERROR_LABEL'), | 
					
						
							|  |  |  |                          errorPayCountryNetwork.data.error, | 
					
						
							|  |  |  |                          [ | 
					
						
							|  |  |  |                               { | 
					
						
							|  |  |  |                                    text: I18n.t("OK"), onPress: () => { | 
					
						
							| 
									
										
										
										
											2020-10-25 16:39:19 +00:00
										 |  |  |                                         this.setState({ | 
					
						
							|  |  |  |                                              isDataSubmit: false, | 
					
						
							|  |  |  |                                              isModalConfirmVisible: false, | 
					
						
							|  |  |  |                                              triggerSubmitClick: false | 
					
						
							|  |  |  |                                         }); | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                                         this.props.getPayCountryNetworkReset(); | 
					
						
							|  |  |  |                                    } | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          ], | 
					
						
							|  |  |  |                          { cancelable: false } | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } else { | 
					
						
							|  |  |  |                     Alert.alert( | 
					
						
							|  |  |  |                          I18n.t('ERROR_LABEL'), | 
					
						
							|  |  |  |                          JSON.stringify(errorPayCountryNetwork), | 
					
						
							|  |  |  |                          [ | 
					
						
							|  |  |  |                               { | 
					
						
							|  |  |  |                                    text: I18n.t("OK"), onPress: () => { | 
					
						
							|  |  |  |                                         this.props.getPayCountryNetworkReset(); | 
					
						
							| 
									
										
										
										
											2020-10-25 16:39:19 +00:00
										 |  |  |                                         this.setState({ | 
					
						
							|  |  |  |                                              isDataSubmit: false, | 
					
						
							|  |  |  |                                              isModalConfirmVisible: false, | 
					
						
							|  |  |  |                                              triggerSubmitClick: false | 
					
						
							|  |  |  |                                         }); | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                                    } | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          ], | 
					
						
							|  |  |  |                          { cancelable: false } | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |      renderEnvoieWalletToWalletResponse = () => { | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           const { resultEnvoieWalletToCash, errorEnvoieWalletToCash } = this.props; | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           if (errorEnvoieWalletToCash !== null) { | 
					
						
							|  |  |  |                if (typeof errorEnvoieWalletToCash.data !== 'undefined') { | 
					
						
							|  |  |  |                     Alert.alert( | 
					
						
							|  |  |  |                          I18n.t("ERROR_TRANSFER"), | 
					
						
							|  |  |  |                          errorEnvoieWalletToCash.data.error, | 
					
						
							|  |  |  |                          [ | 
					
						
							|  |  |  |                               { | 
					
						
							|  |  |  |                                    text: I18n.t("OK"), onPress: () => { | 
					
						
							| 
									
										
										
										
											2020-10-25 16:39:19 +00:00
										 |  |  |                                         this.setState({ | 
					
						
							|  |  |  |                                              isDataSubmit: false, | 
					
						
							|  |  |  |                                              isModalConfirmVisible: false, | 
					
						
							|  |  |  |                                              triggerSubmitClick: false | 
					
						
							|  |  |  |                                         }); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                                         this.props.envoieUserWalletToCashReset(); | 
					
						
							|  |  |  |                                    } | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  |                          ], | 
					
						
							|  |  |  |                          { cancelable: false } | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           if (resultEnvoieWalletToCash !== null) { | 
					
						
							|  |  |  |                if (resultEnvoieWalletToCash.response !== null) { | 
					
						
							|  |  |  |                     Alert.alert( | 
					
						
							|  |  |  |                          I18n.t("SUCCESS_TRANSFER"), | 
					
						
							|  |  |  |                          resultEnvoieWalletToCash.response, | 
					
						
							|  |  |  |                          [ | 
					
						
							|  |  |  |                               { | 
					
						
							|  |  |  |                                    text: I18n.t("OK"), onPress: () => { | 
					
						
							|  |  |  |                                         this.props.envoieUserWalletToCashReset(); | 
					
						
							|  |  |  |                                         IlinkEmitter.emit("refreshWallet"); | 
					
						
							|  |  |  |                                         this.props.navigation.pop(); | 
					
						
							| 
									
										
										
										
											2020-10-25 16:39:19 +00:00
										 |  |  |                                         this.setState({ | 
					
						
							|  |  |  |                                              isDataSubmit: false, | 
					
						
							|  |  |  |                                              isModalConfirmVisible: false, | 
					
						
							|  |  |  |                                              triggerSubmitClick: false | 
					
						
							|  |  |  |                                         });                                   } | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                               } | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                          ], | 
					
						
							|  |  |  |                          { cancelable: false } | 
					
						
							|  |  |  |                     ) | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |      renderDialogGetCommissionResponse = () => { | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           const { errorEnvoieWalletToCashGetCommission } = this.props; | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           if (errorEnvoieWalletToCashGetCommission !== null) { | 
					
						
							|  |  |  |                if (typeof errorEnvoieWalletToCashGetCommission.data !== 'undefined') { | 
					
						
							|  |  |  |                     Alert.alert( | 
					
						
							|  |  |  |                          I18n.t("ERROR_LABLE"), | 
					
						
							|  |  |  |                          errorEnvoieWalletToCashGetCommission.data.error, | 
					
						
							|  |  |  |                          [ | 
					
						
							|  |  |  |                               { | 
					
						
							|  |  |  |                                    text: I18n.t("OK"), onPress: () => { | 
					
						
							| 
									
										
										
										
											2020-10-25 16:39:19 +00:00
										 |  |  |                                         this.setState({ | 
					
						
							|  |  |  |                                              isDataSubmit: false, | 
					
						
							|  |  |  |                                              isModalConfirmVisible: false, | 
					
						
							|  |  |  |                                              triggerSubmitClick: false | 
					
						
							|  |  |  |                                         }); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                                         this.props.getCommissionUserWalletToCashReset(); | 
					
						
							|  |  |  |                                    } | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  |                          ], | 
					
						
							|  |  |  |                          { cancelable: false } | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      ckeckIfFieldIsOK(champ) { | 
					
						
							|  |  |  |           return (isNil(champ) || isEqual(champ.length, 0)); | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |      isMontantValid = () => { | 
					
						
							|  |  |  |           const { montant } = this.state; | 
					
						
							|  |  |  |           if ((parseInt(isEqual(montant, 0)) || montant < 0)) | 
					
						
							|  |  |  |                return { | 
					
						
							|  |  |  |                     errorMessage: I18n.t('ENTER_AMOUNT_SUPERIOR_ZEROR'), | 
					
						
							|  |  |  |                     isValid: false | 
					
						
							|  |  |  |                }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           else if (!isNormalInteger(montant)) | 
					
						
							|  |  |  |                return { | 
					
						
							|  |  |  |                     errorMessage: I18n.t('ENTER_VALID_AMOUNT'), | 
					
						
							|  |  |  |                     isValid: false | 
					
						
							|  |  |  |                }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           else if (montant > parseInt(this.state.comptePrincipal)) | 
					
						
							|  |  |  |                return { | 
					
						
							|  |  |  |                     errorMessage: I18n.t('AMOUNT_SUPERIOR_TO_PRINCIPAL_ACCOUNT'), | 
					
						
							|  |  |  |                     isValid: false | 
					
						
							|  |  |  |                }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           else | 
					
						
							|  |  |  |                return { | 
					
						
							|  |  |  |                     errorMessage: '', | 
					
						
							|  |  |  |                     isValid: true | 
					
						
							|  |  |  |                }; | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      modalConfirmTransaction = (data) => { | 
					
						
							|  |  |  |           const commission = data.response.frais; | 
					
						
							|  |  |  |           const montant_net_final = data.response.montant_net_final; | 
					
						
							|  |  |  |           const montant_net_init = data.response.montant_net_init; | 
					
						
							|  |  |  |           const destinataire = data.response.destinataire; | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |           const exchange_rate = data.response.exchange_rate; | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |           console.log("DATA SEND TO CONFIRM DIALOG", data); | 
					
						
							|  |  |  |           return ( | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                <Dialog.Container useNativeDriver={true} visible={this.state.isModalConfirmVisible}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     <Dialog.Title>{I18n.t('TRANSACTION_DETAIL')}</Dialog.Title> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     <View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <View style={[styles.blockView, { borderBottomColor: Color.borderColor }]}> | 
					
						
							|  |  |  |                               <View style={{ flexDirection: 'row', marginTop: 10 }}> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1 }}> | 
					
						
							|  |  |  |                                         <Text style={[styles.body2]}>{I18n.t('DESTINATAIRE')}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1, alignItems: 'flex-end' }}> | 
					
						
							| 
									
										
										
										
											2020-07-28 17:37:46 +00:00
										 |  |  |                                         <Text style={[Typography.caption1, Color.grayColor]}>{`${this.state.prenoms} ${this.state.noms}`}</Text> | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                                    </View> | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  |                               <View style={{ flexDirection: 'row', marginTop: 10 }}> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1 }}> | 
					
						
							|  |  |  |                                         <Text style={[styles.body2]}>{I18n.t('AMOUNT')}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1, alignItems: 'flex-end' }}> | 
					
						
							|  |  |  |                                         <Text style={[Typography.caption1, Color.grayColor]}>{`${thousands(this.state.montant, ' ')} ${this.state.wallet.currency_code}`}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  |                               <View style={{ flexDirection: 'row', marginTop: 10 }}> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1 }}> | 
					
						
							|  |  |  |                                         <Text tyle={[Typography.body2]}>{I18n.t('FEES_AND_TAXES')}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1, alignItems: 'flex-end' }}> | 
					
						
							|  |  |  |                                         <Text style={[Typography.caption1, Color.grayColor]}>{`${thousands(commission, ' ')} ${this.state.wallet.currency_code}`}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                          <View style={{ paddingVertical: 10 }}> | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |                          <View style={{flexDirection: 'row', marginTop: 10}}> | 
					
						
							|  |  |  |                             <View style={{flex: 1}}> | 
					
						
							|  |  |  |                                 <Text tyle={[Typography.body2, FontWeight.bold]}>{I18n.t('EXCHANGE_TAUX')}: </Text> | 
					
						
							|  |  |  |                             </View> | 
					
						
							|  |  |  |                             <View style={{flex: 1, alignItems: 'flex-end'}}> | 
					
						
							|  |  |  |                                 <Text style={[Typography.caption1, Color.grayColor]}>{exchange_rate}</Text> | 
					
						
							|  |  |  |                             </View> | 
					
						
							|  |  |  |                         </View> | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                               <View style={{ flexDirection: 'row', marginTop: 10 }}> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1 }}> | 
					
						
							|  |  |  |                                         <Text tyle={[Typography.body2, FontWeight.bold]}>{I18n.t('NET_AMOUNT')}:</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1, alignItems: 'flex-end' }}> | 
					
						
							|  |  |  |                                         <Text style={[Typography.caption1, Color.grayColor]}></Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  |                               <View style={{ flexDirection: 'row', marginTop: 10 }}> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1 }}> | 
					
						
							|  |  |  |                                         <Text tyle={[Typography.body2]}>{I18n.t('INIT_COUNTRY')}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1, alignItems: 'flex-end' }}> | 
					
						
							|  |  |  |                                         <Text style={[Typography.caption1, Color.grayColor]}>{`${thousands(montant_net_init, ' ')} ${this.state.wallet.currency_code}`}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  |                               <View style={{ flexDirection: 'row', marginTop: 10 }}> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1 }}> | 
					
						
							|  |  |  |                                         <Text tyle={[Typography.body2]}>{I18n.t('FINAL_COUNTRY')}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                                    <View style={{ flex: 1, alignItems: 'flex-end' }}> | 
					
						
							|  |  |  |                                         <Text style={[Typography.caption1, Color.grayColor]}>{montant_net_final}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                     </View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     <Dialog.Button bold={true} label={I18n.t('CANCEL_LABEL')} onPress={() => { | 
					
						
							| 
									
										
										
										
											2020-10-25 16:39:19 +00:00
										 |  |  |                     this.setState({ | 
					
						
							|  |  |  |                          isDataSubmit: false, | 
					
						
							|  |  |  |                          isModalConfirmVisible: false, | 
					
						
							|  |  |  |                          triggerSubmitClick: false | 
					
						
							|  |  |  |                     }); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                     }} /> | 
					
						
							|  |  |  |                     <Dialog.Button bold={true} label={I18n.t('SUBMIT_LABEL')} onPress={() => { | 
					
						
							|  |  |  |                          this.setState({ | 
					
						
							| 
									
										
										
										
											2020-10-25 16:39:19 +00:00
										 |  |  |                               triggerSubmitClick: false, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                               isModalConfirmVisible: false, | 
					
						
							|  |  |  |                               isDataSubmit: true | 
					
						
							|  |  |  |                          }); | 
					
						
							|  |  |  |                          this.props.envoieUserWalletToCashAction({ | 
					
						
							|  |  |  |                               type: 3, | 
					
						
							|  |  |  |                               id_wallet_user: this.state.wallet.id, | 
					
						
							|  |  |  |                               final_country: (this.state.paysDestination.filter(element => element.name === this.state.paysDestinationSelect))[0].id, | 
					
						
							|  |  |  |                               id_destinataire: this.state.numeroTelephone, | 
					
						
							|  |  |  |                               type_document_destinataire: this.state.identityPiecesName, | 
					
						
							|  |  |  |                               nom_destinataire: this.state.noms, | 
					
						
							|  |  |  |                               prenom_destinataire: this.state.prenoms, | 
					
						
							|  |  |  |                               id_document_destinataire: this.state.numeroIdentite, | 
					
						
							|  |  |  |                               network_destinataire: (this.state.walletActifs.filter(element => element.name === this.state.walletActifSelect))[0].id, | 
					
						
							|  |  |  |                               montant: this.state.montant, | 
					
						
							|  |  |  |                               password: this.state.password | 
					
						
							|  |  |  |                          }); | 
					
						
							|  |  |  |                          this.props.getCommissionUserWalletToCashReset(); | 
					
						
							|  |  |  |                     }} /> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                </Dialog.Container> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |      onSubmitSendWalletToWallet = () => { | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           const { identityPiecesName, noms, prenoms, paysDestinationSelect, numeroIdentite, walletActifSelect, typeIdDestinataireSelect, numeroTelephone, montant, password } = this.state; | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |           if (this.ckeckIfFieldIsOK(identityPiecesName)) | 
					
						
							|  |  |  |                this.identityPiecesAnim.shake(800); | 
					
						
							|  |  |  |           else if (this.ckeckIfFieldIsOK(paysDestinationSelect)) | 
					
						
							|  |  |  |                this.paysDestinationAnim.shake(800); | 
					
						
							|  |  |  |           else if (this.ckeckIfFieldIsOK(walletActifSelect)) | 
					
						
							|  |  |  |                this.walletActifAnim.shake(800); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           else if (this.ckeckIfFieldIsOK(noms)) | 
					
						
							|  |  |  |                this.firstnameAnim.shake(800); | 
					
						
							|  |  |  |           else if (this.ckeckIfFieldIsOK(prenoms)) | 
					
						
							|  |  |  |                this.lastnameAnim.shake(800); | 
					
						
							|  |  |  |           else if (this.ckeckIfFieldIsOK(numeroIdentite)) | 
					
						
							|  |  |  |                this.numeroIdentiteAnim.shake(800); | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |           else if (this.ckeckIfFieldIsOK(numeroTelephone)) | 
					
						
							|  |  |  |                this.numeroTelephoneAnim.shake(800); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           else if (this.ckeckIfFieldIsOK(montant) || !this.isMontantValid().isValid) { | 
					
						
							|  |  |  |                console.log("IS MONTANT VALID", this.isMontantValid()) | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                this.montantAnim.shake(800); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |           else if (this.ckeckIfFieldIsOK(password)) | 
					
						
							|  |  |  |                this.passwordAnim.shake(800); | 
					
						
							|  |  |  |           else { | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                this.props.getCommissionUserWalletToCashAction({ | 
					
						
							|  |  |  |                     type: 3, | 
					
						
							|  |  |  |                     id_wallet_user: this.state.wallet.id, | 
					
						
							|  |  |  |                     final_country: (this.state.paysDestination.filter(element => element.name === this.state.paysDestinationSelect))[0].id, | 
					
						
							|  |  |  |                     montant: this.state.montant, | 
					
						
							| 
									
										
										
										
											2023-10-05 10:22:10 +00:00
										 |  |  |                     network_destinataire: (this.state.walletActifs.filter(element => element.name === this.state.walletActifSelect))[0].id, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |           } | 
					
						
							|  |  |  |           this.setState({ | 
					
						
							|  |  |  |                triggerSubmitClick: true | 
					
						
							|  |  |  |           }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      renderLoader = () => { | 
					
						
							|  |  |  |           return ( | 
					
						
							|  |  |  |                <ProgressDialog | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                     visible={this.state.modalVisible || this.props.loadingEnvoieWalletToCashGetCommission || this.props.loadingEnvoieWalletToCash || this.props.loadingCountryByDialCode || this.props.loadingActiveCountryList || this.props.loadingCountryByDialCode} | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                     title={I18n.t('LOADING')} | 
					
						
							|  |  |  |                     message={I18n.t('LOADING_INFO')} | 
					
						
							|  |  |  |                /> | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      render() { | 
					
						
							|  |  |  |           console.log("STATE", this.state); | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           const { resultEnvoieWalletToCashGetCommission } = this.props; | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |           return ( | 
					
						
							|  |  |  |                <> | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                     {(this.state.modalVisible || this.props.loadingEnvoieWalletToCashGetCommission || this.props.loadingEnvoieWalletToCash || this.props.loadingCountryByDialCode || this.props.loadingActiveCountryList || this.props.loadingCountryByDialCode) && this.renderLoader()} | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                     {this.state.hasLoadActiveCountryList && this.renderGetActionCountryList()} | 
					
						
							|  |  |  |                     {this.state.hasLoadActivePayCountryNetworkList && this.renderGetPayCountryNetworkResponse()} | 
					
						
							| 
									
										
										
										
											2020-10-25 16:39:19 +00:00
										 |  |  |                     {(this.state.isDataSubmit && !this.state.triggerSubmitClick) && this.renderEnvoieWalletToWalletResponse()} | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                     {this.state.triggerSubmitClick && this.renderDialogGetCommissionResponse()} | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                          (resultEnvoieWalletToCashGetCommission !== null) && | 
					
						
							|  |  |  |                          (typeof resultEnvoieWalletToCashGetCommission.response !== 'undefined') && | 
					
						
							|  |  |  |                          this.modalConfirmTransaction(resultEnvoieWalletToCashGetCommission) | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                     <ScrollView style={styles.container}> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                          <Text style={styles.subbigtitle}>{I18n.t('ENVOIE_WALLET_TO_CASH')}</Text> | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                          <Animatable.View ref={(comp) => { this.paysDestinationAnim = comp }} | 
					
						
							|  |  |  |                               style={{ | 
					
						
							|  |  |  |                                    width: responsiveWidth(90), | 
					
						
							|  |  |  |                                    height: 60, | 
					
						
							|  |  |  |                                    marginTop: 20, | 
					
						
							|  |  |  |                                    alignSelf: 'center', | 
					
						
							|  |  |  |                                    borderRadius: 10, | 
					
						
							|  |  |  |                                    paddingLeft: 20, | 
					
						
							|  |  |  |                                    paddingRight: 20, | 
					
						
							|  |  |  |                                    backgroundColor: 'white' | 
					
						
							|  |  |  |                               }}> | 
					
						
							|  |  |  |                               <Dropdown | 
					
						
							|  |  |  |                                    label={I18n.t('PAYS_DESTINATION')} | 
					
						
							|  |  |  |                                    data={this.state.paysDestination} | 
					
						
							|  |  |  |                                    useNativeDriver={true} | 
					
						
							|  |  |  |                                    value={this.state.paysDestinationSelect === null ? '' : this.state.paysDestinationSelect} | 
					
						
							|  |  |  |                                    onChangeText={(value, index, data) => { | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                                         this.props.getPayCountryNetworkReset(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                                         let countrySelect = data.filter(element => element.name === value); | 
					
						
							|  |  |  |                                         this.setState({ paysDestinationSelect: value, hasLoadActivePayCountryNetworkList: true }, () => { | 
					
						
							|  |  |  |                                              this.props.getPayCountryNetworkAction({ id_wallet_user: this.state.wallet.id, id_country: countrySelect[0].id }); | 
					
						
							|  |  |  |                                         }); | 
					
						
							|  |  |  |                                         this.props.getCommissionUserWalletToCashReset(); | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                                    }} | 
					
						
							|  |  |  |                                    valueExtractor={(value) => { return value.name }} | 
					
						
							|  |  |  |                                    labelExtractor={(value) => { return value.name }} | 
					
						
							|  |  |  |                               /> | 
					
						
							|  |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <Animatable.View ref={(comp) => { this.walletActifAnim = comp }} | 
					
						
							|  |  |  |                               style={{ | 
					
						
							|  |  |  |                                    width: responsiveWidth(90), | 
					
						
							|  |  |  |                                    height: 60, | 
					
						
							|  |  |  |                                    marginTop: 20, | 
					
						
							|  |  |  |                                    alignSelf: 'center', | 
					
						
							|  |  |  |                                    borderRadius: 10, | 
					
						
							|  |  |  |                                    paddingLeft: 20, | 
					
						
							|  |  |  |                                    paddingRight: 20, | 
					
						
							|  |  |  |                                    backgroundColor: 'white' | 
					
						
							|  |  |  |                               }}> | 
					
						
							|  |  |  |                               <Dropdown | 
					
						
							|  |  |  |                                    label={I18n.t('ACTIVE_WALLET')} | 
					
						
							|  |  |  |                                    data={this.state.walletActifs} | 
					
						
							|  |  |  |                                    useNativeDriver={true} | 
					
						
							|  |  |  |                                    value={isNil(this.state.walletActifSelect) ? '' : this.state.walletActifSelect} | 
					
						
							|  |  |  |                                    onChangeText={(value, index, data) => { | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                                         this.setState({ | 
					
						
							|  |  |  |                                              walletActifSelect: value, | 
					
						
							|  |  |  |                                         }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                                    }} | 
					
						
							|  |  |  |                                    valueExtractor={(value) => { return value.name }} | 
					
						
							|  |  |  |                                    labelExtractor={(value) => { return value.name }} | 
					
						
							|  |  |  |                               /> | 
					
						
							|  |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                          <Animatable.View ref={(comp) => { this.firstnameAnim = comp }}> | 
					
						
							|  |  |  |                               <Fumi iconClass={FontAwesomeIcon} iconName={'user'} | 
					
						
							|  |  |  |                                    label={`${I18n.t('NAME')}`} | 
					
						
							|  |  |  |                                    iconColor={'#f95a25'} | 
					
						
							|  |  |  |                                    iconSize={20} | 
					
						
							|  |  |  |                                    value={this.state.noms} | 
					
						
							|  |  |  |                                    onChangeText={(noms) => { | 
					
						
							|  |  |  |                                         this.setState({ noms }) | 
					
						
							|  |  |  |                                    }} | 
					
						
							|  |  |  |                                    style={styles.input} | 
					
						
							|  |  |  |                               > | 
					
						
							|  |  |  |                               </Fumi> | 
					
						
							|  |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <Animatable.View ref={(comp) => { this.lastnameAnim = comp }}> | 
					
						
							|  |  |  |                               <Fumi iconClass={FontAwesomeIcon} iconName={'user-circle-o'} | 
					
						
							|  |  |  |                                    label={`${I18n.t('FIRSTNAME')}`} | 
					
						
							|  |  |  |                                    iconColor={'#f95a25'} | 
					
						
							|  |  |  |                                    iconSize={20} | 
					
						
							|  |  |  |                                    value={this.state.prenoms} | 
					
						
							|  |  |  |                                    onChangeText={(prenoms) => { | 
					
						
							|  |  |  |                                         this.setState({ prenoms }) | 
					
						
							|  |  |  |                                    }} | 
					
						
							|  |  |  |                                    style={styles.input} | 
					
						
							|  |  |  |                               > | 
					
						
							|  |  |  |                               </Fumi> | 
					
						
							|  |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <Animatable.View ref={(comp) => { this.numeroTelephoneAnim = comp }}> | 
					
						
							|  |  |  |                               <Fumi iconClass={FontAwesomeIcon} iconName={isEqual(this.state.typeIdDestinataireSelect, I18n.t('PHONE')) ? 'phone' : 'lock'} | 
					
						
							|  |  |  |                                    label={I18n.t('PHONE')} | 
					
						
							|  |  |  |                                    iconColor={'#f95a25'} | 
					
						
							|  |  |  |                                    keyboardType='phone-pad' | 
					
						
							|  |  |  |                                    iconSize={20} | 
					
						
							|  |  |  |                                    value={this.state.numeroTelephone} | 
					
						
							|  |  |  |                                    onChangeText={(numeroTelephone) => { | 
					
						
							|  |  |  |                                         this.setState({ numeroTelephone }) | 
					
						
							|  |  |  |                                    }} | 
					
						
							|  |  |  |                                    style={styles.input} | 
					
						
							|  |  |  |                               > | 
					
						
							|  |  |  |                               </Fumi> | 
					
						
							|  |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                          <Animatable.View ref={(comp) => { this.identityPiecesAnim = comp }} | 
					
						
							|  |  |  |                               style={{ | 
					
						
							|  |  |  |                                    width: responsiveWidth(90), | 
					
						
							|  |  |  |                                    height: 60, | 
					
						
							|  |  |  |                                    marginTop: 20, | 
					
						
							|  |  |  |                                    alignSelf: 'center', | 
					
						
							|  |  |  |                                    borderRadius: 10, | 
					
						
							|  |  |  |                                    paddingLeft: 20, | 
					
						
							|  |  |  |                                    paddingRight: 20, | 
					
						
							|  |  |  |                                    backgroundColor: 'white' | 
					
						
							|  |  |  |                               }}> | 
					
						
							|  |  |  |                               <Dropdown | 
					
						
							|  |  |  |                                    label={I18n.t('PIECE_IDENTITE')} | 
					
						
							|  |  |  |                                    data={this.state.identityPieces} | 
					
						
							|  |  |  |                                    useNativeDriver={true} | 
					
						
							|  |  |  |                                    value={this.state.identityPiecesName} | 
					
						
							|  |  |  |                                    onChangeText={(value, index, data) => { | 
					
						
							|  |  |  |                                         this.setState({ identityPiecesName: value }); | 
					
						
							|  |  |  |                                    }} | 
					
						
							| 
									
										
										
										
											2020-11-04 20:02:23 +00:00
										 |  |  |                                    valueExtractor={(value) => { return I18n.t(value.name) }} | 
					
						
							|  |  |  |                                    labelExtractor={(value) => { return I18n.t(value.name) }} | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                               /> | 
					
						
							|  |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                          <Animatable.View ref={(comp) => { this.numeroIdentiteAnim = comp }}> | 
					
						
							|  |  |  |                               <Fumi iconClass={FontAwesomeIcon} iconName={'address-card'} | 
					
						
							|  |  |  |                                    label={`${I18n.t('NUMERO_IDENTITE')}`} | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                                    iconColor={'#f95a25'} | 
					
						
							|  |  |  |                                    iconSize={20} | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                                    onChangeText={(numeroIdentite) => { | 
					
						
							|  |  |  |                                         this.setState({ numeroIdentite }) | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                                    }} | 
					
						
							|  |  |  |                                    style={styles.input} | 
					
						
							|  |  |  |                               > | 
					
						
							|  |  |  |                               </Fumi> | 
					
						
							|  |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <Animatable.View ref={(comp) => { this.montantAnim = comp }}> | 
					
						
							|  |  |  |                               <Fumi iconClass={FontAwesomeIcon} iconName={'money'} | 
					
						
							|  |  |  |                                    label={I18n.t('AMOUNT')} | 
					
						
							|  |  |  |                                    iconColor={'#f95a25'} | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                                    keyboardType='numeric' | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                                    iconSize={20} | 
					
						
							|  |  |  |                                    value={this.state.montant} | 
					
						
							|  |  |  |                                    onChangeText={(montant) => { | 
					
						
							|  |  |  |                                         this.setState({ montant }) | 
					
						
							|  |  |  |                                    }} | 
					
						
							|  |  |  |                                    style={styles.input} | 
					
						
							|  |  |  |                               > | 
					
						
							|  |  |  |                               </Fumi> | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                               <View style={{ | 
					
						
							|  |  |  |                                    position: 'absolute', | 
					
						
							|  |  |  |                                    left: responsiveWidth(82), | 
					
						
							|  |  |  |                                    top: 35, | 
					
						
							|  |  |  |                                    flexDirection: 'row' | 
					
						
							|  |  |  |                               }}> | 
					
						
							|  |  |  |                                    <View | 
					
						
							|  |  |  |                                         style={{ | 
					
						
							|  |  |  |                                              width: 1, | 
					
						
							|  |  |  |                                              borderLeftColor: '#f0f0f0', | 
					
						
							|  |  |  |                                              height: 40, | 
					
						
							|  |  |  |                                              left: -8, | 
					
						
							|  |  |  |                                              top: -10, | 
					
						
							|  |  |  |                                              borderLeftWidth: 1, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                                         }} | 
					
						
							|  |  |  |                                    /> | 
					
						
							|  |  |  |                                    <Text style={[Typography.body1, FontWeight.bold]}>{this.state.wallet.currency_code}</Text> | 
					
						
							|  |  |  |                               </View> | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <Animatable.View ref={(comp) => { this.passwordAnim = comp }}> | 
					
						
							|  |  |  |                               <Fumi iconClass={FontAwesomeIcon} iconName={'lock'} | 
					
						
							|  |  |  |                                    label={I18n.t('PASSWORD')} | 
					
						
							|  |  |  |                                    iconColor={'#f95a25'} | 
					
						
							|  |  |  |                                    iconSize={20} | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                                    secureTextEntry={true} | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |                                    value={this.state.password} | 
					
						
							|  |  |  |                                    onChangeText={(password) => { | 
					
						
							|  |  |  |                                         this.setState({ password }) | 
					
						
							|  |  |  |                                    }} | 
					
						
							|  |  |  |                                    style={styles.input} | 
					
						
							|  |  |  |                               > | 
					
						
							|  |  |  |                               </Fumi> | 
					
						
							|  |  |  |                          </Animatable.View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <Button style={styles.btnvalide} | 
					
						
							|  |  |  |                               textStyle={styles.textbtnvalide} | 
					
						
							|  |  |  |                               isLoading={this.state.isLoging} | 
					
						
							|  |  |  |                               onPress={() => { this.onSubmitSendWalletToWallet() }}> | 
					
						
							|  |  |  |                               {I18n.t('SUBMIT_LABEL')}</Button> | 
					
						
							|  |  |  |                     </ScrollView> | 
					
						
							|  |  |  |                </> | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const maptStateToProps = state => ({ | 
					
						
							|  |  |  |      loadingCountryByDialCode: state.countryByDialCode.loading, | 
					
						
							|  |  |  |      resultCountryByDialCode: state.countryByDialCode.result, | 
					
						
							|  |  |  |      errorCountryByDialCode: state.countryByDialCode.error, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      loadingActiveCountryList: state.activeCountryListReducer.loading, | 
					
						
							|  |  |  |      resultActiveCountryList: state.activeCountryListReducer.result, | 
					
						
							|  |  |  |      errorActiveCountryList: state.activeCountryListReducer.error, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      loadingPayCountryNetwork: state.payCountryNetworkReducer.loading, | 
					
						
							|  |  |  |      resultPayCountryNetwork: state.payCountryNetworkReducer.result, | 
					
						
							|  |  |  |      errorPayCountryNetwork: state.payCountryNetworkReducer.error, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |      loadingEnvoieWalletToCash: state.envoieUserWalletToCashReducer.loading, | 
					
						
							|  |  |  |      resultEnvoieWalletToCash: state.envoieUserWalletToCashReducer.result, | 
					
						
							|  |  |  |      errorEnvoieWalletToCash: state.envoieUserWalletToCashReducer.error, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      loadingEnvoieWalletToCashGetCommission: state.envoieUserWalletToCashGetCommissionReducer.loading, | 
					
						
							|  |  |  |      resultEnvoieWalletToCashGetCommission: state.envoieUserWalletToCashGetCommissionReducer.result, | 
					
						
							|  |  |  |      errorEnvoieWalletToCashGetCommission: state.envoieUserWalletToCashGetCommissionReducer.error, | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const mapDispatchToProps = dispatch => bindActionCreators({ | 
					
						
							|  |  |  |      getActiveCountryByDialCodeAction, | 
					
						
							|  |  |  |      getActiveCountryByDialCodeReset, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      getPayCountryNetworkAction, | 
					
						
							|  |  |  |      getPayCountryNetworkReset, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      getActiveCountryAction, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |      getActiveCountryReset, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      envoieUserWalletToCashAction, | 
					
						
							|  |  |  |      envoieUserWalletToCashReset, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      getCommissionUserWalletToCashAction, | 
					
						
							|  |  |  |      getCommissionUserWalletToCashReset | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | }, dispatch); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default connect(maptStateToProps, mapDispatchToProps)(EnvoieWalletToCashUser); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const styles = StyleSheet.create({ | 
					
						
							|  |  |  |      container: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           backgroundColor: Color.primaryDarkColor, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      textbtnvalide: { | 
					
						
							|  |  |  |           color: 'white', | 
					
						
							|  |  |  |           fontWeight: 'bold' | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      bigtitle: { | 
					
						
							|  |  |  |           color: 'white', | 
					
						
							|  |  |  |           fontSize: 20, | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           fontWeight: 'bold', | 
					
						
							|  |  |  |           textAlign: 'center', | 
					
						
							|  |  |  |           margin: 20, | 
					
						
							|  |  |  |      }, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |      blockView: { | 
					
						
							|  |  |  |           paddingVertical: 10, | 
					
						
							|  |  |  |           borderBottomWidth: 1 | 
					
						
							|  |  |  |      }, | 
					
						
							| 
									
										
										
										
											2020-06-23 08:55:19 +00:00
										 |  |  |      subbigtitle: { | 
					
						
							|  |  |  |           color: 'white', | 
					
						
							|  |  |  |           fontSize: 17, | 
					
						
							|  |  |  |           textAlign: 'center', | 
					
						
							|  |  |  |           margin: 5, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      btnvalide: { | 
					
						
							|  |  |  |           marginTop: 20, | 
					
						
							|  |  |  |           marginLeft: 20, | 
					
						
							|  |  |  |           marginRight: 20, | 
					
						
							|  |  |  |           borderColor: 'transparent', | 
					
						
							|  |  |  |           backgroundColor: Color.accentLightColor, | 
					
						
							|  |  |  |           height: 52 | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      btnSubmit: { | 
					
						
							|  |  |  |           marginTop: 20, | 
					
						
							|  |  |  |           borderColor: 'transparent', | 
					
						
							|  |  |  |           backgroundColor: Color.accentLightColor, | 
					
						
							|  |  |  |           height: 52, | 
					
						
							|  |  |  |           width: "30%", | 
					
						
							|  |  |  |           marginLeft: 20, | 
					
						
							|  |  |  |           marginRight: 20, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      input: { | 
					
						
							|  |  |  |           height: 60, | 
					
						
							|  |  |  |           marginTop: responsiveHeight(2), | 
					
						
							|  |  |  |           marginLeft: responsiveWidth(5), | 
					
						
							|  |  |  |           marginRight: responsiveWidth(5), | 
					
						
							|  |  |  |           borderRadius: 5, | 
					
						
							|  |  |  |      } | 
					
						
							| 
									
										
										
										
											2023-03-12 23:38:33 +00:00
										 |  |  | }); |