| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Sample React Native App | 
					
						
							|  |  |  |  * https://github.com/facebook/react-native
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @format | 
					
						
							|  |  |  |  * @flow | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | import React, { Component } from 'react'; | 
					
						
							|  |  |  | import { Platform, StyleSheet, Alert, FlatList, Text, View, TouchableOpacity, Linking } from 'react-native'; | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | import ActionButton from 'react-native-action-button'; | 
					
						
							|  |  |  | import Icon from 'react-native-vector-icons/Ionicons'; | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  | import { responsiveFontSize, responsiveHeight, responsiveWidth } from 'react-native-responsive-dimensions'; | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | import HeaderMenu from './HeaderMenu'; | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  | import { historiques as histo, first, useraccount, notification, configurations } from './../../route.json'; | 
					
						
							|  |  |  | import { primary, primaryDarkAdvanced } from './../../utils/theme.json'; | 
					
						
							|  |  |  | import { readUser, disconnect } from './../../webservice/AuthApi'; | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | import I18n from 'react-native-i18n' | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  | const route = require("./../../route.json") | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | require('./../../utils/Translations') | 
					
						
							|  |  |  | var DBEvents = require('react-native-db-models').DBEvents | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  | let theme = require('./../../utils/theme.json') | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | import Button from 'apsl-react-native-button' | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  | import { IlinkEmitter } from "./../../utils/events" | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | import { DrawerItems, SafeAreaView } from 'react-navigation'; | 
					
						
							|  |  |  | import DeviceInfo from "react-native-device-info" | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  | import AppContainer, { AppNavigator } from "../../App"; | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | import Configuration from "../../webservice/persistences/Configuration"; | 
					
						
							|  |  |  | import { ScrollView } from 'react-native-gesture-handler'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-30 21:58:22 +00:00
										 |  |  | export default class OptionsMenu extends Component { | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      static navigatorStyle = { | 
					
						
							|  |  |  |           statusBarColor: primaryDarkAdvanced, | 
					
						
							|  |  |  |      }; | 
					
						
							|  |  |  |      commandeListe | 
					
						
							|  |  |  |      constructor(props) { | 
					
						
							|  |  |  |           super(props); | 
					
						
							|  |  |  |           this.state = this.initState(); | 
					
						
							|  |  |  |           IlinkEmitter.on("menuLink", this.onMenuNavigationEvent.bind(this)) | 
					
						
							|  |  |  |           IlinkEmitter.on("userconnect", this.onUserConnect.bind(this)) | 
					
						
							|  |  |  |           IlinkEmitter.on("userdisconnect", this.hideSideMenu.bind(this)) | 
					
						
							|  |  |  |           IlinkEmitter.on("langueChange", this.updateLangue.bind(this)) | 
					
						
							|  |  |  |           this.configuration = new Configuration(); | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |           readUser().then((user) => { | 
					
						
							| 
									
										
										
										
											2020-05-19 07:57:56 +00:00
										 |  |  |                if (user !== null && user !== undefined) { | 
					
						
							|  |  |  |                     this.setState({ user }); | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                } | 
					
						
							|  |  |  |           }); | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      } | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      retrieveAndroidInformation() { | 
					
						
							|  |  |  |           this.configuration._getData().then((lang) => { | 
					
						
							|  |  |  |                if (lang) { | 
					
						
							|  |  |  |                     I18n.locale = lang | 
					
						
							|  |  |  |                     readUser().then((result) => { | 
					
						
							|  |  |  |                          setTimeout(() => { | 
					
						
							|  |  |  |                               this.updateUser(result); | 
					
						
							|  |  |  |                          }, 3000) | 
					
						
							|  |  |  |                     }) | 
					
						
							|  |  |  |                } else { | 
					
						
							|  |  |  |                     let code = DeviceInfo.getDeviceLocale(); | 
					
						
							|  |  |  |                     I18n.locale = code.toLowerCase() | 
					
						
							|  |  |  |                     readUser().then((result) => { | 
					
						
							|  |  |  |                          setTimeout(() => { | 
					
						
							|  |  |  |                               this.updateUser(result); | 
					
						
							|  |  |  |                          }, 3000) | 
					
						
							|  |  |  |                     }).catch((e) => { | 
					
						
							|  |  |  |                          this.props.navigation.navigate("Auth") | 
					
						
							|  |  |  |                     }); | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           }).catch((e) => { | 
					
						
							|  |  |  |                let code = DeviceInfo.getDeviceLocale() | 
					
						
							|  |  |  |                I18n.locale = code.toLowerCase() | 
					
						
							|  |  |  |                readUser().then((result) => { | 
					
						
							|  |  |  |                     setTimeout(() => { | 
					
						
							|  |  |  |                          this.updateUser(result); | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  |                     }, 3000) | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                }).catch((e) => { | 
					
						
							|  |  |  |                     this.props.navigation.navigate("Auth") | 
					
						
							|  |  |  |                }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |           }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |           return "" | 
					
						
							|  |  |  |      } | 
					
						
							| 
									
										
										
										
											2020-05-30 21:58:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      componentDidMount() { | 
					
						
							|  |  |  |           const items = this.props.navigation.router.childRouters.sta.childRouters; | 
					
						
							|  |  |  |           this.setState({ items: items }) | 
					
						
							|  |  |  |           this.retrieveAndroidInformation() | 
					
						
							| 
									
										
										
										
											2020-05-30 21:58:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      } | 
					
						
							|  |  |  |      updateLangue() { | 
					
						
							|  |  |  |           this.setState({ lang: "change" }) | 
					
						
							|  |  |  |           this.forceUpdate() | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      componentWillUnmount() { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      onMenuNavigationEvent(menuOption) { | 
					
						
							|  |  |  |           /* Navigation.mergeOptions(this.props.componentId,{ | 
					
						
							|  |  |  |                sideMenu: { | 
					
						
							|  |  |  |                    left: { | 
					
						
							|  |  |  |                        visible: false, | 
					
						
							|  |  |  |                    } | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |            }) | 
					
						
							|  |  |  |           switch (menuOption){ | 
					
						
							|  |  |  |                case "home":{ | 
					
						
							|  |  |  |                    this.setState({currentId:0}) | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |                    break; | 
					
						
							|  |  |  |                case "userInfo":{ | 
					
						
							|  |  |  |                    this.setState({currentId:1}) | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |            }*/ | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      onUserConnect() { | 
					
						
							|  |  |  |           readUser().then((user) => { | 
					
						
							|  |  |  |                if (user !== null && user !== undefined) { | 
					
						
							|  |  |  |                     this.updateUser(user); | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           }); | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      onNavigatorEvent(event) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      hideSideMenu() { | 
					
						
							|  |  |  |           /*  Navigation.mergeOptions("drawer", { | 
					
						
							|  |  |  |                 sideMenu: { | 
					
						
							|  |  |  |                     left: { | 
					
						
							|  |  |  |                         visible: false, | 
					
						
							|  |  |  |                         enabled:false | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |             });*/ | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      initState() { | 
					
						
							|  |  |  |           return { | 
					
						
							|  |  |  |                user: null, | 
					
						
							|  |  |  |                menu: [], | 
					
						
							|  |  |  |                currentId: 0, | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      } | 
					
						
							|  |  |  |      getGeolocatedUserMenu() { | 
					
						
							|  |  |  |           return [ | 
					
						
							|  |  |  |                { title: I18n.t('MAP'), id: 0, key: 0, icon: 'md-map', active: true } | 
					
						
							|  |  |  |                , { title: I18n.t('MY_ACCOUNT'), id: 1, key: 1, icon: 'md-person', active: false } | 
					
						
							| 
									
										
										
										
											2020-04-11 22:33:59 +00:00
										 |  |  |                , { title: I18n.t('WALLET'), id: 6, key: 6, icon: 'md-wallet-outline', active: false } | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                , { title: I18n.t('CREDIT_MANAGE'), id: 2, key: 2, icon: 'md-card', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('ADD_NETWORK'), id: 11, key: 11, icon: 'md-people', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('CHANGE_INFORMATION'), id: 13, key: 13, icon: 'md-person', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('NOTIFICATIONS'), id: 3, key: 3, icon: 'md-notifications', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('CONFIGURATIONS'), id: 4, icon: 'md-settings', active: false }] | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      getSuperUserMenu() { | 
					
						
							|  |  |  |           return [ | 
					
						
							|  |  |  |                { title: I18n.t('MAP'), id: 0, key: 0, icon: 'md-map', active: true } | 
					
						
							|  |  |  |                , { title: I18n.t('MY_ACCOUNT'), id: 1, key: 1, icon: 'md-person', active: false } | 
					
						
							| 
									
										
										
										
											2020-04-11 22:33:59 +00:00
										 |  |  |                , { title: I18n.t('WALLET'), id: 6, key: 6, icon: 'md-wallet-outline', active: false } | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                , { title: I18n.t('CREDIT_MANAGE'), id: 2, key: 2, icon: 'md-card', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('GROUP_MANAGE'), id: 5, key: 5, icon: 'md-people', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('NOTIFICATIONS'), id: 3, key: 3, icon: 'md-notifications', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('CONFIGURATIONS'), id: 4, icon: 'md-settings', active: false }] | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      getHyperUsermenu() { | 
					
						
							|  |  |  |           return [ | 
					
						
							|  |  |  |                { title: I18n.t('MAP'), id: 0, key: 0, icon: 'md-map', active: true } | 
					
						
							|  |  |  |                , { title: I18n.t('MY_ACCOUNT'), id: 1, key: 1, icon: 'md-person', active: false } | 
					
						
							| 
									
										
										
										
											2020-04-11 22:33:59 +00:00
										 |  |  |                , { title: I18n.t('WALLET'), id: 6, key: 6, icon: 'md-wallet-outline', active: false } | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                , { title: I18n.t('CREDIT_MANAGE'), id: 2, key: 2, icon: 'md-card', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('GROUP_MANAGE'), id: 5, key: 5, icon: 'md-people', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('NOTIFICATIONS'), id: 3, key: 3, icon: 'md-notifications', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('CONFIGURATIONS'), id: 4, icon: 'md-settings', active: false }] | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      updateUser(user) { | 
					
						
							|  |  |  |           let menu = []; | 
					
						
							|  |  |  |           if (user !== undefined) { | 
					
						
							|  |  |  |                /*  Navigation.mergeOptions("drawer", { | 
					
						
							|  |  |  |                      sideMenu: { | 
					
						
							|  |  |  |                          left: { | 
					
						
							|  |  |  |                              visible: false, | 
					
						
							|  |  |  |                              enabled:true | 
					
						
							|  |  |  |                          } | 
					
						
							|  |  |  |                      } | 
					
						
							|  |  |  |                  });*/ | 
					
						
							|  |  |  |                if (user.category !== undefined) { | 
					
						
							|  |  |  |                     switch (user.category) { | 
					
						
							|  |  |  |                          case "geolocated": | 
					
						
							|  |  |  |                               menu = this.getGeolocatedUserMenu(); | 
					
						
							|  |  |  |                               break; | 
					
						
							|  |  |  |                          case "super": | 
					
						
							|  |  |  |                               menu = this.getSuperUserMenu(); | 
					
						
							|  |  |  |                               break; | 
					
						
							|  |  |  |                          case "hyper": | 
					
						
							|  |  |  |                               menu = this.getHyperUsermenu(); | 
					
						
							|  |  |  |                               break; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                } else { | 
					
						
							|  |  |  |                     menu = this.getUserMenu(); | 
					
						
							|  |  |  |                } | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |           this.setState({ user: user, menu: menu }); | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      getUserMenu() { | 
					
						
							|  |  |  |           return [ | 
					
						
							|  |  |  |                { title: I18n.t('MAP'), id: 0, key: 0, icon: 'md-map', active: true } | 
					
						
							|  |  |  |                , { title: I18n.t('MY_ACCOUNT'), id: 1, key: 1, icon: 'md-person', active: false } | 
					
						
							| 
									
										
										
										
											2020-05-30 21:58:22 +00:00
										 |  |  |                , { title: I18n.t('WALLET'), id: 6, key: 6, icon: 'md-wallet-outline', active: false } | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                , { title: I18n.t('NOTIFICATIONS'), id: 3, key: 3, icon: 'md-notifications', active: false } | 
					
						
							|  |  |  |                , { title: I18n.t('CONFIGURATIONS'), id: 4, icon: 'md-settings', active: false }] | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |      } | 
					
						
							|  |  |  |      redirectToScreen = (item) => { | 
					
						
							|  |  |  |           console.log("Item Menu Click", item); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  |           if (this.state.user === null) | 
					
						
							|  |  |  |                return; | 
					
						
							|  |  |  |           else { | 
					
						
							|  |  |  |                switch (this.state.user.category) { | 
					
						
							|  |  |  |                     case "super": | 
					
						
							|  |  |  |                          if (item === "walletSelect") | 
					
						
							|  |  |  |                               item = "walletDetail"; | 
					
						
							|  |  |  |                          this.props.navigation.navigate(item, { agentId: this.state.user.agentId }); | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  |                          break; | 
					
						
							|  |  |  |                     case "hyper": | 
					
						
							|  |  |  |                          if (item === "walletSelect") | 
					
						
							|  |  |  |                               item = "walletDetail"; | 
					
						
							|  |  |  |                          this.props.navigation.navigate(item, { agentId: this.state.user.agentId }); | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  |                          break; | 
					
						
							| 
									
										
										
										
											2020-05-30 21:58:22 +00:00
										 |  |  |                     case "geolocated": | 
					
						
							|  |  |  |                          this.props.navigation.navigate(item); | 
					
						
							|  |  |  |                          break; | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  |                     default: | 
					
						
							| 
									
										
										
										
											2020-05-30 21:58:22 +00:00
										 |  |  |                          if (item === "walletSelect") | 
					
						
							|  |  |  |                               item = "walletDetailUser"; | 
					
						
							|  |  |  |                          this.props.navigation.navigate(item, { userId: this.state.user.id }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-24 15:11:08 +00:00
										 |  |  |                          break; | 
					
						
							|  |  |  |                } | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      } | 
					
						
							|  |  |  |      _renderItem = (item) => { | 
					
						
							| 
									
										
										
										
											2020-06-02 09:05:50 +00:00
										 |  |  |           if (item === "creditrequest" || item === 'historyItemDetails' || item === 'filter' || item === 'networks' || item === 'walletDetail' || item === 'walletDetailUser' | 
					
						
							|  |  |  |                || item === 'walletDepot' || item === 'walletRetrait' || item === 'createIdentification' || item === 'walletOptionSelect') { | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                return null | 
					
						
							|  |  |  |           } else { | 
					
						
							|  |  |  |                const color = this.state.currentId === item.id ? theme.accent : "grey" | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                //console.log("ITEM OPTION MENU", item);
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                return ( | 
					
						
							|  |  |  |                     <TouchableOpacity onPress={() => { | 
					
						
							|  |  |  |                          this.props.navigation.toggleDrawer(); | 
					
						
							| 
									
										
										
										
											2020-04-20 10:43:01 +00:00
										 |  |  |                          this.setState({ currentId: item.id }); | 
					
						
							|  |  |  |                          this.redirectToScreen(item); | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                     }} | 
					
						
							|  |  |  |                     > | 
					
						
							|  |  |  |                          <View | 
					
						
							|  |  |  |                               style={items.content} | 
					
						
							|  |  |  |                          > | 
					
						
							|  |  |  |                               <Icon | 
					
						
							|  |  |  |                                    name={this.getIcon(item)} | 
					
						
							|  |  |  |                                    size={32} | 
					
						
							|  |  |  |                               /> | 
					
						
							|  |  |  |                               <Text style={{ | 
					
						
							|  |  |  |                                    marginLeft: 20, | 
					
						
							|  |  |  |                                    fontSize: 16, | 
					
						
							|  |  |  |                               }}>{this.getNameItems(item)} | 
					
						
							|  |  |  |                               </Text> | 
					
						
							|  |  |  |                          </View></TouchableOpacity>) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      }; | 
					
						
							|  |  |  |      _onPress = ((item) => { | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |           this.setState({ currentId: item.id }) | 
					
						
							|  |  |  |           let current = this.state.menu.filter((item) => { return item.active })[0] | 
					
						
							|  |  |  |           current.active = false; | 
					
						
							|  |  |  |           item.active = true; | 
					
						
							|  |  |  |           let newMenu = []; | 
					
						
							|  |  |  |           this.state.menu.forEach(function (it) { | 
					
						
							|  |  |  |                if (it.id === current.id) newMenu.push(current) | 
					
						
							|  |  |  |                else if (it.id === item.id) newMenu.push(item) | 
					
						
							|  |  |  |                else newMenu.push(it) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |           this.setState({ menu: newMenu }) | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  |        /*    switch(item.id){ | 
					
						
							|  |  |  |                case 2: | 
					
						
							|  |  |  |                   Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                     component: { | 
					
						
							|  |  |  |                         name: histo, | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                       options: { | 
					
						
							|  |  |  |                           topBar: { | 
					
						
							|  |  |  |                               title: { | 
					
						
							|  |  |  |                                   text: I18n.t('CREDIT_MANAGE') | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  |                           } | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |               }); | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |                case 0: | 
					
						
							|  |  |  |                    Navigation.popToRoot(route.stackRoot) | 
					
						
							|  |  |  |                   IlinkEmitter.emit("menuLink","home"); | 
					
						
							|  |  |  |                break; | 
					
						
							|  |  |  |                case 1: | 
					
						
							|  |  |  |                    Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                        component: { | 
					
						
							|  |  |  |                            name:useraccount, | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |                        options: { | 
					
						
							|  |  |  |                            sideMenu:{ | 
					
						
							|  |  |  |                                visibility:false | 
					
						
							|  |  |  |                            }, | 
					
						
							|  |  |  |                            topBar: { | 
					
						
							|  |  |  |                                title: { | 
					
						
							|  |  |  |                                    text:I18n.t('MY_ACCOUNT') | 
					
						
							|  |  |  |                                }, | 
					
						
							|  |  |  |                                hideOnScroll: true, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                            } | 
					
						
							|  |  |  |                        } | 
					
						
							|  |  |  |                    }); | 
					
						
							|  |  |  |                    IlinkEmitter.emit("menuLink","userInfo"); | 
					
						
							|  |  |  |                   break; | 
					
						
							|  |  |  |               case 3: | 
					
						
							|  |  |  |                   Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                       component: { | 
					
						
							|  |  |  |                           name:notification, | 
					
						
							|  |  |  |                       }, | 
					
						
							|  |  |  |                       options: { | 
					
						
							|  |  |  |                           topBar: { | 
					
						
							|  |  |  |                               title: { | 
					
						
							|  |  |  |                                   text:I18n.t('NOTIFICATION') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  |                           } | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                   }); | 
					
						
							|  |  |  |                   IlinkEmitter.emit("menuLink","notification"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   break; | 
					
						
							|  |  |  |               case 4: | 
					
						
							|  |  |  |                   Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                       component: { | 
					
						
							|  |  |  |                           name:configurations, | 
					
						
							|  |  |  |                       }, | 
					
						
							|  |  |  |                       options: { | 
					
						
							|  |  |  |                           topBar: { | 
					
						
							|  |  |  |                               title: { | 
					
						
							|  |  |  |                                   text:I18n.t('CONFIGURATIONS') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  |                           } | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                   }); | 
					
						
							|  |  |  |                   IlinkEmitter.emit("menuLink","config"); | 
					
						
							|  |  |  |                   break; | 
					
						
							|  |  |  |               case 5: | 
					
						
							|  |  |  |                   Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                       component: { | 
					
						
							|  |  |  |                           name:route.superviseurgroup, | 
					
						
							|  |  |  |                       }, | 
					
						
							|  |  |  |                       options: { | 
					
						
							|  |  |  |                           topBar: { | 
					
						
							|  |  |  |                               title: { | 
					
						
							|  |  |  |                                   text:I18n.t('GROUP_MANAGE') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               } | 
					
						
							|  |  |  |                           } | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                   }); | 
					
						
							|  |  |  |                   IlinkEmitter.emit("menuLink","manage_group"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   break; | 
					
						
							|  |  |  |               case 7:     Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                   component: { | 
					
						
							|  |  |  |                       name:route.credrequester, | 
					
						
							|  |  |  |                   }, | 
					
						
							|  |  |  |                   options: { | 
					
						
							|  |  |  |                       topBar: { | 
					
						
							|  |  |  |                         visible:false | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                   } | 
					
						
							|  |  |  |               }); | 
					
						
							|  |  |  |                   break; | 
					
						
							|  |  |  |               case 11: | 
					
						
							|  |  |  |                   Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                       component: { | 
					
						
							|  |  |  |                           name:route.addNetwork, | 
					
						
							|  |  |  |                       }, | 
					
						
							|  |  |  |                       options: { | 
					
						
							|  |  |  |                           topBar: { | 
					
						
							|  |  |  |                               visible:false | 
					
						
							|  |  |  |                           } | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                   }); | 
					
						
							|  |  |  |                   break; | 
					
						
							|  |  |  |               case 12: | 
					
						
							|  |  |  |                   Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                       component: { | 
					
						
							|  |  |  |                           name:route.generateNetwork, | 
					
						
							|  |  |  |                       }, | 
					
						
							|  |  |  |                       options: { | 
					
						
							|  |  |  |                           topBar: { | 
					
						
							|  |  |  |                               visible:false | 
					
						
							|  |  |  |                           } | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                   }); | 
					
						
							|  |  |  |                   break; | 
					
						
							|  |  |  |               case 13: | 
					
						
							|  |  |  |                   Navigation.push(route.stackRoot,{ | 
					
						
							|  |  |  |                       component: { | 
					
						
							|  |  |  |                           name:route.updateinfo, | 
					
						
							|  |  |  |                       }, | 
					
						
							|  |  |  |                       options: { | 
					
						
							|  |  |  |                           topBar: { | 
					
						
							|  |  |  |                               visible:false | 
					
						
							|  |  |  |                           } | 
					
						
							|  |  |  |                       } | 
					
						
							|  |  |  |                   }); | 
					
						
							|  |  |  |           }; | 
					
						
							|  |  |  |             Navigation.mergeOptions(this.props.componentId,{ | 
					
						
							|  |  |  |                 sideMenu: { | 
					
						
							|  |  |  |                     left: { | 
					
						
							|  |  |  |                         visible: false, | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |      */ }); | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      getNameItems(item) { | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |           let icon = item | 
					
						
							|  |  |  |           switch (item) { | 
					
						
							|  |  |  |                case "home": icon = I18n.t('MAP') | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case 'useraccount': icon = I18n.t('MY_ACCOUNT') | 
					
						
							|  |  |  |                     break | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  |                case 'walletSelect': icon = I18n.t('WALLET') | 
					
						
							| 
									
										
										
										
											2020-04-11 22:33:59 +00:00
										 |  |  |                     break | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                case 'Historique': icon = I18n.t('CREDIT_MANAGE') | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case "superviseurgroup": icon = I18n.t('GROUP_MANAGE') | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case "updateinformation": icon = I18n.t("CHANGE_INFORMATION") | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case 'notificationview': icon = I18n.t('NOTIFICATIONS') | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case 'configuration': icon = I18n.t('CONFIGURATIONS') | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                case 'addNetwork': icon = I18n.t('ADD_NETWORK') | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case 'about': icon = I18n.t('ABOUT') | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           return icon; | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      getIcon(item) { | 
					
						
							|  |  |  |           let icon = "md-map" | 
					
						
							|  |  |  |           switch (item) { | 
					
						
							|  |  |  |                case "home": icon = "md-map" | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case 'useraccount': icon = "md-person" | 
					
						
							|  |  |  |                     break | 
					
						
							| 
									
										
										
										
											2020-04-17 22:03:04 +00:00
										 |  |  |                case 'walletSelect': icon = "md-wallet" | 
					
						
							| 
									
										
										
										
											2020-04-11 22:33:59 +00:00
										 |  |  |                     break | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                case 'Historique': icon = "md-card" | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case "superviseurgroup": icon = "md-people" | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case 'notificationview': icon = "md-notifications"; | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case "updateinformation": icon = "md-people" | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case 'configuration': icon = 'md-settings' | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |                case 'addNetwork': icon = "md-people" | 
					
						
							|  |  |  |                     break | 
					
						
							|  |  |  |                case 'about': icon = 'md-contacts'; | 
					
						
							|  |  |  |                     break; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           return icon; | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      render() { | 
					
						
							|  |  |  |           var name = this.state.user ? this.state.user.firstname : ""; | 
					
						
							|  |  |  |           const surname = this.state.user ? this.state.user.lastname : ""; | 
					
						
							|  |  |  |           if (!this.state.lang && this.state.lang !== "change") | 
					
						
							|  |  |  |                return ( | 
					
						
							|  |  |  |                     <View style={styles.container}> | 
					
						
							|  |  |  |                          <View | 
					
						
							|  |  |  |                               style={styles.headercontent} | 
					
						
							|  |  |  |                          > | 
					
						
							|  |  |  |                               <Text style={styles.headerTitle}>{name}</Text> | 
					
						
							|  |  |  |                               <Text style={styles.headerTitle}>{surname}</Text> | 
					
						
							|  |  |  |                               <Text style={styles.headerPhone}>{this.state.user ? "" + this.state.user.phone : ""}</Text> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                          <ScrollView style={{ | 
					
						
							|  |  |  |                               flex: 1, height: responsiveHeight(40) | 
					
						
							|  |  |  |                          }} > | 
					
						
							|  |  |  |                               <SafeAreaView forceInset={{ top: 'always', horizontal: 'never' }}> | 
					
						
							|  |  |  |                                    { | 
					
						
							|  |  |  |                                         this.state.items && Object.keys(this.state.items).map((item, key) => { | 
					
						
							|  |  |  |                                              return this._renderItem(item) | 
					
						
							|  |  |  |                                         }) | 
					
						
							|  |  |  |                                    } | 
					
						
							|  |  |  |                               </SafeAreaView> | 
					
						
							|  |  |  |                          </ScrollView> | 
					
						
							|  |  |  |                          <Button | 
					
						
							|  |  |  |                               textStyle={styles.btntext} | 
					
						
							|  |  |  |                               style={styles.btnDeconnect} | 
					
						
							|  |  |  |                               onPress={() => this.userDeconnect()} | 
					
						
							|  |  |  |                          >{I18n.t('DISCONNEXION')}</Button> | 
					
						
							|  |  |  |                     </View> | 
					
						
							|  |  |  |                ) | 
					
						
							|  |  |  |           else { | 
					
						
							|  |  |  |                setTimeout(() => this.setState({ lang: "" }), 500) | 
					
						
							|  |  |  |                return (<View />) | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      userDeconnect() { | 
					
						
							|  |  |  |           Alert.alert( | 
					
						
							|  |  |  |                I18n.t('DISCONNEXION'), | 
					
						
							|  |  |  |                I18n.t('DISCONNEXION_TEXT'), | 
					
						
							|  |  |  |                [ | 
					
						
							|  |  |  |                     {}, | 
					
						
							|  |  |  |                     { text: I18n.t('NO'), onPress: () => console.log('Cancel Pressed'), style: 'cancel' }, | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                          text: I18n.t('YES'), onPress: () => { | 
					
						
							|  |  |  |                               disconnect().then(() => { | 
					
						
							|  |  |  |                                    IlinkEmitter.emit("userdisconnect"); | 
					
						
							|  |  |  |                                    this.props.navigation.navigate("Auth") | 
					
						
							|  |  |  |                               }) | 
					
						
							|  |  |  |                          } | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                ], | 
					
						
							|  |  |  |                { cancelable: false } | 
					
						
							|  |  |  |           ) | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |      watchUser() { | 
					
						
							|  |  |  |           readUser().then((user) => { | 
					
						
							| 
									
										
										
										
											2020-05-19 07:57:56 +00:00
										 |  |  |                if (user !== null && user !== undefined) { | 
					
						
							|  |  |  |                     if (user.id !== this.state.user.id) { | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |                          this.updateUser(user); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           }); | 
					
						
							|  |  |  |      } | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  | const items = StyleSheet.create({ | 
					
						
							|  |  |  |      content: { | 
					
						
							|  |  |  |           width: responsiveWidth(100), | 
					
						
							|  |  |  |           height: 50, | 
					
						
							|  |  |  |           paddingLeft: 20, | 
					
						
							|  |  |  |           flexDirection: 'row', | 
					
						
							|  |  |  |           alignItems: 'center' | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      itemText: { | 
					
						
							|  |  |  |           color: '#000000', | 
					
						
							|  |  |  |           marginLeft: 20, | 
					
						
							|  |  |  |           fontSize: responsiveFontSize(2), | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | }); | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | const styles = StyleSheet.create({ | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      container: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           backgroundColor: "white", | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      btnDeconnect: { | 
					
						
							|  |  |  |           borderColor: "transparent", | 
					
						
							|  |  |  |           marginLeft: 20, | 
					
						
							|  |  |  |           marginRight: 20, | 
					
						
							|  |  |  |           backgroundColor: theme.accent | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      btntext: { | 
					
						
							|  |  |  |           color: "white", | 
					
						
							|  |  |  |           fontSize: 17, | 
					
						
							|  |  |  |           fontWeight: "bold" | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      headerTitle: { | 
					
						
							|  |  |  |           fontSize: 14, | 
					
						
							|  |  |  |           marginBottom: 5, | 
					
						
							|  |  |  |           color: "white", | 
					
						
							|  |  |  |           fontWeight: 'bold', | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      headerPhone: { | 
					
						
							|  |  |  |           fontSize: 12, | 
					
						
							|  |  |  |           marginBottom: 20, | 
					
						
							|  |  |  |           color: "white", | 
					
						
							|  |  |  |           justifyContent: 'flex-end' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      listMenu: { | 
					
						
							|  |  |  |           paddingTop: 15, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      headercontent: { | 
					
						
							|  |  |  |           height: responsiveHeight(30), | 
					
						
							|  |  |  |           backgroundColor: primary, | 
					
						
							|  |  |  |           justifyContent: 'flex-end', | 
					
						
							|  |  |  |           alignItems: 'flex-start', | 
					
						
							|  |  |  |           paddingLeft: 20 | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 18:28:22 +00:00
										 |  |  |      }, | 
					
						
							|  |  |  |      backgroundd_drawer: { | 
					
						
							|  |  |  |           backgroundColor: '#000', | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      listbackground: { | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      actionButtonIcon: { | 
					
						
							|  |  |  |           fontSize: 20, | 
					
						
							|  |  |  |           height: 22, | 
					
						
							|  |  |  |           color: 'white', | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      welcome: { | 
					
						
							|  |  |  |           fontSize: 20, | 
					
						
							|  |  |  |           textAlign: 'center', | 
					
						
							|  |  |  |           margin: 10, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      instructions: { | 
					
						
							|  |  |  |           textAlign: 'center', | 
					
						
							|  |  |  |           color: '#333333', | 
					
						
							|  |  |  |           marginBottom: 5, | 
					
						
							|  |  |  |      }, | 
					
						
							| 
									
										
										
										
											2019-06-16 13:09:54 +00:00
										 |  |  | }); |