| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | import React, { Component } from 'react'; | 
					
						
							|  |  |  | import { | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      Alert, | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      Platform, | 
					
						
							|  |  |  |      StyleSheet, | 
					
						
							|  |  |  |      AppState, | 
					
						
							|  |  |  |      FlatList, | 
					
						
							|  |  |  |      ProgressBarAndroid, | 
					
						
							|  |  |  |      TouchableOpacity, | 
					
						
							|  |  |  |      Text, | 
					
						
							|  |  |  |      View, | 
					
						
							|  |  |  |      Animated, | 
					
						
							|  |  |  |      StatusBar | 
					
						
							|  |  |  | } from 'react-native'; | 
					
						
							|  |  |  | import ActionButton from 'react-native-action-button'; | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  | import Icon from 'react-native-vector-icons/MaterialCommunityIcons'; | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | import { responsiveFontSize, responsiveHeight, responsiveWidth } from 'react-native-responsive-dimensions'; | 
					
						
							|  |  |  | import { HistoryListItem, HistoryItemSectionned } from '../history-request/HistoryItem'; | 
					
						
							|  |  |  | import { credrequester } from './../../route.json'; | 
					
						
							|  |  |  | import { loadDemandeCredit, loadMyDemandeCredit } from './../../webservice/HistoryRequestApi'; | 
					
						
							|  |  |  | import FontAwesome5 from 'react-native-vector-icons/FontAwesome5'; | 
					
						
							|  |  |  | import BaseScreen from './../../screens/BaseScreen' | 
					
						
							|  |  |  | import Button from 'apsl-react-native-button' | 
					
						
							|  |  |  | import { readUser } from "../../webservice/AuthApi"; | 
					
						
							|  |  |  | import Calendar from 'react-native-calendario'; | 
					
						
							|  |  |  | let route = require('./../../route.json') | 
					
						
							|  |  |  | import 'moment'; | 
					
						
							|  |  |  | 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' | 
					
						
							|  |  |  | import moment from 'moment-timezone'; | 
					
						
							|  |  |  | let theme = require('./../../utils/theme.json') | 
					
						
							|  |  |  | import { primary, primaryDark, accent, purpleLight, primaryLight } from './../../utils/theme.json'; | 
					
						
							|  |  |  | import { PagerTabIndicator, PagerTitleIndicator, PagerDotIndicator } from 'react-native-best-viewpager' | 
					
						
							|  |  |  | var sortIcons; | 
					
						
							|  |  |  | var sectionIcons; | 
					
						
							|  |  |  | import I18n from 'react-native-i18n' | 
					
						
							|  |  |  | require('./../../utils/Translations') | 
					
						
							|  |  |  | import { SinglePickerMaterialDialog } from 'react-native-material-dialog'; | 
					
						
							|  |  |  | import { Header } from "react-native-elements"; | 
					
						
							|  |  |  | import { withNavigationFocus } from "react-navigation"; | 
					
						
							|  |  |  | import IconWithBadge from "../IconWithBadge"; | 
					
						
							|  |  |  | import { Appbar, Paragraph, Menu, Divider, Provider } from 'react-native-paper'; | 
					
						
							|  |  |  | import DeviceInfo from 'react-native-device-info' | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  | import { bindActionCreators } from 'redux'; | 
					
						
							|  |  |  | import { connect } from 'react-redux'; | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  | import { getNanoCreditDemandsAction, getNanoCreditDemandsReset } from '../../webservice/user/NanoCreditApi'; | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  | import { IlinkEmitter } from '../../utils/events'; | 
					
						
							|  |  |  | import { Typography } from '../../config/typography'; | 
					
						
							|  |  |  | import { ScrollView } from 'react-native-gesture-handler'; | 
					
						
							|  |  |  | import { Color } from '../../config/Color'; | 
					
						
							| 
									
										
										
										
											2020-08-25 05:39:28 +00:00
										 |  |  | import { color } from 'react-native-reanimated'; | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class DemandValidationGroup extends React.Component { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      constructor(props) { | 
					
						
							|  |  |  |           super(props, true); | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           this.state = { | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |                user: {}, | 
					
						
							|  |  |  |                conserve: [], | 
					
						
							|  |  |  |                count: 0, | 
					
						
							|  |  |  |                translateAnim: new Animated.Value(0), | 
					
						
							|  |  |  |                visibleMenu: false, | 
					
						
							|  |  |  |                appState: AppState.currentState, | 
					
						
							|  |  |  |                filter: false, | 
					
						
							|  |  |  |                sortIcons: null, | 
					
						
							|  |  |  |                panelVisible: false, | 
					
						
							|  |  |  |                filder_disable: true, | 
					
						
							|  |  |  |                datestartformated: 'La date de debut', | 
					
						
							|  |  |  |                dateendformated: 'La date de fin', | 
					
						
							|  |  |  |                datestart: null, | 
					
						
							|  |  |  |                dateend: null, | 
					
						
							|  |  |  |                isLoaded: false, | 
					
						
							|  |  |  |                isSectionned: false, | 
					
						
							|  |  |  |                isDateTimePickerVisible: false, | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                isDateEndTimePickerVisible: false, | 
					
						
							| 
									
										
										
										
											2020-09-30 05:46:30 +00:00
										 |  |  |                isDataSubmit: false, | 
					
						
							|  |  |  |                position: 0 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           }; | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |           readUser().then((user) => { | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                this.setState({ user: user }); | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                this.props.getNanoCreditDemandsAction(user.id); | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           }); | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           this.props.getNanoCreditDemandsReset(); | 
					
						
							|  |  |  |           this.navigation = this.props.navigation | 
					
						
							|  |  |  |           this.currentLocale = DeviceInfo.getDeviceLocale().includes("fr") ? "fr" : "en-gb"; | 
					
						
							|  |  |  |           //moment.locale(this.currentLocale);
 | 
					
						
							| 
									
										
										
										
											2020-08-19 03:53:12 +00:00
										 |  |  |           //IlinkEmitter.on('treatNanoGroupDemand', this.refreshData);
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      }; | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-24 19:18:19 +00:00
										 |  |  |      static navigatorStyle = { | 
					
						
							|  |  |  |           navBarBackgroundColor: primary, | 
					
						
							|  |  |  |           statusBarColor: primaryDark, | 
					
						
							|  |  |  |           navBarTextColor: '#FFFFFF', | 
					
						
							|  |  |  |           navBarButtonColor: '#FFFFFF', | 
					
						
							|  |  |  |           contextualMenuStatusBarColor: theme.accent, | 
					
						
							|  |  |  |           contextualMenuBackgroundColor: theme.accentLight, | 
					
						
							|  |  |  |           contextualMenuButtonsColor: '#ffffff' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      componentDidMount() { | 
					
						
							|  |  |  |           const { routeName } = this.navigation.state | 
					
						
							| 
									
										
										
										
											2020-08-24 19:18:19 +00:00
										 |  |  |           this.setState({ | 
					
						
							|  |  |  |                position: routeName === "demandeValidationGroupe" ? 0 | 
					
						
							|  |  |  |                     : routeName === "myNanoCreditGroup" ? 1 | 
					
						
							|  |  |  |                          : 2 | 
					
						
							|  |  |  |           }); | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |           this.animateSlidingUp(false) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      componentWillUnmount() { | 
					
						
							|  |  |  |           clearInterval(this.intervaller) | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-19 06:25:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      animateSlidingUp(state = false) { | 
					
						
							|  |  |  |           const height = responsiveHeight(100) | 
					
						
							|  |  |  |           let initialValue = !state ? 0 : height, | 
					
						
							|  |  |  |                finalValue = !state ? height : 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           this.setState({ isSliding: state }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           this.state.translateAnim.setValue(initialValue);  //Step 3
 | 
					
						
							|  |  |  |           Animated.timing(     //Step 4
 | 
					
						
							|  |  |  |                this.state.translateAnim, | 
					
						
							|  |  |  |                { | 
					
						
							|  |  |  |                     toValue: finalValue, | 
					
						
							|  |  |  |                     duration: 500, | 
					
						
							|  |  |  |                     useNativeDriver: true, | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |           ).start() | 
					
						
							|  |  |  |      } | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      _openMenu = () => this.setState({ visibleMenu: true }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      _closeMenu = () => this.setState({ visibleMenu: false }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-25 05:39:28 +00:00
										 |  |  |      getDemandTypeIcon = (type) => { | 
					
						
							|  |  |  |           switch (type) { | 
					
						
							|  |  |  |                case 'creation': return 'account-multiple-plus'; | 
					
						
							|  |  |  |                case 'suppression': return 'account-multiple-minus'; | 
					
						
							|  |  |  |                case 'adhesion': return 'account-multiple-check' | 
					
						
							|  |  |  |                case 'nano_credit': return 'cash' | 
					
						
							|  |  |  |                default: return 'account-multiple' | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      getDemandTypeColor = (type) => { | 
					
						
							|  |  |  |           switch (type) { | 
					
						
							|  |  |  |                case 'creation': return 'green'; | 
					
						
							|  |  |  |                case 'suppression': return 'red'; | 
					
						
							|  |  |  |                case 'adhesion': return Color.primaryColor | 
					
						
							|  |  |  |                case 'nano_credit': return Color.primaryColor | 
					
						
							|  |  |  |                default: | 
					
						
							|  |  |  |                     return Color.primaryColor | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      renderDemandItem = (item) => { | 
					
						
							| 
									
										
										
										
											2020-08-25 05:39:28 +00:00
										 |  |  |           let dateFormat = moment.tz(item.date_creation_demande, 'Etc/GMT+0').format(); | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           dateFormat = moment(dateFormat).fromNow(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |           return ( | 
					
						
							| 
									
										
										
										
											2020-08-13 05:17:57 +00:00
										 |  |  |                <TouchableOpacity onPress={() => { | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                     this.props.navigation.push(route.demandGroupNanoCreditDetail, { | 
					
						
							|  |  |  |                          id: item.id | 
					
						
							|  |  |  |                     }); | 
					
						
							| 
									
										
										
										
											2020-08-25 05:39:28 +00:00
										 |  |  |                }} | 
					
						
							|  |  |  |                     style={[styles.paymentItem]}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     <View style={{ flexDirection: 'row', alignItems: 'center', }}> | 
					
						
							|  |  |  |                          <View style={styles.iconContent}> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                               <Icon name={this.getDemandTypeIcon(item.type)} color={this.getDemandTypeColor(item.type)} size={35} /> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                     </View> | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                     <View style={styles.content}> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                          <Text style={styles.title}>{item.nom}</Text> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                          <Text style={styles.description}>{`${I18n.t('CREATOR')}: ${item.createur}`}</Text> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                          {/* <Text style={styles.description}>{`Sponsor 1: ${item.sponsor1}`}</Text> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                          <Text style={styles.description}>{`Sponsor 2:  ${item.sponsor2}`}</Text> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                          <Text style={styles.description}>{`Sponsor 3:  ${item.sponsor3}`}</Text> */} | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                          <View style={styles.timeContent}> | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                               <View style={{ alignContent: 'flex-start', flex: 1, flexDirection: 'row' }}> | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                                    <Text style={{ | 
					
						
							|  |  |  |                                         fontWeight: 'bold', | 
					
						
							|  |  |  |                                         marginLeft: 20, | 
					
						
							|  |  |  |                                         marginBottom: 10, | 
					
						
							|  |  |  |                                         color: item.nombre_validation === 3 ? 'green' : 'red', | 
					
						
							|  |  |  |                                    }}> | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                                         {item.nombre_validation === 3 ? I18n.t('VALIDATE') : I18n.t('NO_VALIDATE')} | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                                         {` (${item.nombre_validation} ${item.nombre_validation > 1 ? I18n.t('VALIDATIONS') : I18n.t('VALIDATION')})`} | 
					
						
							|  |  |  |                                    </Text> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |                               </View> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                               <View style={{ alignContent: 'flex-end', flex: 1, flexDirection: 'row' }}> | 
					
						
							|  |  |  |                                    <Icon name="map-marker" style={[styles.descriptionIcon], { color: Color.accentColor, marginTop: 5 }} /> | 
					
						
							|  |  |  |                                    <Text style={styles.time}>{item.country}</Text> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                                    <Icon name="clock" style={[styles.descriptionIcon], { color: Color.accentColor, marginTop: 5 }} /> | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                                    <Text style={styles.time}> {dateFormat}</Text> | 
					
						
							|  |  |  |                               </View> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                          </View> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                     </View> | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                </TouchableOpacity> | 
					
						
							|  |  |  |           ) | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      rendeGetDemandsGroupResponse = () => { | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           const { resultGetDemandsGroup, errorGetDemandsGroup } = this.props; | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           if (errorGetDemandsGroup !== null) { | 
					
						
							|  |  |  |                if (typeof errorGetDemandsGroup.data !== 'undefined') { | 
					
						
							|  |  |  |                     return ( | 
					
						
							|  |  |  |                          <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}> | 
					
						
							|  |  |  |                               <Text style={Typography.body1}>{errorGetDemandsGroup.data.error}</Text> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |                else { | 
					
						
							|  |  |  |                     return ( | 
					
						
							|  |  |  |                          <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}> | 
					
						
							|  |  |  |                               <Text style={Typography.body1}>{errorGetDemandsGroup}</Text> | 
					
						
							|  |  |  |                          </View> | 
					
						
							|  |  |  |                     ) | 
					
						
							|  |  |  |                } | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           if (resultGetDemandsGroup !== null) { | 
					
						
							|  |  |  |                if (resultGetDemandsGroup.response !== null) { | 
					
						
							|  |  |  |                     return ( | 
					
						
							|  |  |  |                          Array.isArray(resultGetDemandsGroup.response) && (resultGetDemandsGroup.response.length) > 0 ? | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                               (<ScrollView style={{ flex: 1 }}> | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                                    { | 
					
						
							|  |  |  |                                         resultGetDemandsGroup.response.map((item) => ( | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                                              this.renderDemandItem(item) | 
					
						
							|  |  |  |                                         )) | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                                    } | 
					
						
							|  |  |  |                               </ScrollView>) : | 
					
						
							|  |  |  |                               ( | 
					
						
							|  |  |  |                                    <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}> | 
					
						
							|  |  |  |                                         <Text style={Typography.body1}>{I18n.t('NO_DEMAND_CREATION_GROUP')}</Text> | 
					
						
							|  |  |  |                                    </View> | 
					
						
							|  |  |  |                               ) | 
					
						
							|  |  |  |                     ) | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                } | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      renderLoader = () => { | 
					
						
							|  |  |  |           return ( | 
					
						
							|  |  |  |                <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}> | 
					
						
							|  |  |  |                     {Platform.OS === 'android' | 
					
						
							|  |  |  |                          ? | 
					
						
							|  |  |  |                          ( | 
					
						
							|  |  |  |                               <> | 
					
						
							|  |  |  |                                    <ProgressBarAndroid /> | 
					
						
							|  |  |  |                                    <Text>{I18n.t('LOADING_DOTS')}</Text> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                               </> | 
					
						
							|  |  |  |                          ) : | 
					
						
							|  |  |  |                          <> | 
					
						
							|  |  |  |                               <ActivityIndicator size="large" color={'#ccc'} /> | 
					
						
							|  |  |  |                               <Text>{I18n.t('LOADING_DOTS')}</Text> | 
					
						
							|  |  |  |                          </> | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                </View> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |           ) | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      printOptions() { | 
					
						
							|  |  |  |           return (<ActionButton buttonColor={accent}> | 
					
						
							|  |  |  |                <ActionButton.Item buttonColor={primary} title={I18n.t('CREATE_GROUP')} | 
					
						
							|  |  |  |                     onPress={() => { | 
					
						
							|  |  |  |                          this.props.navigation.push(route.createGroupNanoCredit); | 
					
						
							|  |  |  |                     }} | 
					
						
							|  |  |  |                > | 
					
						
							|  |  |  |                     <Icon name="account-multiple-plus" style={styles.actionButtonIcon} /> | 
					
						
							|  |  |  |                </ActionButton.Item> | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                <ActionButton.Item buttonColor={purpleLight} title={I18n.t('JOIN_GROUP')} | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                     onPress={() => { | 
					
						
							| 
									
										
										
										
											2020-08-19 06:25:24 +00:00
										 |  |  |                          this.props.navigation.push(route.adhererGroupNanoCredit); | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                     }} | 
					
						
							|  |  |  |                > | 
					
						
							|  |  |  |                     <Icon name="account-multiple" style={styles.actionButtonIcon} /> | 
					
						
							|  |  |  |                </ActionButton.Item> | 
					
						
							|  |  |  |           </ActionButton>) | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-17 21:16:31 +00:00
										 |  |  |      refreshData() { | 
					
						
							| 
									
										
										
										
											2020-08-19 06:25:24 +00:00
										 |  |  |           this.props.getNanoCreditDemandsAction(this.state.user.id); | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      render() { | 
					
						
							| 
									
										
										
										
											2020-09-30 05:46:30 +00:00
										 |  |  |           console.warn("POSITION", this.state.position); | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |           return ( | 
					
						
							|  |  |  |                <Provider> | 
					
						
							|  |  |  |                     <View style={{ flex: 1 }} | 
					
						
							|  |  |  |                     > | 
					
						
							|  |  |  |                          <StatusBar | 
					
						
							|  |  |  |                               backgroundColor={theme.primaryDark} | 
					
						
							|  |  |  |                               barStyle="light-content" | 
					
						
							|  |  |  |                               translucent={false} | 
					
						
							|  |  |  |                          /> | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                          <Appbar.Header dark={true} style={{ backgroundColor: theme.primary }}> | 
					
						
							|  |  |  |                               <Appbar.BackAction | 
					
						
							|  |  |  |                                    onPress={() => { this.props.navigation.pop() }} | 
					
						
							|  |  |  |                               /> | 
					
						
							|  |  |  |                               <Appbar.Content | 
					
						
							|  |  |  |                                    title={I18n.t('MANAGE_GROUP')} | 
					
						
							|  |  |  |                                    subtitle={this.state.position === 0 ? I18n.t('VALIDATION_DEMAND') : I18n.t('DELETE_DEMAND')} | 
					
						
							|  |  |  |                               /> | 
					
						
							|  |  |  |                               <Appbar.Action icon="refresh" onPress={() => { this.refreshData() }} /> | 
					
						
							|  |  |  |                               {/* <Appbar.Action icon="more-vert" onPress={() => { this._openMenu(); this.renderSliding(); }} /> */} | 
					
						
							|  |  |  |                          </Appbar.Header> | 
					
						
							| 
									
										
										
										
											2020-08-24 19:18:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                          {this.state.position === 0 ? | 
					
						
							|  |  |  |                               this.props.loadingGetDemandsGroup ? | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                                    this.renderLoader() : | 
					
						
							|  |  |  |                                    this.rendeGetDemandsGroupResponse() | 
					
						
							| 
									
										
										
										
											2020-08-13 07:23:23 +00:00
										 |  |  |                               : null} | 
					
						
							|  |  |  |                          {this.state.position === 0 && this.printOptions()} | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |                     </View> | 
					
						
							|  |  |  |                </Provider> | 
					
						
							|  |  |  |           ); | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  | const mapStateToProps = state => ({ | 
					
						
							|  |  |  |      loadingGetDemandsGroup: state.getDemandsGroupReducer.loading, | 
					
						
							|  |  |  |      resultGetDemandsGroup: state.getDemandsGroupReducer.result, | 
					
						
							|  |  |  |      errorGetDemandsGroup: state.getDemandsGroupReducer.error, | 
					
						
							|  |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const mapDispatchToProps = dispatch => bindActionCreators({ | 
					
						
							|  |  |  |      getNanoCreditDemandsAction: getNanoCreditDemandsAction, | 
					
						
							|  |  |  |      getNanoCreditDemandsReset: getNanoCreditDemandsReset | 
					
						
							|  |  |  | }, dispatch); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default connect(mapStateToProps, mapDispatchToProps)(DemandValidationGroup); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | const styles = StyleSheet.create({ | 
					
						
							|  |  |  |      slidingup: { | 
					
						
							|  |  |  |           position: "absolute", | 
					
						
							|  |  |  |           height: responsiveHeight(84), | 
					
						
							|  |  |  |           bottom: 0, | 
					
						
							|  |  |  |           backgroundColor: 'white', | 
					
						
							|  |  |  |           width: responsiveWidth(100), | 
					
						
							|  |  |  |           zIndex: 1000 | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      root: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      container: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           backgroundColor: 'white', | 
					
						
							|  |  |  |           justifyContent: 'center', | 
					
						
							|  |  |  |           alignItems: 'center', | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      emptylist: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           justifyContent: 'center', | 
					
						
							|  |  |  |           alignItems: 'center' | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      backgroundd_drawer: { | 
					
						
							|  |  |  |           backgroundColor: '#000', | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      listbackground: { | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      actionButtonIcon: { | 
					
						
							|  |  |  |           fontSize: 20, | 
					
						
							|  |  |  |           height: 22, | 
					
						
							|  |  |  |           color: 'white', | 
					
						
							|  |  |  |      }, | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      descriptionIcon: { | 
					
						
							|  |  |  |           fontSize: 10, | 
					
						
							|  |  |  |           height: 12, | 
					
						
							|  |  |  |           top: 10 | 
					
						
							|  |  |  |      }, | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  |      welcome: { | 
					
						
							|  |  |  |           fontSize: 20, | 
					
						
							|  |  |  |           textAlign: 'center', | 
					
						
							|  |  |  |           margin: 10, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      instructions: { | 
					
						
							|  |  |  |           textAlign: 'center', | 
					
						
							|  |  |  |           color: '#333333', | 
					
						
							|  |  |  |           marginBottom: 5, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      dateText: { | 
					
						
							|  |  |  |           marginTop: 20, | 
					
						
							|  |  |  |           marginLeft: responsiveWidth(13), | 
					
						
							|  |  |  |           marginBottom: 20, | 
					
						
							|  |  |  |           fontSize: 17, | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      titlecontent: { | 
					
						
							|  |  |  |           fontSize: 17, | 
					
						
							|  |  |  |           marginLeft: responsiveWidth(10), | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           color: 'black' | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      title: { | 
					
						
							|  |  |  |           fontSize: 20, | 
					
						
							|  |  |  |           marginLeft: 20, | 
					
						
							|  |  |  |           marginTop: 20, | 
					
						
							|  |  |  |           color: 'black', | 
					
						
							|  |  |  |           fontWeight: 'bold' | 
					
						
							|  |  |  |      }, | 
					
						
							| 
									
										
										
										
											2020-08-12 18:24:56 +00:00
										 |  |  |      content: { | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           flexDirection: 'column', | 
					
						
							|  |  |  |           paddingTop: 10, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      listStyle: { | 
					
						
							|  |  |  |           backgroundColor: 'white' | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      bottomSeparator: { | 
					
						
							|  |  |  |           width: responsiveWidth(100), | 
					
						
							|  |  |  |           height: 5, | 
					
						
							|  |  |  |           justifyContent: 'center', | 
					
						
							|  |  |  |           alignSelf: 'center', | 
					
						
							|  |  |  |           backgroundColor: '#EEE', | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      title: { | 
					
						
							|  |  |  |           color: '#000', | 
					
						
							|  |  |  |           paddingLeft: 10, | 
					
						
							|  |  |  |           fontSize: responsiveFontSize(2.2) | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      description: { | 
					
						
							|  |  |  |           fontSize: responsiveFontSize(1.8), | 
					
						
							|  |  |  |           color: '#4f5b62', | 
					
						
							|  |  |  |           paddingLeft: 10, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      timeContent: { | 
					
						
							|  |  |  |           justifyContent: 'space-between', | 
					
						
							|  |  |  |           flex: 1, | 
					
						
							|  |  |  |           marginTop: 10, | 
					
						
							|  |  |  |           marginBottom: 5, | 
					
						
							|  |  |  |           flexDirection: 'row', | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      time: { | 
					
						
							|  |  |  |           fontWeight: 'bold', | 
					
						
							|  |  |  |           marginRight: 20, | 
					
						
							|  |  |  |           marginBottom: 10, | 
					
						
							|  |  |  |           color: theme.accent, | 
					
						
							|  |  |  |      }, | 
					
						
							| 
									
										
										
										
											2020-08-25 05:39:28 +00:00
										 |  |  |      paymentItem: { | 
					
						
							|  |  |  |           flexDirection: "row", | 
					
						
							|  |  |  |           alignItems: "center", | 
					
						
							|  |  |  |           justifyContent: "space-between", | 
					
						
							|  |  |  |           width: "100%", | 
					
						
							|  |  |  |           borderBottomColor: '#EEE', | 
					
						
							|  |  |  |           borderBottomWidth: 1 | 
					
						
							|  |  |  |      }, | 
					
						
							|  |  |  |      iconContent: { | 
					
						
							|  |  |  |           width: 40, | 
					
						
							|  |  |  |           marginRight: 5, | 
					
						
							|  |  |  |           alignItems: "center" | 
					
						
							|  |  |  |      } | 
					
						
							| 
									
										
										
										
											2020-08-11 09:42:31 +00:00
										 |  |  | }); |