| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  | import React, { Component } from "react"; | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  | import { View, Text, TouchableOpacity, StyleSheet, ScrollView, Animated } from "react-native"; | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  | import { Typography } from "../../../config/typography"; | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  | import * as Utils from '../../../utils/DeviceUtils'; | 
					
						
							|  |  |  | import Icon from 'react-native-vector-icons/MaterialCommunityIcons'; | 
					
						
							|  |  |  | import {optionenvoieautrewalletScreen} from '../../../utils/UtilsFunction' | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  | import { Color } from "../../../config/Color"; | 
					
						
							|  |  |  | import route from '../../../route.json'; | 
					
						
							|  |  |  | import I18n from 'react-native-i18n'; | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  | import 'moment/locale/fr' | 
					
						
							|  |  |  | import 'moment/locale/es-us' | 
					
						
							|  |  |  | import 'moment/locale/en-au' | 
					
						
							|  |  |  | import 'moment/locale/en-ca' | 
					
						
							|  |  |  | import 'moment/locale/en-ie' | 
					
						
							|  |  |  | import 'moment/locale/en-il' | 
					
						
							|  |  |  | import 'moment/locale/en-nz' | 
					
						
							|  |  |  | import 'moment/locale/en-gb' | 
					
						
							|  |  |  | let slugify = require('slugify'); | 
					
						
							|  |  |  | import {IlinkEmitter} from "../../../utils/events"; | 
					
						
							| 
									
										
										
										
											2023-10-05 10:22:10 +00:00
										 |  |  | import { readUser } from "../../../webservice/AuthApi"; | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | class Modal 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'), | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |             headerTintColor: 'white', | 
					
						
							|  |  |  |             headerStyle: { | 
					
						
							|  |  |  |                 backgroundColor: Color.primaryColor, | 
					
						
							|  |  |  |                 marginTop: 30, | 
					
						
							|  |  |  |                 color: 'white' | 
					
						
							|  |  |  |             }, | 
					
						
							|  |  |  |             headerTitleStyle: { | 
					
						
							|  |  |  |                 color: "white" | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |             title: I18n.t('ENVOIE_ARGENT'), | 
					
						
							|  |  |  |            | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     constructor(props) { | 
					
						
							|  |  |  |         super(props); | 
					
						
							|  |  |  |         this.state = { | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |             with_linked_card: true, | 
					
						
							|  |  |  |             scrollHeaderY: 0, | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |         this.scrollY = new Animated.Value(0); | 
					
						
							|  |  |  |         this.scrollHeaderY = new Animated.Value(0); | 
					
						
							|  |  |  |         this.deltaY = new Animated.Value(0); | 
					
						
							|  |  |  |         this.bgBannerY = new Animated.Value(0); | 
					
						
							|  |  |  |         IlinkEmitter.on("refreshWallet", this.refresh); | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     refresh = () => { | 
					
						
							|  |  |  |         readUser().then((user) => { | 
					
						
							|  |  |  |             if (user) { | 
					
						
							|  |  |  |                 if (user !== undefined) { | 
					
						
							|  |  |  |                     this.props.getWalletDetailActivated(user.id, null); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     render() { | 
					
						
							|  |  |  |         return ( | 
					
						
							|  |  |  |             <> | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  | {/* transactions */} | 
					
						
							|  |  |  | <View  style={styles.container}> | 
					
						
							|  |  |  |                        <Animated.View style={{ | 
					
						
							|  |  |  |                             position: 'absolute', | 
					
						
							|  |  |  |                             width: "100%", | 
					
						
							|  |  |  |                             zIndex: 1, | 
					
						
							|  |  |  |                            // backgroundColor: Color.primaryColor,
 | 
					
						
							|  |  |  |                             height: 140 - this.state.scrollHeaderY, | 
					
						
							|  |  |  |                             top: 40, | 
					
						
							|  |  |  |                         }}/> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <ScrollView ref={component => this._scrollView = component} | 
					
						
							|  |  |  |                 style={{ | 
					
						
							|  |  |  |                     paddingHorizontal: 20, position: 'absolute', | 
					
						
							|  |  |  |                     width: '100%', | 
					
						
							|  |  |  |                     height: '100%', | 
					
						
							|  |  |  |                     zIndex: 2 | 
					
						
							|  |  |  |                 }} | 
					
						
							|  |  |  |                 scrollEventThrottle={8} | 
					
						
							|  |  |  |                 onScroll={Animated.event([ | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                             nativeEvent: { | 
					
						
							|  |  |  |                                 contentOffset: {y: this.scrollY}, | 
					
						
							|  |  |  |                             }, | 
					
						
							|  |  |  |                         }, | 
					
						
							|  |  |  |                     ], | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         listener: (event) => { | 
					
						
							|  |  |  |                             this.setState({scrollHeaderY: event.nativeEvent.contentOffset.y}); | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |                         } | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |                     })}> | 
					
						
							|  |  |  |         <View style={[styles.checkDefault, {borderBottomColor: Color.borderColor}]}> | 
					
						
							|  |  |  |             <Text | 
					
						
							|  |  |  |                 style={[Typography.title3, Typography.semibold]}> | 
					
						
							|  |  |  |                 {I18n.t('TRANSACTIONS')} | 
					
						
							|  |  |  |             </Text> | 
					
						
							|  |  |  |         </View> | 
					
						
							|  |  |  |         <View style={styles.container}> | 
					
						
							|  |  |  |             <Text style={styles.subbigtitle}>Choisisez la carte que vous voulez utiliser. </Text> | 
					
						
							|  |  |  |             <View style={styles.transactionContainer}> | 
					
						
							|  |  |  |                 <View style={[styles.containerTouch]}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     <TouchableOpacity style={styles.contain} | 
					
						
							|  |  |  |                                     onPress={() => { | 
					
						
							|  |  |  |                                         this.props.navigation.push(route.carteLier, { | 
					
						
							|  |  |  |                                             optionSelect: optionenvoieautrewalletScreen, | 
					
						
							|  |  |  |                                             onGoBack: () => this.refresh(), | 
					
						
							|  |  |  |                                             lottie: { | 
					
						
							|  |  |  |                                                 source: require("./../../../datas/json/wallet_with_cash.json"), | 
					
						
							|  |  |  |                                                 loop: true | 
					
						
							|  |  |  |                                             } | 
					
						
							|  |  |  |                                         }) | 
					
						
							|  |  |  |                                     }} | 
					
						
							|  |  |  |                                     activeOpacity={0.9}> | 
					
						
							|  |  |  |                         <Icon name='arrow-bottom-right' | 
					
						
							|  |  |  |                             color={Color.primaryColor} | 
					
						
							|  |  |  |                             size={30} | 
					
						
							|  |  |  |                             style={styles.imageBanner}/> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         <View style={[styles.content]}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                             <View style={styles.contentTitle}> | 
					
						
							|  |  |  |                                 <Text style={[Typography.headline, Typography.semibold]}> | 
					
						
							|  |  |  |                                     {I18n.t('CARD_LINK')} | 
					
						
							|  |  |  |                                 </Text> | 
					
						
							|  |  |  |                             </View> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         </View> | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |                     </TouchableOpacity> | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |                 </View> | 
					
						
							|  |  |  |                 <View style={[styles.containerTouch]}> | 
					
						
							|  |  |  |                     <TouchableOpacity style={styles.contain} | 
					
						
							|  |  |  |                                         onPress={() => { | 
					
						
							|  |  |  |                                             this.props.navigation.push(route.autreCarte, { | 
					
						
							|  |  |  |                                                 optionSelect: optionenvoieautrewalletScreen, | 
					
						
							|  |  |  |                                                 onGoBack: () => this.refresh(), | 
					
						
							|  |  |  |                                                 lottie: { | 
					
						
							|  |  |  |                                                     source: require("./../../../datas/json/wallet_with_cash.json"), | 
					
						
							|  |  |  |                                                     loop: true | 
					
						
							|  |  |  |                                                 } | 
					
						
							|  |  |  |                                             }) | 
					
						
							|  |  |  |                                         }} | 
					
						
							|  |  |  |                                         activeOpacity={0.9}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         <Icon name='arrow-top-left' | 
					
						
							|  |  |  |                                 color={Color.primaryColor} | 
					
						
							|  |  |  |                                 size={30} | 
					
						
							|  |  |  |                                 style={styles.imageBanner}/> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         <View style={[styles.content]}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                             <View style={styles.contentTitle}> | 
					
						
							|  |  |  |                                 <Text style={[Typography.headline, Typography.semibold]}> | 
					
						
							|  |  |  |                                     {I18n.t('OTHER_CARD')} | 
					
						
							|  |  |  |                                 </Text> | 
					
						
							|  |  |  |                             </View> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |                         </View> | 
					
						
							|  |  |  |                     </TouchableOpacity> | 
					
						
							|  |  |  |                 </View> | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |             </View>       | 
					
						
							|  |  |  |         </View> | 
					
						
							|  |  |  |     </ScrollView> | 
					
						
							|  |  |  | </View> | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |         </> | 
					
						
							|  |  |  |     ); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-17 19:58:14 +00:00
										 |  |  | const styles = StyleSheet.create({ | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |     container: { | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |         backgroundColor: '#eee', | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |         flex: 1, | 
					
						
							|  |  |  |         justifyContent: 'center', | 
					
						
							|  |  |  |         alignItems: 'center', | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     checkDefault: { | 
					
						
							|  |  |  |         flexDirection: "row", | 
					
						
							|  |  |  |         justifyContent: "space-between", | 
					
						
							|  |  |  |         alignItems: "center", | 
					
						
							|  |  |  |         borderBottomWidth: 1, | 
					
						
							|  |  |  |         paddingVertical: 10, | 
					
						
							|  |  |  |         marginTop: 5 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     blockView: { | 
					
						
							|  |  |  |         paddingVertical: 10, | 
					
						
							|  |  |  |         borderBottomWidth: 0.5, | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |     circlePoint: { | 
					
						
							|  |  |  |         width: 50, | 
					
						
							|  |  |  |         height: 50, | 
					
						
							|  |  |  |         borderRadius: 25, | 
					
						
							|  |  |  |         marginRight: 5, | 
					
						
							|  |  |  |         alignItems: 'center', | 
					
						
							|  |  |  |         justifyContent: 'center', | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     transactionContainer: { | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |         flexDirection: 'row', | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |         flex: 1, | 
					
						
							|  |  |  |         paddingTop: 10, | 
					
						
							|  |  |  |         paddingLeft: 10, | 
					
						
							|  |  |  |         paddingRight: 10, | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |     containerTouch: { | 
					
						
							|  |  |  |         flex: 1, | 
					
						
							|  |  |  |         flexDirection: 'row', | 
					
						
							|  |  |  |         alignItems: 'center', | 
					
						
							|  |  |  |         marginRight: 1, | 
					
						
							|  |  |  |         shadowColor: Color.borderColor, | 
					
						
							|  |  |  |         borderColor: Color.borderColor, | 
					
						
							|  |  |  |         borderWidth: 0.5, | 
					
						
							|  |  |  |         shadowOffset: {width: 1.5, height: 1.5}, | 
					
						
							|  |  |  |         shadowOpacity: 1.0, | 
					
						
							|  |  |  |         elevation: 5, | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |         borderRadius: 10, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |         backgroundColor: Color.cardBackgroundColor | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     contain: { | 
					
						
							|  |  |  |         flexDirection: 'row', | 
					
						
							|  |  |  |         justifyContent: 'space-between', | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2023-10-05 06:09:30 +00:00
										 |  |  |     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: 5, | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  | }); | 
					
						
							| 
									
										
										
										
											2023-07-17 19:58:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-24 08:43:45 +00:00
										 |  |  | export default Modal; |