import Button from 'apsl-react-native-button';
import isEqual from 'lodash/isEqual';
import isNil from 'lodash/isNil';
import React, {Component} from 'react';
import {Alert, ScrollView, StyleSheet, Text, View} from 'react-native';
import * as Animatable from 'react-native-animatable';
import I18n from 'react-native-i18n';
import Dialog from "react-native-dialog";
import {Dropdown} from 'react-native-material-dropdown-v2';
import {responsiveHeight, responsiveWidth} from 'react-native-responsive-dimensions';
import {ProgressDialog} from 'react-native-simple-dialogs';
import {Fumi} from 'react-native-textinput-effects';
import FontAwesomeIcon from 'react-native-vector-icons/FontAwesome';
import {connect} from 'react-redux';
import {bindActionCreators} from 'redux';
import {Color} from '../../../config/Color';
import {store} from "../../../redux/store";
import {identityPieces, isIlinkWorldWallet, isNormalInteger, typeIdIDestinataire} from '../../../utils/UtilsFunction';
import {readUser} from '../../../webservice/AuthApi';
import {
    getActiveCountryAction,
    getActiveCountryByDialCodeAction,
    getActiveCountryByDialCodeReset,
    getActiveCountryReset,
    getPayCountryNetworkAction,
    getPayCountryNetworkReset
} from '../../../webservice/CountryApi';
import {
    envoieUserWalletToWalletAction,
    envoieUserWalletToWalletReset,
    getCommissionUserWalletToWalletAction,
    getCommissionUserWalletToWalletReset
} from '../../../webservice/EnvoieUserApi';
import {FontWeight, Typography} from '../../../config/typography';
import thousands from 'thousands';
import {IlinkEmitter} from '../../../utils/events';
let theme = require('../../../utils/theme.json');
let route = require('../../../route.json');
class EnvoieWalletToWalletUser extends Component {
    static navigatorStyle = {
        navBarBackgroundColor: Color.primaryColor,
        statusBarColor: Color.primaryDarkColor,
        navBarTextColor: '#FFFFFF',
        navBarButtonColor: '#FFFFFF'
    };
    static navigationOptions = () => {
        return {
            drawerLabel: () => null,
            headerTitle: I18n.t('ENVOIE_ARGENT'),
            headerTintColor: 'white',
            headerStyle: {
                backgroundColor: Color.primaryColor,
                marginTop: 0,
                color: 'white'
            },
            headerTitleStyle: {
                color: "white"
            },
            title: I18n.t('ENVOIE_ARGENT')
        }
    };
    constructor(props) {
        super(props);
        this.state = {
            identityPieces: identityPieces(),
            identityPiecesName: I18n.t((identityPieces()[0]).name),
            paysDestination: [],
            paysDestinationSelect: null,
            walletActifs: [],
            walletActifSelect: null,
            typeIdDestinataire: typeIdIDestinataire(),
            typeIdDestinataireSelect: (typeIdIDestinataire()[0].value),
            numeroTelephoneOrWalletCode: null,
            numeroIdentite: null,
            montant: null,
            password: null,
            isIlinkWorldWalletSelect: false,
            loading: false,
            user: null,
            modalVisible: true,
            hasLoadActiveCountryList: true,
            hasLoadActivePayCountryNetworkList: true,
            triggerSubmitClick: false,
            isDataSubmit: false,
            isModalConfirmVisible: false,
            wallet: store.getState().walletDetailReducer.result.response
        };
        this.props.getActiveCountryReset();
        this.props.getActiveCountryByDialCodeReset();
        this.props.getPayCountryNetworkReset();
        this.props.envoieUserWalletToWalletReset();
        this.props.getCommissionUserWalletToWalletReset();
        this.props.getActiveCountryAction();
        console.log("ENVOIE WALLET PROPS", this.props);
    }
    componentDidMount() {
        
        readUser().then((user) => {
            if (user) {
                if (user !== undefined) {
                    this.setState({user});
                }
            }
        });
    }
    componentWillReceiveProps(nextProps) {
        if (nextProps.resultEnvoieWalletToWalletGetCommission != null) {
            if (typeof nextProps.resultEnvoieWalletToWalletGetCommission.response !== 'undefined') {
                if (!nextProps.loadingEnvoieWalletToWalletGetCommission)
                    this.setState({
                        isModalConfirmVisible: true
                    });
            }
        }
    }
    renderGetActionCountryList = () => {
        const {resultActiveCountryList, errorActiveCountryList} = this.props;
        if (resultActiveCountryList !== null) {
            if (typeof resultActiveCountryList.response !== 'undefined') {
                this.setState({
                    hasLoadActiveCountryList: false,
                    paysDestination: resultActiveCountryList.response,
                    paysDestinationSelect: resultActiveCountryList.response[0].name,
                });
                if (this.state.hasLoadActivePayCountryNetworkList)
                    this.props.getPayCountryNetworkAction({
                        id_wallet_user: this.state.wallet.id,
                        id_country: resultActiveCountryList.response[0].id
                    });
            }
        }
        if (errorActiveCountryList !== null) {
            if (typeof errorActiveCountryList.data !== 'undefined') {
                Alert.alert(
                    I18n.t('ERROR_LABEL'),
                    errorActiveCountryList.data.error,
                    [
                        {
                            text: I18n.t("OK"), onPress: () => {
                                this.props.getActiveCountryReset();
                            }
                        }
                    ],
                    {cancelable: false}
                )
            } else {
                Alert.alert(
                    I18n.t('ERROR_LABEL'),
                    JSON.stringify(errorActiveCountryList),
                    [
                        {
                            text: I18n.t("OK"), onPress: () => {
                                this.props.getActiveCountryReset();
                            }
                        }
                    ],
                    {cancelable: false}
                )
            }
        }
    }
    renderGetPayCountryNetworkResponse = () => {
        const {resultPayCountryNetwork, errorPayCountryNetwork} = this.props;
        if (resultPayCountryNetwork !== null) {
            if (typeof resultPayCountryNetwork.response !== 'undefined') {
                if (resultPayCountryNetwork.response.length > 0) {
                    let typeIdentifiant = isIlinkWorldWallet(resultPayCountryNetwork.response[0].type) ? 'user_code' : 'phone';
                    this.setState({
                        hasLoadActivePayCountryNetworkList: false,
                        walletActifs: resultPayCountryNetwork.response,
                        walletActifSelect: resultPayCountryNetwork.response[0].name,
                        typeIdDestinataireSelect: typeIdentifiant,
                        isIlinkWorldWalletSelect: isIlinkWorldWallet(resultPayCountryNetwork.response[0].type),
                        modalVisible: false
                    });
                } else if (resultPayCountryNetwork.response.length === 0) {
                    this.setState({
                        walletActifs: [],
                        walletActifSelect: '',
                        modalVisible: false,
                        hasLoadActivePayCountryNetworkList: false,
                    });
                }
            }
        }
        if (errorPayCountryNetwork !== null) {
            if (typeof errorPayCountryNetwork.data !== 'undefined') {
                Alert.alert(
                    I18n.t('ERROR_LABEL'),
                    errorPayCountryNetwork.data.error,
                    [
                        {
                            text: I18n.t("OK"), onPress: () => {
                                this.props.getPayCountryNetworkReset();
                            }
                        }
                    ],
                    {cancelable: false}
                )
            } else {
                Alert.alert(
                    I18n.t('ERROR_LABEL'),
                    JSON.stringify(errorPayCountryNetwork),
                    [
                        {
                            text: I18n.t("OK"), onPress: () => {
                                this.props.getPayCountryNetworkReset();
                            }
                        }
                    ],
                    {cancelable: false}
                )
            }
        }
    }
    renderEnvoieWalletToWalletResponse = () => {
   
        const {resultEnvoieWalletToWallet, errorEnvoieWalletToWallet} = this.props;
        if (errorEnvoieWalletToWallet !== null) {
            if (typeof errorEnvoieWalletToWallet.data !== 'undefined') {
                Alert.alert(
                    I18n.t("ERROR_TRANSFER"),
                    errorEnvoieWalletToWallet.data.error,
                    [
                        {
                            text: I18n.t("OK"), onPress: () => {
                                this.props.envoieUserWalletToWalletReset();
                            }
                        }
                    ],
                    {cancelable: false}
                )
            }
        }
        if (resultEnvoieWalletToWallet !== null) {
            if (resultEnvoieWalletToWallet.response !== null) {
                Alert.alert(
                    I18n.t("SUCCESS_TRANSFER"),
                    resultEnvoieWalletToWallet.response,
                    [
                        {
                            text: I18n.t("OK"), onPress: () => {
                                this.props.envoieUserWalletToWalletReset();
                                IlinkEmitter.emit("refreshWallet");
                                this.props.navigation.pop();
                            }
                        }
                    ],
                    {cancelable: false}
                )
            }
        }
    }
    
    renderDialogGetCommissionResponse = () => {
        const {errorEnvoieWalletToWalletGetCommission} = this.props;
        if (errorEnvoieWalletToWalletGetCommission !== null) {
            if (typeof errorEnvoieWalletToWalletGetCommission.data !== 'undefined') {
                Alert.alert(
                    I18n.t("ERROR_LABLE"),
                    errorEnvoieWalletToWalletGetCommission.data.error,
                    [
                        {
                            text: I18n.t("OK"), onPress: () => {
                                this.props.getCommissionUserWalletToWalletReset();
                            }
                        }
                    ],
                    {cancelable: false}
                )
            }
        }
    }
    ckeckIfFieldIsOK(champ) {
        return (isNil(champ) || isEqual(champ.length, 0));
    }
    isMontantValid = () => {
        const {montant} = this.state;
        if ((parseInt(isEqual(montant, 0)) || montant < 0))
            return {
                errorMessage: I18n.t('ENTER_AMOUNT_SUPERIOR_ZEROR'),
                isValid: false
            };
        else if (!isNormalInteger(montant))
            return {
                errorMessage: I18n.t('ENTER_VALID_AMOUNT'),
                isValid: false
            };
        else if (montant > parseInt(this.state.comptePrincipal))
            return {
                errorMessage: I18n.t('AMOUNT_SUPERIOR_TO_PRINCIPAL_ACCOUNT'),
                isValid: false
            };
        else
            return {
                errorMessage: '',
                isValid: true
            };
    }
    modalConfirmTransaction = (data) => {
        const commission = data.response.frais;
        const montant_net_final = data.response.montant_net_final;
        const montant_net_init = data.response.montant_net_init;
        const destinataire = data.response.destinataire;
        const exchange_rate = data.response.exchange_rate;
        console.log("DATA SEND TO CONFIRM DIALOG", data);
        return (
            
                {I18n.t('TRANSACTION_DETAIL')}
                
                    
                        
                            
                                {I18n.t('DESTINATAIRE')}
                            
                            
                                {destinataire}
                            
                        
                        
                            
                                {I18n.t('AMOUNT')}
                            
                            
                                {`${thousands(this.state.montant, ' ')} ${this.state.wallet.currency_code}`}
                            
                        
                        
                            
                                {I18n.t('FEES_AND_TAXES')}
                            
                            
                                {`${thousands(commission, ' ')} ${this.state.wallet.currency_code}`}
                            
                        
                    
                    
                    
                            
                                {I18n.t('EXCHANGE_TAUX')}: 
                            
                            
                                {exchange_rate}
                            
                        
                        
                            
                                {I18n.t('NET_AMOUNT')}:
                            
                            
                                
                            
                        
                        
                            
                                {I18n.t('INIT_COUNTRY')}
                            
                            
                                {`${thousands(montant_net_init, ' ')} ${this.state.wallet.currency_code}`}
                            
                        
                        
                            
                                {I18n.t('FINAL_COUNTRY')}
                            
                            
                                {montant_net_final}
                            
                        
                    
                
                 {
                    this.setState({
                        isModalConfirmVisible: false
                    });
                }}/>
                 {
                    this.setState({
                        isModalConfirmVisible: false,
                        isDataSubmit: true
                    });
                    
                    this.props.envoieUserWalletToWalletAction({
                        type: 1,
                        id_wallet_user: this.state.wallet.id,
                        type_id_destinataire : this.state.typeIdDestinataireSelect,
                        final_country: (this.state.paysDestination.filter(element => element.name === this.state.paysDestinationSelect))[0].id,
                        id_destinataire: this.state.numeroTelephoneOrWalletCode,
                        type_document_destinataire: this.state.identityPiecesName,
                        id_document_destinataire: this.state.numeroIdentite,
                        network_destinataire: (this.state.walletActifs.filter(element => element.name === this.state.walletActifSelect))[0].id,
                        montant: this.state.montant,
                        password: this.state.password
                    });
                    this.props.getCommissionUserWalletToWalletReset();
                }}
                />
            
        );
    }
    onSubmitSendWalletToWallet = () => {
        const {
            identityPiecesName,
            paysDestinationSelect,
            numeroIdentite,
            walletActifSelect,
            typeIdDestinataireSelect,
            numeroTelephoneOrWalletCode,
            montant,
            password
        } = this.state;
        if (this.ckeckIfFieldIsOK(identityPiecesName))
            this.identityPiecesAnim.shake(800);
        else if (this.ckeckIfFieldIsOK(paysDestinationSelect))
            this.paysDestinationAnim.shake(800);
        else if (this.ckeckIfFieldIsOK(walletActifSelect))
            this.walletActifAnim.shake(800);
        else if (this.ckeckIfFieldIsOK(typeIdDestinataireSelect))
            this.typeIdDestinataireAnim.shake(800);
        else if (this.ckeckIfFieldIsOK(numeroIdentite))
            this.numeroIdentiteAnim.shake(800);
        else if (this.ckeckIfFieldIsOK(numeroTelephoneOrWalletCode))
            this.numeroTelephoneAnim.shake(800);
        else if (this.ckeckIfFieldIsOK(montant) || !this.isMontantValid().isValid) {
            console.log("IS MONTANT VALID", this.isMontantValid())
            this.montantAnim.shake(800);
        } else if (this.ckeckIfFieldIsOK(password))
            this.passwordAnim.shake(800);
        else {
            this.props.getCommissionUserWalletToWalletAction({
                type: 1,
                network_destinataire: (this.state.walletActifs.filter(element => element.name === this.state.walletActifSelect))[0].id,
                id_wallet_user: this.state.wallet.id,
                final_country: (this.state.paysDestination.filter(element => element.name === this.state.paysDestinationSelect))[0].id,
                id_destinataire: this.state.numeroTelephoneOrWalletCode,
                montant: this.state.montant,
            });
        }
        this.setState({
            triggerSubmitClick: true
        })
    }
    renderLoader = () => {
        return (
            
        )
    }
    render() {
        console.log("STATE", this.state);
        const {resultEnvoieWalletToWalletGetCommission} = this.props;
        //const isFirstElementSelected = this.state.walletActifSelect === this.state.walletActifs[1]?.name;
        const lastTwoWallets = this.state.walletActifs.slice(-2).map(wallet => wallet.name);
        const isLastTwoElementsSelected = lastTwoWallets.includes(this.state.walletActifSelect);
    
        return (
            <>
                {(this.state.modalVisible || this.props.loadingEnvoieWalletToWalletGetCommission || this.props.loadingEnvoieWalletToWallet || this.props.loadingCountryByDialCode || this.props.loadingActiveCountryList || this.props.loadingCountryByDialCode) && this.renderLoader()}
                {this.state.hasLoadActiveCountryList && this.renderGetActionCountryList()}
                {this.state.hasLoadActivePayCountryNetworkList && this.renderGetPayCountryNetworkResponse()}
                {this.state.isDataSubmit && this.renderEnvoieWalletToWalletResponse()}
                {this.state.triggerSubmitClick && this.renderDialogGetCommissionResponse()}
                {
                    (resultEnvoieWalletToWalletGetCommission !== null) &&
                    (typeof resultEnvoieWalletToWalletGetCommission.response !== 'undefined') &&
                    this.modalConfirmTransaction(resultEnvoieWalletToWalletGetCommission)
                }
                
                    {I18n.t('DEPOSIT_WALLET_TO_WALLET')}
                     {
                        this.paysDestinationAnim = comp
                    }}
                                     style={{
                                         width: responsiveWidth(90),
                                         height: 60,
                                         marginTop: 20,
                                         alignSelf: 'center',
                                         borderRadius: 10,
                                         paddingLeft: 20,
                                         paddingRight: 20,
                                         backgroundColor: 'white'
                                     }}>
                         {
                                this.props.getPayCountryNetworkReset();
                                let countrySelect = data.filter(element => element.name === value);
                                this.setState({
                                    paysDestinationSelect: value,
                                    hasLoadActivePayCountryNetworkList: true
                                }, () => {
                                    this.props.getPayCountryNetworkAction({
                                        id_wallet_user: this.state.wallet.id,
                                        id_country: countrySelect[0].id
                                    });
                                });
                                this.props.getCommissionUserWalletToWalletReset();
                            }}
                            valueExtractor={(value) => {
                                return value.name
                            }}
                            labelExtractor={(value) => {
                                return value.name
                            }}
                        />
                    
                     {
                        this.walletActifAnim = comp
                    }}
                                     style={{
                                         width: responsiveWidth(90),
                                         height: 60,
                                         marginTop: 20,
                                         alignSelf: 'center',
                                         borderRadius: 10,
                                         paddingLeft: 20,
                                         paddingRight: 20,
                                         backgroundColor: 'white'
                                     }}>
                         {
                                let activeWalletSelect = data.filter(element => element.name === value);
                                let typeIdentifiant = isIlinkWorldWallet(activeWalletSelect[0].type) ? I18n.t('CODE_WALLET') : I18n.t('PHONE');
                                this.setState({
                                    walletActifSelect: value,
                                    typeIdDestinataireSelect: typeIdentifiant
                                });
                            }}
                            valueExtractor={(value) => {
                                return value.name
                            }}
                            labelExtractor={(value) => {
                                return value.name
                            }}
                        />
                    
                    {/* {isFirstElementSelected && ( */}
                    {isLastTwoElementsSelected && (
                    <>
                         {
                            this.nomDestinataireAnim = comp;
                        } }>
                             {
                                  
                                    this.setState({ nomsDestinataire });
                                    
                                } }
                                style={styles.input}
                            >
                            
                        
                         {
                            this.prenomsDestinataireAnim = comp;
                        } }>
                                 {
                                        this.setState({ prenomsDestinataire });
                                    } }
                                    style={styles.input}
                                >
                                
                        
                    >
                      )}
                     {
                        this.typeIdDestinataireAnim = comp
                    }}
                                     style={{
                                         width: responsiveWidth(90),
                                         height: 60,
                                         marginTop: 20,
                                         alignSelf: 'center',
                                         borderRadius: 10,
                                         paddingLeft: 20,
                                         paddingRight: 20,
                                         backgroundColor: 'white'
                                     }}>
                         {
                                this.setState({typeIdDestinataireSelect: value});
                            }}
                            valueExtractor={(value) => {
                                return value.value
                            }}
                            labelExtractor={(value) => {
                                return I18n.t(value.name)
                            }}
                        />
                
                    
                     {
                        this.numeroTelephoneAnim = comp
                    }}>
                         {
                                  this.setState({numeroTelephoneOrWalletCode})
                              }}
                              style={styles.input}
                        >
                        
                    
                     {
                        this.identityPiecesAnim = comp
                    }}
                                     style={{
                                         width: responsiveWidth(90),
                                         height: 60,
                                         marginTop: 20,
                                         alignSelf: 'center',
                                         borderRadius: 10,
                                         paddingLeft: 20,
                                         paddingRight: 20,
                                         backgroundColor: 'white'
                                     }}>
                         {
                                this.setState({identityPiecesName: value});
                            }}
                            valueExtractor={(value) => {
                                return I18n.t(value.name)
                            }}
                            labelExtractor={(value) => {
                                return I18n.t(value.name)
                            }}
                        />
                    
                     {
                        this.numeroIdentiteAnim = comp
                    }}>
                         {
                                  this.setState({numeroIdentite})
                              }}
                              style={styles.input}
                        >
                        
                    
                     {
                        this.montantAnim = comp
                    }}>
                         {
                                  this.setState({montant})
                              }}
                              style={styles.input}
                        >
                        
                        
                            
                            {this.state.wallet.currency_code}
                        
                    
                     {
                        this.passwordAnim = comp
                    }}>
                         {
                                  this.setState({password})
                              }}
                              style={styles.input}
                        >
                        
                    
                    
                
            >
        )
    }
}
const maptStateToProps = state => ({
    loadingCountryByDialCode: state.countryByDialCode.loading,
    resultCountryByDialCode: state.countryByDialCode.result,
    errorCountryByDialCode: state.countryByDialCode.error,
    loadingActiveCountryList: state.activeCountryListReducer.loading,
    resultActiveCountryList: state.activeCountryListReducer.result,
    errorActiveCountryList: state.activeCountryListReducer.error,
    loadingPayCountryNetwork: state.payCountryNetworkReducer.loading,
    resultPayCountryNetwork: state.payCountryNetworkReducer.result,
    errorPayCountryNetwork: state.payCountryNetworkReducer.error,
    loadingEnvoieWalletToWallet: state.envoieUserWalletToWalletReducer.loading,
    resultEnvoieWalletToWallet: state.envoieUserWalletToWalletReducer.result,
    errorEnvoieWalletToWallet: state.envoieUserWalletToWalletReducer.error,
    loadingEnvoieWalletToWalletGetCommission: state.envoieUserWalletToWalletGetCommissionReducer.loading,
    resultEnvoieWalletToWalletGetCommission: state.envoieUserWalletToWalletGetCommissionReducer.result,
    errorEnvoieWalletToWalletGetCommission: state.envoieUserWalletToWalletGetCommissionReducer.error,
});
const mapDispatchToProps = dispatch => bindActionCreators({
    getActiveCountryByDialCodeAction,
    getActiveCountryByDialCodeReset,
    getPayCountryNetworkAction,
    getPayCountryNetworkReset,
    getActiveCountryAction,
    getActiveCountryReset,
    envoieUserWalletToWalletAction,
    envoieUserWalletToWalletReset,
    getCommissionUserWalletToWalletAction,
    getCommissionUserWalletToWalletReset
}, dispatch);
export default connect(maptStateToProps, mapDispatchToProps)(EnvoieWalletToWalletUser);
const styles = StyleSheet.create({
    container: {
        flex: 1,
        backgroundColor: Color.primaryDarkColor,
    },
    textbtnvalide: {
        color: 'white',
        fontWeight: 'bold'
    },
    bigtitle: {
        color: 'white',
        fontSize: 20,
        flex: 1,
        fontWeight: 'bold',
        textAlign: 'center',
        margin: 20,
    },
    blockView: {
        paddingVertical: 10,
        borderBottomWidth: 1
    },
    subbigtitle: {
        color: 'white',
        fontSize: 17,
        textAlign: 'center',
        margin: 5,
    },
    btnvalide: {
        marginTop: 20,
        marginLeft: 20,
        marginRight: 20,
        borderColor: 'transparent',
        backgroundColor: Color.accentLightColor,
        height: 52
    },
    btnSubmit: {
        marginTop: 20,
        borderColor: 'transparent',
        backgroundColor: Color.accentLightColor,
        height: 52,
        width: "30%",
        marginLeft: 20,
        marginRight: 20,
    },
    input: {
        height: 60,
        marginTop: responsiveHeight(2),
        marginLeft: responsiveWidth(5),
        marginRight: responsiveWidth(5),
        borderRadius: 5,
    }
});