693 lines
		
	
	
		
			27 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			693 lines
		
	
	
		
			27 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| /**
 | |
|  * Project iLinkWorld
 | |
|  * File ActivateBuySubscriptionScreen
 | |
|  * Path screens/wallet/user
 | |
|  * Created by BRICE ZELE
 | |
|  * Date: 08/11/2021
 | |
|  */
 | |
| import React, {useEffect, useState, useRef} from 'react';
 | |
| import {
 | |
|     Alert,
 | |
|     Dimensions,
 | |
|     KeyboardAvoidingView,
 | |
|     Platform,
 | |
|     ScrollView,
 | |
|     StyleSheet,
 | |
|     TouchableOpacity,
 | |
|     View,
 | |
| } from 'react-native';
 | |
| import {connect, useDispatch} from 'react-redux';
 | |
| import {useFormik} from 'formik';
 | |
| import * as Yup from 'yup';
 | |
| import * as Utils from '../../../utils/UtilsFunction'
 | |
| import { optionenvoieautrewalletNanoSanteScreen} from '../../../utils/UtilsFunction'
 | |
| import {Color} from "../../../config/Color";
 | |
| import I18n from 'react-native-i18n';
 | |
| import {Fumi} from 'react-native-textinput-effects';
 | |
| import {ScreenComponent} from "../../../components/ScreenComponent";
 | |
| import PasswordInput from '../../../components/PasswordInput';
 | |
| import Button from "../../../components/Button";
 | |
| import FontAwesome from "react-native-vector-icons/FontAwesome";
 | |
| import {
 | |
|     fetchActivePaySubscription,
 | |
|     fetchActivePaySubscriptionReset,
 | |
|     fetchGetSubscriptionList,
 | |
|     fetchGetSubscriptionListReset
 | |
| } from "../../../redux/insurance/insurance.actions";
 | |
| import DropdownAlert from "react-native-dropdownalert";
 | |
| import {readUser} from "../../../webservice/AuthApi";
 | |
| import * as Animatable from 'react-native-animatable';
 | |
| import FontAwesomeIcon from 'react-native-vector-icons/FontAwesome';
 | |
| import {createStructuredSelector} from "reselect";
 | |
| import {selectActivatePaySubscription, selectSubscriptionList} from "../../../redux/insurance/insurance.selector";
 | |
| import {responsiveHeight, responsiveWidth} from 'react-native-responsive-dimensions';
 | |
| import {Dropdown} from "react-native-material-dropdown-v2";
 | |
| import {store} from "../../../redux/store";
 | |
| import Modal from "react-native-modal";
 | |
| import Text from "../../../components/Text";
 | |
| import Icon from "react-native-vector-icons/FontAwesome5";
 | |
| import TextInput from "../../../components/TextInput";
 | |
| import route from '../../../route.json';
 | |
| let moment = require('moment-timezone');
 | |
| 
 | |
| const {width, height} = Dimensions.get('window');
 | |
| const CIRCLE_SIZE = width * 0.5;
 | |
| 
 | |
| const styles = StyleSheet.create({
 | |
|     container: {
 | |
|         marginTop: 20,
 | |
|         paddingHorizontal: 20,
 | |
|       },
 | |
|       dropdownContainer: {
 | |
|         borderWidth: 1,
 | |
|         borderRadius: 4,
 | |
|         paddingHorizontal: 10,
 | |
|       },
 | |
|     textInput: {
 | |
|         height: 46,
 | |
|         backgroundColor: Color.fieldColor,
 | |
|         borderRadius: 5,
 | |
|         marginTop: 10,
 | |
|         padding: 10,
 | |
|         width: '100%',
 | |
|     },
 | |
|     lineRow: {
 | |
|         flexDirection: 'row',
 | |
|         justifyContent: 'space-between',
 | |
|         paddingBottom: 20,
 | |
|     },
 | |
|     contain: {
 | |
|         alignItems: 'center',
 | |
|         marginTop: 40,
 | |
|         paddingBottom: 20,
 | |
|         paddingLeft: 20,
 | |
|         paddingRight: 20,
 | |
|         flex: 1,
 | |
|     },
 | |
|     circle: {
 | |
|         width: CIRCLE_SIZE,
 | |
|         height: CIRCLE_SIZE,
 | |
|         borderRadius: CIRCLE_SIZE / 2,
 | |
|         position: 'absolute',
 | |
|         top: '15%',
 | |
|     },
 | |
|     circleContainer: {
 | |
|         alignItems: 'flex-end',
 | |
|         right: -(CIRCLE_SIZE / 3),
 | |
|         top: -(CIRCLE_SIZE / 1.5),
 | |
|     },
 | |
|     lineSeparator: {
 | |
|         borderWidth: 1,
 | |
|         width: '40%',
 | |
|         height: 1,
 | |
|         alignSelf: 'center',
 | |
|     },
 | |
|     line: {
 | |
|         width: 1,
 | |
|         height: 14,
 | |
|         backgroundColor: Color.grayColor,
 | |
|         marginLeft: 10,
 | |
|     },
 | |
|     contentModeView: {
 | |
|         width: 30,
 | |
|         height: '100%',
 | |
|         alignItems: 'flex-end',
 | |
|         justifyContent: 'center',
 | |
|     },
 | |
|     contentFilter: {
 | |
|         flexDirection: 'row',
 | |
|         alignItems: 'center',
 | |
|         marginLeft: 10,
 | |
|     },
 | |
|     bottomModal: {
 | |
|         justifyContent: 'flex-end',
 | |
|         margin: 0,
 | |
|     },
 | |
|     contentFilterBottom: {
 | |
|         width: "100%",
 | |
|         borderTopLeftRadius: 8,
 | |
|         borderTopRightRadius: 8,
 | |
|         paddingHorizontal: 20
 | |
|     },
 | |
|     contentSwipeDown: {
 | |
|         paddingTop: 10,
 | |
|         alignItems: 'center',
 | |
|     },
 | |
|     lineSwipeDown: {
 | |
|         width: 30,
 | |
|         height: 2.5,
 | |
|         backgroundColor: Color.dividerColor,
 | |
|     },
 | |
|     contentActionModalBottom: {
 | |
|         flexDirection: 'row',
 | |
|         paddingVertical: 15,
 | |
|         justifyContent: 'space-between',
 | |
|         borderBottomWidth: 1,
 | |
|     },
 | |
|     containModal: {
 | |
|         paddingVertical: 10,
 | |
|         paddingHorizontal: 20,
 | |
|         flexDirection: 'row',
 | |
|         justifyContent: 'space-between',
 | |
|     },
 | |
|     floatingButtonAdd: {
 | |
|         backgroundColor: Color.accentColor,
 | |
|         position: "absolute",
 | |
|         width: 25,
 | |
|         bottom: 0,
 | |
|         zIndex: 1000,
 | |
|         right: 20,
 | |
|         top: 35,
 | |
|         height: 25,
 | |
|         borderRadius: 12.5,
 | |
|         alignItems: 'center',
 | |
|         justifyContent: 'center',
 | |
|     },
 | |
|     contentSwitch: {
 | |
|         width: responsiveWidth(40),
 | |
|     },
 | |
|     switch: {},
 | |
|     choosePhotoBtn: {
 | |
|         marginTop: 10,
 | |
|         marginBottom: 10,
 | |
|         width: "auto",
 | |
|         height: "auto",
 | |
|         padding: 5,
 | |
|         alignItems: 'center',
 | |
|         borderColor: Color.borderColor,
 | |
|         marginRight: 10,
 | |
|         elevation: 2,
 | |
|     },
 | |
|     checkbox: {
 | |
|         alignSelf: "center",
 | |
|         color: "white"
 | |
|     },
 | |
|     itemAmountPerMonth: {
 | |
|         paddingLeft: 10,
 | |
|         marginTop: 10,
 | |
|         flexDirection: 'row',
 | |
|     },
 | |
|     dot: {
 | |
|         width: 12,
 | |
|         height: 12,
 | |
|         borderRadius: 6
 | |
|     },
 | |
|     blockView: {
 | |
|         paddingVertical: 10,
 | |
|         borderBottomWidth: 0.5,
 | |
|     },
 | |
|     containPaymentMethod: {
 | |
|         flex: 1,
 | |
|         alignItems: 'center',
 | |
|         paddingHorizontal: 20,
 | |
|         paddingVertical: 15,
 | |
|     },
 | |
|     methodItem: {
 | |
|         width: '100%',
 | |
|         flexDirection: 'row',
 | |
|         justifyContent: 'space-between',
 | |
|         alignItems: 'center',
 | |
|         paddingVertical: 15,
 | |
|         marginBottom: 5,
 | |
|     },
 | |
|     iconContent: {
 | |
|         width: 30,
 | |
|         marginRight: 10,
 | |
|         alignItems: 'center',
 | |
|     },
 | |
|     input: {
 | |
|         height: 60,
 | |
|         marginTop: responsiveHeight(2),
 | |
|         marginLeft: responsiveWidth(5),
 | |
|         marginRight: responsiveWidth(5),
 | |
|         borderRadius: 5,
 | |
|     }
 | |
| });
 | |
| 
 | |
| const ActivateBuySubscriptionScreen = ({
 | |
|                                            activatePaySubscription,
 | |
|                                            fetchGetSubscriptionList,
 | |
|                                            subscriptionList,
 | |
|                                            fetchActivePaySubscription,
 | |
|                                            navigation,
 | |
|                                        }) => {
 | |
| 
 | |
|     const [user, setUser] = useState(null);
 | |
|     const [password, setPassword] = useState(null);
 | |
|     const [ state, setState] = useState("")
 | |
|     const [subscriptions, setSubscriptions] = useState([]);
 | |
|     const [subscription, setSubscription] = useState(null);
 | |
|     const [modalPaymentModal, setModalPaymentModal] = useState(false);
 | |
|  
 | |
| 
 | |
|  
 | |
|     const dispatch = useDispatch();
 | |
|     let dropDownAlertRef: any = null;
 | |
|     let subscriptionRef = null;
 | |
|     let amountPerMonthRef = null;
 | |
|     const [wallet] = useState(store.getState().walletDetailReducer.result.response);
 | |
| 
 | |
|     useEffect(() => {
 | |
|         readUser().then((user) => {
 | |
|             setUser(user)
 | |
|         });
 | |
|         dispatch(fetchGetSubscriptionListReset());
 | |
|         dispatch(fetchActivePaySubscriptionReset());
 | |
|     }, []);
 | |
| 
 | |
|     useEffect(() => {
 | |
|         if (user !== null) {
 | |
|             console.log("user", user.id);
 | |
|             fetchGetSubscriptionList(user.id, 'UNPAID', true);
 | |
|         }
 | |
|     }, [user]);
 | |
| 
 | |
|     useEffect(() => {
 | |
|         if (subscriptionList.result !== null) {
 | |
|             let subscriptionListTemp = [];
 | |
|             subscriptionList.result.response.map((subscriptionItem, index) => {
 | |
|                 subscriptionListTemp.push(subscriptionItem);
 | |
|             });
 | |
|             setSubscriptions(subscriptionListTemp);
 | |
|         }
 | |
| 
 | |
|         if (subscriptionList.error) {
 | |
|             Alert.alert(
 | |
|                 I18n.t("ERROR_LABLE"),
 | |
|                 Utils.getErrorMsg(subscriptionList),
 | |
|                 [
 | |
|                     {
 | |
|                         text: I18n.t("OK"), onPress: () => {
 | |
|                             dispatch(fetchGetSubscriptionListReset());
 | |
|                         }
 | |
|                     }
 | |
|                 ],
 | |
|                 {cancelable: false}
 | |
|             );
 | |
|             /*            dropDownAlertRef.alertWithType(
 | |
|                             'error',
 | |
|                             I18n.t('ERROR_LABEL'),
 | |
|                             Utils.getErrorMsg(subscriptionList),
 | |
|                         );
 | |
|                         dispatch(fetchGetSubscriptionListReset());*/
 | |
|         }
 | |
|     }, [subscriptionList]);
 | |
| 
 | |
|     useEffect(() => {
 | |
| 
 | |
|  
 | |
|             if (activatePaySubscription !== null) {
 | |
|              if (activatePaySubscription.status === 301) {
 | |
|                          dispatch(fetchActivePaySubscriptionReset());
 | |
|                          try{
 | |
|                              navigation.navigate('webviewScreen', {
 | |
|                                  url: activatePaySubscription.response.payment_url,
 | |
|                                  requestBody: fetchActivePaySubscription(subscription.id, {password: values.password, amount: values.amount, payment_method: 'MOBILE_MONEY'})
 | |
|                                  
 | |
|                              });
 | |
|                          } catch(error) {
 | |
|                              console.log('error', error);
 | |
|                          }
 | |
|                     }
 | |
|                      if (activatePaySubscription.status === 200) {
 | |
|                                  if (activatePaySubscription.response !== null) {
 | |
|                                       Alert.alert(
 | |
|                                            I18n.t("WITHDRAWAL_SUCCESS"),
 | |
|                                            activatePaySubscription.response,
 | |
|                                            [
 | |
|                                                 {
 | |
|                                                      text: I18n.t("OK"), onPress: () => {
 | |
|                                                           dispatch(fetchActivePaySubscriptionReset());
 | |
|                                                         //   IlinkEmitter.emit("refreshWallet");
 | |
|                                                         //   navigation.pop();
 | |
|                                                      }
 | |
|                                                 }
 | |
|                   
 | |
|                                            ],
 | |
|                                            { cancelable: false }
 | |
|                                       )
 | |
|                                  }
 | |
| 
 | |
|                 }
 | |
| 
 | |
|             }
 | |
| 
 | |
|     //     if (activatePaySubscription.result !== null) {
 | |
|     //         console.warn('tototo tototot: ', activatePaySubscription.result)
 | |
|     //     //     if (activatePaySubscription.status === 301) {
 | |
|     //     //         dispatch(fetchActivePaySubscriptionReset());
 | |
|     //     //         try{
 | |
|     //     //             navigation.push('webviewScreen', {
 | |
|     //     //                 url: activatePaySubscription.response.payment_url,
 | |
|     //     //                 requestBody: {password: values.password, amount: values.amount, payment_method: 'MOBILE_MONEY'}
 | |
|                         
 | |
|     //     //             });
 | |
|     //     //         } catch(error) {
 | |
|     //     //             console.log('error', error);
 | |
|     //     //         }
 | |
|     //     //    }
 | |
|     //         Alert.alert(
 | |
|     //             I18n.t("SUCCESS"),
 | |
|     //             activatePaySubscription.result.response,
 | |
|     //             [
 | |
|     //                 {
 | |
|     //                     text: I18n.t("OK"), onPress: () => {
 | |
|     //                         dispatch(fetchActivePaySubscriptionReset());
 | |
|     //                        // setModalPaymentModal(false);
 | |
|     //                         //navigation.goBack();
 | |
|     //                     }
 | |
|     //                 }
 | |
| 
 | |
|     //             ],
 | |
|     //             {cancelable: false}
 | |
|     //         )
 | |
|         
 | |
|     // //     if (activatePaySubscription.status === 200) {
 | |
|             
 | |
|     // //         if (activatePaySubscription.response !== null) {
 | |
|     // //             console.warn("blabla blabla : ", activatePaySubscription.response)
 | |
|     // //              Alert.alert(
 | |
|     // //                   I18n.t("WITHDRAWAL_SUCCESS"),
 | |
|     // //                   activatePaySubscription.response,
 | |
|     // //                   [
 | |
|     // //                        {
 | |
|     // //                             text: I18n.t("OK"), onPress: () => {
 | |
|     // //                                 dispatch(fetchActivePaySubscriptionReset());
 | |
|     // //                                  IlinkEmitter.emit("refreshWallet");
 | |
|     // //                                  navigation.pop();
 | |
|     // //                             }
 | |
|     // //                        }
 | |
| 
 | |
|     // //                   ],
 | |
|     // //                   { cancelable: false }
 | |
|     // //              )
 | |
|     // //         }
 | |
|     // //    }
 | |
|     // }
 | |
|   
 | |
|         if (activatePaySubscription.error) {
 | |
|             Alert.alert(
 | |
|                 I18n.t("ERROR_LABLE"),
 | |
|                 Utils.getErrorMsg(activatePaySubscription),
 | |
|                 [
 | |
|                     {
 | |
|                         text: I18n.t("OK"), onPress: () => {
 | |
|                             dispatch(fetchActivePaySubscriptionReset());                         
 | |
|                         }
 | |
|                     }
 | |
|                 ],
 | |
|                 {cancelable: false}
 | |
|             );
 | |
|             /*            dropDownAlertRef.alertWithType(
 | |
|                             'error',
 | |
|                             I18n.t('ERROR_LABEL'),
 | |
|                             Utils.getErrorMsg(activatePaySubscription),
 | |
|                         );
 | |
|                         dispatch(fetchActivePaySubscriptionReset());*/
 | |
|         }
 | |
|     }, [activatePaySubscription]);
 | |
| 
 | |
|     const RegisterSchema = Yup.object().shape({
 | |
|         password: Yup.string().required(I18n.t('THIS_FIELD_IS_REQUIRED')),
 | |
|         amount: Yup.number().required(I18n.t('THIS_FIELD_IS_REQUIRED'))
 | |
|     });
 | |
| 
 | |
| 
 | |
|     const {
 | |
|         handleChange,
 | |
|         handleSubmit,
 | |
|         handleBlur,
 | |
|         values,
 | |
|         errors,
 | |
|         touched,
 | |
|         setFieldValue,
 | |
|         setFieldTouched,
 | |
|         isValid,
 | |
|     } = useFormik({
 | |
|         validationSchema: RegisterSchema,
 | |
|         initialValues: {
 | |
|             password: '',
 | |
|             amount: ''
 | |
|         },
 | |
|         onSubmit: values => {
 | |
|             if (user !== null) {
 | |
|                 if (subscription === null) {
 | |
|                     subscriptionRef.shake(800);
 | |
|                 } else {
 | |
|                     console.log("subscription", subscription);
 | |
|                     setModalPaymentModal(true);
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     });
 | |
| 
 | |
|     const renderPaymentMethodModal = () => (
 | |
|         <ScrollView style={{flex: 1}}>
 | |
|             <View style={[styles.containModal, {backgroundColor: Color.containerBackgroundColor}]}>
 | |
|                 <Modal
 | |
|                     isVisible={modalPaymentModal}
 | |
|                     onSwipeComplete={() => {
 | |
|                         setModalPaymentModal(false);
 | |
|                     }}
 | |
|                     swipeDirection={['down']}
 | |
|                     style={styles.bottomModal}>
 | |
|                     <View
 | |
|                         style={[
 | |
|                             styles.contentFilterBottom,
 | |
|                             {backgroundColor: Color.containerBackgroundColor},
 | |
|                         ]}>
 | |
|                         <View style={styles.contentSwipeDown}>
 | |
|                             <View style={styles.lineSwipeDown}/>
 | |
|                         </View>
 | |
| 
 | |
|                         <Text body2 style={{marginTop: 10}}>{I18n.t('PAYMENT_METHOD')}</Text>
 | |
| 
 | |
|                         <View>
 | |
|                             <TouchableOpacity
 | |
|                                 style={[
 | |
|                                     styles.methodItem,
 | |
|                                     {
 | |
|                                         borderBottomColor: Color.borderColor,
 | |
|                                         borderBottomWidth: 1,
 | |
|                                     },
 | |
|                                 ]}
 | |
|                                 onPress={() => {
 | |
|                                     fetchActivePaySubscription(subscription.id, {password: values.password, amount: values.amount, payment_method: 'WALLET'});
 | |
|                                 }}>
 | |
|                                 <View
 | |
|                                     style={{
 | |
|                                         flexDirection: 'row',
 | |
|                                         alignItems: 'center',
 | |
|                                     }}>
 | |
|                                     <View style={styles.iconContent}>
 | |
|                                         <Icon name="wallet" size={24} color={Color.textColor}/>
 | |
|                                     </View>
 | |
|                                     <Text headline>{I18n.t('WALLET')}</Text>
 | |
|                                 </View>
 | |
|                                 <Icon
 | |
|                                     name="angle-right"
 | |
|                                     size={18}
 | |
|                                     color={Color.primaryColor}
 | |
|                                     enableRTL
 | |
|                                 />
 | |
|                             </TouchableOpacity>
 | |
|                             <TouchableOpacity
 | |
|                                 style={[
 | |
|                                     styles.methodItem,
 | |
|                                     {
 | |
|                                         borderBottomColor: Color.borderColor,
 | |
|                                         borderBottomWidth: 1,
 | |
|                                     },
 | |
|                                 ]}
 | |
|                                 onPress={() => {
 | |
|                                     fetchActivePaySubscription(subscription.id, {password: values.password, amount: values.amount, payment_method: 'card'});
 | |
|                                 }}>
 | |
|                                 <View
 | |
|                                     style={{
 | |
|                                         flexDirection: 'row',
 | |
|                                         alignItems: 'center',
 | |
|                                     }}>
 | |
|                                     <View style={styles.iconContent}>
 | |
|                                         <Icon
 | |
|                                             name="cc-visa"
 | |
|                                             size={24}
 | |
|                                             color={Color.textColor}
 | |
|                                         />
 | |
|                                     </View>
 | |
|                                     <Text headline>{I18n.t('CREDIT_CARD')}</Text>
 | |
|                                 </View>
 | |
|                                 <Icon
 | |
|                                     name="angle-right"
 | |
|                                     size={18}
 | |
|                                     color={Color.primaryColor}
 | |
|                                     enableRTL
 | |
|                                 />
 | |
|                             </TouchableOpacity>
 | |
|                             <TouchableOpacity
 | |
|                                 style={[
 | |
|                                     styles.methodItem,
 | |
|                                     {
 | |
|                                         borderBottomColor: Color.borderColor,
 | |
|                                         borderBottomWidth: 1,
 | |
|                                     },
 | |
|                                 ]}
 | |
|                                 onPress={() => {
 | |
|                                     fetchActivePaySubscription(subscription.id, {password: values.password, amount: values.amount, payment_method: 'MOBILE_MONEY'});
 | |
|                                 }}>
 | |
|                                 <View
 | |
|                                     style={{
 | |
|                                         flexDirection: 'row',
 | |
|                                         alignItems: 'center',
 | |
|                                     }}>
 | |
|                                     <View style={styles.iconContent}>
 | |
|                                         <Icon
 | |
|                                             name="mobile-alt"
 | |
|                                             size={24}
 | |
|                                             color={Color.textColor}
 | |
|                                         />
 | |
|                                     </View>
 | |
|                                     <Text headline>{I18n.t('MOBILE_MONEY')}</Text>
 | |
|                                 </View>
 | |
|                                 <Icon
 | |
|                                     name="angle-right"
 | |
|                                     size={18}
 | |
|                                     color={Color.primaryColor}
 | |
|                                     enableRTL
 | |
|                                 />
 | |
|                             </TouchableOpacity>
 | |
|                         </View>
 | |
|                         <Button
 | |
|                             full
 | |
|                             style={{marginTop: 10, marginBottom: 20}}
 | |
|                             onPress={() => setModalPaymentModal(false)}>
 | |
|                             {I18n.t('OK')}
 | |
|                         </Button>
 | |
| 
 | |
|                     </View>
 | |
|                 </Modal>
 | |
|             </View>
 | |
|         </ScrollView>
 | |
|     )
 | |
| 
 | |
|     return (
 | |
|         <ScreenComponent>
 | |
|             <DropdownAlert ref={ref => (dropDownAlertRef = ref)}/>
 | |
|             <KeyboardAvoidingView
 | |
|                 behavior={Platform.OS === 'android' ? 'height' : 'padding'}
 | |
|                 style={{flex: 1}}>
 | |
| 
 | |
|                 <ScrollView style={{flex: 1}}>
 | |
|                             {/* <View style={styles.container}>
 | |
|                             <Dropdown
 | |
|                               label="Sélectionnez une méthode de paiement"
 | |
|                               data={paymentMethodOptions}
 | |
|                               value={selectedPaymentMethod}
 | |
|                               onChangeText={handlePaymentMethodChange}
 | |
|                               containerStyle={styles.dropdownContainer}
 | |
|                             />
 | |
|                             </View> */}
 | |
|                             <View style={styles.contain}>
 | |
|                                 <Animatable.View ref={(comp) => {
 | |
|                                     subscriptionRef = comp
 | |
|                                 }}
 | |
|                                                  style={{
 | |
|                                                      width: responsiveWidth(90),
 | |
|                                                      height: 60,
 | |
|                                                      alignSelf: 'center',
 | |
|                                                      borderRadius: 10,
 | |
|                                                      paddingLeft: 20,
 | |
|                                                      paddingRight: 20,
 | |
|                                                      backgroundColor: 'white'
 | |
|                                                  }}>
 | |
|                                     <Dropdown
 | |
|                                         label={I18n.t('SELECT_INSURANCE')}
 | |
|                                         data={subscriptions}
 | |
|                                         useNativeDriver={true}
 | |
|                                         onChangeText={(value, index, data) => {
 | |
|                                             console.log("Value", value);
 | |
|                                             setSubscription(
 | |
|                                                 {
 | |
|                                                     id: value.id,
 | |
|                                                     insurance_subscription_id: value.insurance_subscription_id,
 | |
|                                                     network_id: value.network_id,
 | |
|                                                     user_id: value.user_id,
 | |
|                                                     number_of_months: value.number_of_months,
 | |
|                                                     bonus_amount: value.bonus_amount,
 | |
|                                                     number_of_beneficiaries: value.number_of_beneficiaries,
 | |
|                                                     total_bonus_amount: value.total_bonus_amount,
 | |
|                                                     state: value.state,
 | |
|                                                     created_at: value.created_at,
 | |
|                                                     updated_at: value.updated_at,
 | |
|                                                     start_at: value.start_at,
 | |
|                                                     end_at: value.end_at,
 | |
|                                                     reason: value.reason,
 | |
|                                                     network: value.network,
 | |
|                                                     beneficiaries: value.beneficiaries
 | |
|                                                 }
 | |
|                                             );
 | |
|                                         }}
 | |
|                                         valueExtractor={(value) => {
 | |
|                                             return value
 | |
|                                         }}
 | |
|                                         labelExtractor={(value) => {
 | |
|                                             return `${I18n.t('MNT')}: ${value.amount} | ${I18n.t('FACT')}: ${value.invoice_id.slice(0, 7)} | ${I18n.t('RESTE')}: ${value.remaining_amount}`
 | |
|                                         }}
 | |
|                                     />
 | |
|                                 </Animatable.View>
 | |
| 
 | |
|                                 <TextInput
 | |
|                                     style={{marginTop: 10}}
 | |
|                                     placeholder={I18n.t('AMOUNT')}
 | |
|                                     value={values.amount}
 | |
|                                     onChangeText={(text) => {
 | |
|                                         setFieldValue('amount', text);
 | |
|                                     }}
 | |
|                                     onBlur={handleBlur('amount')}
 | |
|                                     success={touched.amount && !errors.amount}
 | |
|                                     touched={touched.amount}
 | |
|                                     error={errors.amount}
 | |
|                                 />
 | |
| 
 | |
|                                 <PasswordInput
 | |
|                                     style={{marginTop: 10}}
 | |
|                                     onChangeText={handleChange('password')}
 | |
|                                     placeholder={I18n.t('PASSWORD')}
 | |
|                                     secureTextEntry
 | |
|                                     icon={<FontAwesome name="lock" size={20}/>}
 | |
|                                     value={values.password}
 | |
|                                     onBlur={handleBlur('password')}
 | |
|                                     success={touched.password && !errors.password}
 | |
|                                     touched={touched.password}
 | |
|                                     error={errors.password}
 | |
|                                 />
 | |
|              
 | |
|                                 <Button
 | |
|                                     style={{marginTop: 20}}
 | |
|                                     full
 | |
|                                     loading={activatePaySubscription.loading}
 | |
|                                     onPress={handleSubmit}>
 | |
|                                     {I18n.t('SUBMIT_LABEL')}
 | |
|                                 </Button>
 | |
|                             </View>
 | |
|                     {modalPaymentModal && renderPaymentMethodModal()}
 | |
| 
 | |
|                 </ScrollView>
 | |
|             </KeyboardAvoidingView>
 | |
|         </ScreenComponent>
 | |
|     );
 | |
| };
 | |
| 
 | |
| 
 | |
| const mapStateToProps = createStructuredSelector({
 | |
|     subscriptionList: selectSubscriptionList,
 | |
|     activatePaySubscription: selectActivatePaySubscription,
 | |
| 
 | |
| });
 | |
| 
 | |
| export default connect(mapStateToProps, {
 | |
|     fetchActivePaySubscription,
 | |
|     fetchGetSubscriptionList,
 | |
| })(
 | |
|     ActivateBuySubscriptionScreen,
 | |
| );
 |