| 
									
										
										
										
											2020-06-02 09:05:50 +00:00
										 |  |  | import React, { Component } from 'react'; | 
					
						
							|  |  |  | import { StyleSheet, View, Image, StatusBar, Alert, FlatList, TouchableOpacity, ActivityIndicator, Platform, ProgressBarAndroid, Text } from 'react-native'; | 
					
						
							|  |  |  | 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'; | 
					
						
							|  |  |  | import { readUser } from '../../webservice/AuthApi'; | 
					
						
							|  |  |  | import { FontWeight, Typography } from '../../config/typography'; | 
					
						
							| 
									
										
										
										
											2020-06-05 16:51:15 +00:00
										 |  |  | import LottieView from 'lottie-react-native'; | 
					
						
							| 
									
										
										
										
											2020-06-17 14:09:27 +00:00
										 |  |  | import { isIlinkWorldWallet, optionDepotScreen, optionPaiementFactureSubScreen } from '../../utils/UtilsFunction'; | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  | import chunk from 'lodash/chunk'; | 
					
						
							| 
									
										
										
										
											2020-06-02 09:05:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default class WalletOptionSelect extends Component { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      constructor(props) { | 
					
						
							|  |  |  |           super(props); | 
					
						
							|  |  |  |           IlinkEmitter.on("langueChange", this.updateLangue.bind(this)); | 
					
						
							|  |  |  |           this.state = { | 
					
						
							|  |  |  |                options: this.props.navigation.state.params.optionSelect.options, | 
					
						
							|  |  |  |                title: this.props.navigation.state.params.optionSelect.title, | 
					
						
							|  |  |  |                subTitle: this.props.navigation.state.params.optionSelect.subTitle, | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                type: this.props.navigation.state.params.optionSelect.type, | 
					
						
							|  |  |  |                wallet: this.props.navigation.state.params.wallet, | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                lottie: this.props.navigation.state.params.lottie, | 
					
						
							|  |  |  |                onGoBack: this.props.navigation.state.params.onGoBack, | 
					
						
							| 
									
										
										
										
											2020-06-02 09:05:50 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |           console.log("WALLET OPTION PROPS", this.props); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |           IlinkEmitter.on("langueChange", this.updateLangue.bind(this)); | 
					
						
							| 
									
										
										
										
											2020-06-02 09:05:50 +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-07-02 14:35:00 +00:00
										 |  |  |      updateLangue() { | 
					
						
							|  |  |  |           this.props.navigation.setParams({ name: I18n.t('WALLET') }) | 
					
						
							|  |  |  |           this.forceUpdate() | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |      redirectToRoute = (options) => { | 
					
						
							|  |  |  |           switch (this.state.type) { | 
					
						
							|  |  |  |                case 'FACTURE': | 
					
						
							|  |  |  |                     this.props.navigation.push(options.screen, { | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                          optionSelect: options.subScreenOption, | 
					
						
							|  |  |  |                          onGoBack: () => this.props.navigation.state.params.onGoBack(), | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                     }); | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                case 'DEPOT': | 
					
						
							|  |  |  |                     this.props.navigation.push(options.screen, { | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                          wallet: this.state.wallet, | 
					
						
							|  |  |  |                          onGoBack: () => this.props.navigation.state.params.onGoBack(), | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                case 'DEPOT_USER': | 
					
						
							|  |  |  |                     this.props.navigation.push(options.screen, { | 
					
						
							|  |  |  |                          wallet: this.state.wallet, | 
					
						
							|  |  |  |                          onGoBack: () => this.props.navigation.state.params.onGoBack(), | 
					
						
							|  |  |  |                          optionSelect: options.subScreenOption, | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                     }); | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                case 'RETRAIT': | 
					
						
							|  |  |  |                     this.props.navigation.push(options.screen, { | 
					
						
							| 
									
										
										
										
											2020-07-02 14:35:00 +00:00
										 |  |  |                          wallet: this.state.wallet, | 
					
						
							|  |  |  |                          onGoBack: () => this.props.navigation.state.params.onGoBack(), | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                     }); | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                default: | 
					
						
							|  |  |  |                     this.props.navigation.push(options.screen) | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      renderItem = (options, isOneElement, index) => ( | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |           isOneElement ? | 
					
						
							|  |  |  |                <> | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                     <View key={index} style={[styles.containerTouch]}> | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                          <TouchableOpacity style={styles.contain} | 
					
						
							|  |  |  |                               onPress={() => { | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                                    this.redirectToRoute(options); | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                               }} | 
					
						
							|  |  |  |                               activeOpacity={0.9}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               <Icon name={options.icon} | 
					
						
							|  |  |  |                                    color={Color.primaryColor} | 
					
						
							|  |  |  |                                    size={30} | 
					
						
							|  |  |  |                                    style={styles.imageBanner} /> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               <View style={[styles.content]}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                                    <View style={styles.contentTitle}> | 
					
						
							|  |  |  |                                         <Text style={[Typography.headline, Typography.semibold]}> | 
					
						
							|  |  |  |                                              {options.title} | 
					
						
							|  |  |  |                                         </Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  |                          </TouchableOpacity> | 
					
						
							|  |  |  |                     </View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     <View style={{ flex: 1 }} /> | 
					
						
							|  |  |  |                </> : | 
					
						
							|  |  |  |                <View style={[styles.containerTouch]}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     <TouchableOpacity style={styles.contain} | 
					
						
							|  |  |  |                          onPress={() => { | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                               this.redirectToRoute(options); | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                          }} | 
					
						
							|  |  |  |                          activeOpacity={0.9}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <Icon name={options.icon} | 
					
						
							|  |  |  |                               color={Color.primaryColor} | 
					
						
							|  |  |  |                               size={30} | 
					
						
							|  |  |  |                               style={styles.imageBanner} /> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <View style={[styles.content]}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               <View style={styles.contentTitle}> | 
					
						
							|  |  |  |                                    <Text style={[Typography.headline, Typography.semibold]}> | 
					
						
							|  |  |  |                                         {options.title} | 
					
						
							|  |  |  |                                    </Text> | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               <View style={{ flex: 1 }}> | 
					
						
							|  |  |  |                               </View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                     </TouchableOpacity> | 
					
						
							|  |  |  |                </View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-02 09:05:50 +00:00
										 |  |  |      updateLangue() { | 
					
						
							|  |  |  |           this.props.navigation.setParams({ name: I18n.t('WALLET') }) | 
					
						
							|  |  |  |           this.forceUpdate(); | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      render() { | 
					
						
							|  |  |  |           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={this.state.title} | 
					
						
							|  |  |  |                                    subtitle={this.state.subTitle} | 
					
						
							|  |  |  |                               /> | 
					
						
							|  |  |  |                          </Appbar.Header> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                          <View style={styles.container}> | 
					
						
							| 
									
										
										
										
											2020-06-05 16:51:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                               <View style={{ | 
					
						
							|  |  |  |                                    justifyContent: 'center', | 
					
						
							|  |  |  |                                    alignItems: 'center' | 
					
						
							|  |  |  |                               }}> | 
					
						
							|  |  |  |                                    <LottieView | 
					
						
							|  |  |  |                                         style={styles.lottie} | 
					
						
							| 
									
										
										
										
											2020-06-10 03:10:45 +00:00
										 |  |  |                                         source={this.state.lottie.source} | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                                         autoPlay | 
					
						
							| 
									
										
										
										
											2020-06-10 03:10:45 +00:00
										 |  |  |                                         loop={this.state.lottie.loop} | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                                    /> | 
					
						
							|  |  |  |                               </View> | 
					
						
							| 
									
										
										
										
											2020-06-05 16:51:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                               <View style={[styles.checkDefault, { borderBottomColor: Color.borderColor }]}> | 
					
						
							|  |  |  |                                    <Text | 
					
						
							|  |  |  |                                         style={[Typography.title3, Typography.semibold]}> | 
					
						
							|  |  |  |                                         {I18n.t('TRANSACTIONS')} | 
					
						
							|  |  |  |                                    </Text> | 
					
						
							|  |  |  |                               </View> | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                               { | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                                    chunk(this.state.options, 2).map((item, index) => ( | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                                         <View key={index} style={styles.transactionContainer}> | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                                              { | 
					
						
							|  |  |  |                                                   item.length === 1 ? | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                                                        item.map((wallet, i) => ( | 
					
						
							|  |  |  |                                                             this.renderItem(wallet, true, i) | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                                                        )) : | 
					
						
							| 
									
										
										
										
											2020-06-18 05:38:10 +00:00
										 |  |  |                                                        item.map((wallet, i) => ( | 
					
						
							|  |  |  |                                                             this.renderItem(wallet, false, i) | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |                                                        )) | 
					
						
							|  |  |  |                                              } | 
					
						
							|  |  |  |                                         </View> | 
					
						
							|  |  |  |                                    )) | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-02 09:05:50 +00:00
										 |  |  |                          </View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     </View> | 
					
						
							|  |  |  |                </Provider> | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const styles = StyleSheet.create({ | 
					
						
							|  |  |  |      container: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           backgroundColor: Color.containerBackgroundColor, | 
					
						
							| 
									
										
										
										
											2020-06-05 16:51:15 +00:00
										 |  |  |           paddingHorizontal: 20, | 
					
						
							| 
									
										
										
										
											2020-06-02 09:05:50 +00:00
										 |  |  |      }, | 
					
						
							|  |  |  |      item: { | 
					
						
							|  |  |  |           paddingVertical: 15, | 
					
						
							|  |  |  |           borderBottomWidth: 1, | 
					
						
							|  |  |  |           flexDirection: "row", | 
					
						
							|  |  |  |           justifyContent: "space-between", | 
					
						
							|  |  |  |           alignItems: "center" | 
					
						
							| 
									
										
										
										
											2020-06-05 16:51:15 +00:00
										 |  |  |      }, | 
					
						
							|  |  |  |      lottie: { | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |           width: 540, | 
					
						
							|  |  |  |           height: 240 | 
					
						
							| 
									
										
										
										
											2020-06-05 16:51:15 +00:00
										 |  |  |      }, | 
					
						
							|  |  |  |      checkDefault: { | 
					
						
							|  |  |  |           flexDirection: "row", | 
					
						
							|  |  |  |           justifyContent: "space-between", | 
					
						
							|  |  |  |           alignItems: "center", | 
					
						
							|  |  |  |           borderBottomWidth: 1, | 
					
						
							|  |  |  |           paddingVertical: 10, | 
					
						
							|  |  |  |           marginTop: 5 | 
					
						
							|  |  |  |      }, | 
					
						
							| 
									
										
										
										
											2020-06-09 10:11:19 +00:00
										 |  |  |      transactionContainer: { | 
					
						
							|  |  |  |           flexDirection: 'row', | 
					
						
							|  |  |  |           paddingTop: 10, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      containerTouch: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           flexDirection: 'row', | 
					
						
							|  |  |  |           alignItems: 'center', | 
					
						
							|  |  |  |           shadowColor: Color.borderColor, | 
					
						
							|  |  |  |           borderColor: Color.borderColor, | 
					
						
							|  |  |  |           borderWidth: 0.5, | 
					
						
							|  |  |  |           shadowOffset: { width: 1.5, height: 1.5 }, | 
					
						
							|  |  |  |           shadowOpacity: 1.0, | 
					
						
							|  |  |  |           elevation: 5, | 
					
						
							|  |  |  |           borderRadius: 10, | 
					
						
							|  |  |  |           backgroundColor: Color.cardBackgroundColor | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      contain: { | 
					
						
							|  |  |  |           flexDirection: 'row', | 
					
						
							|  |  |  |           justifyContent: 'space-between', | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      imageBanner: { | 
					
						
							|  |  |  |           marginTop: 15, | 
					
						
							|  |  |  |           marginLeft: 5, | 
					
						
							|  |  |  |           width: Utils.scaleWithPixel(30), | 
					
						
							|  |  |  |           height: Utils.scaleWithPixel(30) | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      content: { | 
					
						
							|  |  |  |           height: Utils.scaleWithPixel(60), | 
					
						
							|  |  |  |           paddingHorizontal: 10, | 
					
						
							|  |  |  |           justifyContent: 'space-between', | 
					
						
							|  |  |  |           alignItems: 'flex-start', | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      contentTitle: { | 
					
						
							|  |  |  |           paddingTop: 12, | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-02 09:05:50 +00:00
										 |  |  | }); |