import React, { Component } from 'react';
import { Dimensions, Platform, StyleSheet, View, Alert, StatusBar, ScrollView, Text, ProgressBarAndroid, ActivityIndicator, TouchableOpacity } from 'react-native';
import Icon from 'react-native-vector-icons/MaterialCommunityIcons';
import I18n from 'react-native-i18n'
import LottieView from 'lottie-react-native';
import * as Utils from '../../utils/DeviceUtils';
import Icons from 'react-native-vector-icons/Ionicons'
import { Images } from '../../config/Images';
import CustomButton from '../../components/CustomButton';
import OutlineTextInput from '../../components/OutlineTextInput';
import { Color } from '../../config/Color';
import Tag from '../../components/Tag';
import { IlinkEmitter } from "../../utils/events";
import { CreditCardInput, LiteCreditCardInput } from "react-native-credit-card-input";
import { Typography, FontWeight } from '../../config/typography';
import { depositAction, depositActionReset } from '../../webservice/DepositApi';
import { getWalletCommissionAmount, walletCommissionAmountReset, resetWalletListDetailReducer } from '../../webservice/WalletApi';
import Dialog from "react-native-dialog";
import { ProgressDialog } from 'react-native-simple-dialogs';
import { Dropdown } from 'react-native-material-dropdown';
import isEqual from 'lodash/isEqual';
//import Dialog, { DialogContent, DialogTitle, DialogFooter, DialogButton } from 'react-native-popup-dialog';
let moment = require('moment-timezone');
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 { connect } from 'react-redux';
import { bindActionCreators } from 'redux';
import style from '../../components/TextInput/styles';
import { responsiveHeight, responsiveWidth, } from 'react-native-responsive-dimensions';
import { identityPieces, inputCardSource } from '../../utils/UtilsFunction';
const CONTAINER_WIDTH = Dimensions.get("window").width;
class WalletDepot extends Component {
     static navigatorStyle = {
          navBarBackgroundColor: Color.accentLightColor,
          statusBarColor: Color.accentColor,
          navBarTextColor: '#FFFFFF',
          navBarButtonColor: '#FFFFFF',
     };
     static navigationOptions = ({ navigation }) => {
          return {
               drawerLabel: () => null,
               title: I18n.t('MAKE_DEPOSIT'),
               headerStyle: {
                    backgroundColor: Color.primaryColor,
                    marginTop: 23,
                    color: 'white'
               },
               headerTitleStyle: {
                    color: "white"
               }
          };
     }
     constructor(props) {
          super(props);
          this.state = {
               type: "credit",
               montant: '',
               numeroSerie: '',
               numCarte: 0,
               cvv: 0,
               expiration_date: '',
               creditCardInput: {},
               comptePrincipal: this.props.navigation.state.params.wallet.balance_princ,
               id: this.props.navigation.state.params.wallet.id,
               isModalConfirmVisible: false,
               isDataSubmit: false,
               isSubmitClick: false,
               displayCardError: false,
               inputCardSource: inputCardSource(),
               isDisplaySerialTextInput: true,
               facade: "back"
          };
          this.props.walletCommissionAmountReset();
          this.props.depositActionReset();
          IlinkEmitter.on("langueChange", this.updateLangue.bind(this));
     }
     componentWillReceiveProps(nextProps) {
          if (nextProps.resultGetCommission != null) {
               if (typeof nextProps.resultGetCommission.response !== 'undefined') {
                    if (!nextProps.loadingGetCommission)
                         this.setState({
                              isModalConfirmVisible: true
                         });
               }
          }
     }
     updateLangue() {
          this.props.navigation.setParams({ name: I18n.t('WALLET') })
          this.forceUpdate()
     }
     onCreditCardChange = (form) => {
          console.log(form);
          this.setState({
               creditCardInput: form,
               displayCardError: false
          });
     }
     isNormalInteger = (str) => {
          if (/[ `!@#$%^&*()_+\-=\[\]{};':"\\|,.<>\/?~]/.test(str))
               return false;
          else
               return true;
     }
     isMontantValid = () => {
          const { montant } = this.state;
          if ((parseInt(isEqual(montant, 0)) || montant < 0))
               return {
                    errorMessage: I18n.t('ENTER_AMOUNT_SUPERIOR_ZEROR'),
                    isValid: false
               };
          else if (!this.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
               };
     }
     isNumeroSerieValid = () => {
          const { numeroSerie } = this.state;
          if ((parseInt(isEqual(numeroSerie, 0)) || numeroSerie < 0))
               return {
                    errorMessage: I18n.t('ENTER_VALID_SERIAL_NUMBER'),
                    isValid: false
               };
          else if (!this.isNormalInteger(numeroSerie)) {
               return {
                    errorMessage: I18n.t('ENTER_VALID_SERIAL_NUMBER'),
                    isValid: false
               };
          }
          else if (numeroSerie.length > 11) {
               return {
                    errorMessage: I18n.t('ENTER_VALID_SERIAL_NUMBER'),
                    isValid: false
               };
          }
          else
               return {
                    errorMessage: '',
                    isValid: true
               };
     }
     isCreditCardValid = () => {
          const { creditCardInput } = this.state;
          const errorMessage = [];
          if (typeof creditCardInput.status !== 'undefined') {
               if (creditCardInput.status.cvc === 'incomplete')
                    errorMessage.push(I18n.t('CVC_CARD_ERROR'));
               if (creditCardInput.status.expiry === 'incomplete')
                    errorMessage.push(I18n.t('EXPIRY_CARD_ERROR'));
               if (creditCardInput.status.number === 'incomplete')
                    errorMessage.push(I18n.t('CARD_NUMBER_ERROR'));
          }
          else
               errorMessage.push(I18n.t('THIS_FIELD_IS_REQUIRED'))
          return errorMessage;
     }
     commissionsLoading = () => {
          return (
               
          )
     }
     modalConfirmTransaction = (data) => {
          const commission = data.response.commission;
          const montant_calcule = data.response.montant_calcule;
          console.log("DATA SEND TO CONFIRM DIALOG", data);
          return (
               
                    {I18n.t('CONFIRM_DEPOSIT')}
                    
                         
                              
                                   
                                        {I18n.t('AMOUNT')}
                                   
                                   
                                        {this.state.montant}
                                   
                              
                              
                                   
                                        {I18n.t('COMMISSION_FEES')}
                                   
                                   
                                        {commission}
                                   
                              
                         
                         
                              
                                   
                                        {I18n.t('TOTAL')}
                                   
                                   
                                        {montant_calcule}
                                   
                              
                         
                    
                     {
                         this.setState({
                              isModalConfirmVisible: false
                         });
                    }} />
                     {
                         this.setState({
                              isModalConfirmVisible: false,
                              isDataSubmit: true
                         });
                         this.props.walletCommissionAmountReset();
                         if (isEqual(this.state.facade, 'front')) {
                              this.props.depositAction({
                                   numCarte: this.state.creditCardInput.values.number.replace(/\s/g, ''),
                                   cvv: this.state.creditCardInput.values.cvc,
                                   expiration_date: this.state.creditCardInput.values.expiry,
                                   type: "credit",
                                   montant: this.state.montant,
                                   id_wallet: this.state.id,
                                   facade: this.state.facade
                              });
                         }
                         else {
                              this.props.depositAction({
                                   numCarte: this.state.numeroSerie,
                                   type: "credit",
                                   montant: this.state.montant,
                                   id_wallet: this.state.id,
                                   facade: this.state.facade
                              });
                         }
                    }} />
               
          );
     }
     onSubmitDeposit = () => {
          const { creditCardInput } = this.state;
          if (isEqual(this.state.facade, 'back')) {
               if (this.isMontantValid().isValid && this.isNumeroSerieValid().isValid && this.state.montant.length > 0) {
                    this.setState({
                         numCarte: this.state.numeroSerie
                    });
                    this.props.getWalletCommissionAmount({
                         type: "credit",
                         montant: this.state.montant,
                         id_wallet: this.state.id
                    });
               }
          } else {
               if (this.isMontantValid().isValid && creditCardInput.valid && this.state.montant.length > 0) {
                    this.setState({
                         numCarte: parseInt((creditCardInput.values.number).replace(/ /g, ' ')),
                         cvv: creditCardInput.values.cvc,
                         expiration_date: creditCardInput.values.expiry,
                    });
                    this.props.getWalletCommissionAmount({
                         type: "credit",
                         montant: this.state.montant,
                         id_wallet: this.state.id
                    });
               }
               else if (!creditCardInput.valid) {
                    this.setState({
                         displayCardError: true
                    })
               }
          }
          this.setState({ isSubmitClick: true });
     }
     renderDialogGetCommissionResponse = () => {
          const { errorGetCommission } = this.props;
          if (errorGetCommission !== null) {
               if (typeof errorGetCommission.data !== 'undefined') {
                    Alert.alert(
                         I18n.t("ERROR_LABLE"),
                         errorGetCommission.data.error,
                         [
                              {
                                   text: I18n.t("OK"), onPress: () => {
                                        //this.props.resetCommissionReducer();
                                   }
                              }
                         ],
                         { cancelable: false }
                    )
               }
          }
     }
     isHasError = () => {
          const { error, result } = this.props;
          if (this.state.isDataSubmit) {
               if (error !== null) {
                    if (typeof error.data !== 'undefined') {
                         Alert.alert(
                              I18n.t("ERROR_LABEL"),
                              error.data.error,
                              [
                                   {
                                        text: I18n.t("OK"), onPress: () => { }
                                   }
                              ],
                              { cancelable: false }
                         );
                         this.props.navigation.state.params.onGoBack();
                         this.props.navigation.pop();
                    }
                    return null;
               }
               else if (result !== null) {
                    setTimeout(() => {
                         this.props.resetWalletListDetailReducer();
                         this.props.navigation.state.params.onGoBack();
                         this.props.navigation.pop();
                    }, 1500);
                    return 
                         
                    
               }
               else
                    return null;
          }
     }
     render() {
          console.log("STATE", this.state);
          const { resultGetCommission } = this.props;
          return (
               
                    {
                         (resultGetCommission !== null) &&
                         (typeof resultGetCommission.response !== 'undefined') &&
                         this.modalConfirmTransaction(resultGetCommission)
                    }
                    {this.isHasError()}
                    {this.commissionsLoading()}
                    {this.state.isSubmitClick && this.renderDialogGetCommissionResponse()}
                    
                         
                              {I18n.t('CHANGE_SOURCE_CARD')}
                               {
                                        this.setState({
                                             isDisplaySerialTextInput: isEqual(value, 'serial-number'),
                                             facade: isEqual(value, 'serial-number') ? 'back' : 'front'
                                        })
                                   }}
                                   valueExtractor={(value) => value.value}
                                   labelExtractor={(value) => value.name}
                              />
                         
                         {!this.state.isDisplaySerialTextInput &&
                              
                                   
                                   {
                                        (this.state.displayCardError) &&
                                        this.isCreditCardValid().map((item) => (
                                             {item}
                                        ))
                                   }
                              
                         }
                         {this.state.isDisplaySerialTextInput &&
                              
                                    {
                                             this.setState({ numeroSerie });
                                             this.isNumeroSerieValid();
                                        }}
                                   />
                                   {
                                        (!this.isNumeroSerieValid().isValid) &&
                                        {this.isNumeroSerieValid().errorMessage}
                                   }
                                   {
                                        (this.state.isSubmitClick && this.state.numeroSerie.length === 0) &&
                                        {I18n.t('ENTER_VALID_SERIAL_NUMBER')}
                                   }
                                   
                              
                         }
                         
                               {
                                        this.setState({ montant });
                                        this.isMontantValid();
                                   }}
                              />
                              {
                                   (!this.isMontantValid().isValid) &&
                                   {this.isMontantValid().errorMessage}
                              }
                              {
                                   (this.state.isSubmitClick && this.state.montant.length === 0) &&
                                   {I18n.t('PLEASE_ENTER_THE_AMOUNT')}
                              }
                              
                         
                         
                               this.onSubmitDeposit()}>
                                   {I18n.t('VALIDATE')}
                              
                         
                    
               
          )
     }
}
const mapStateToProps = state => ({
     loading: state.depositReducer.loading,
     result: state.depositReducer.result,
     error: state.depositReducer.error,
     loadingGetCommission: state.walletGetCommission.loadingGetCommission,
     resultGetCommission: state.walletGetCommission.resultGetCommission,
     errorGetCommission: state.walletGetCommission.errorGetCommission,
});
const mapDispatchToProps = dispatch => bindActionCreators({
     depositAction: depositAction,
     getWalletCommissionAmount: getWalletCommissionAmount,
     walletCommissionAmountReset: walletCommissionAmountReset,
     resetWalletListDetailReducer: resetWalletListDetailReducer,
     depositActionReset
}, dispatch);
export default connect(mapStateToProps, mapDispatchToProps)(WalletDepot);
const styles = StyleSheet.create({
     container: {
          flex: 1,
          backgroundColor: Color.containerBackgroundColor
     },
     checkDefault: {
          flexDirection: "row",
          justifyContent: "space-between",
          alignItems: "center",
          borderBottomWidth: 1,
          paddingVertical: 15,
          marginTop: 10
     },
     contentButtonBottom: {
          borderTopWidth: 1,
          paddingVertical: 10,
          paddingHorizontal: 20,
          flexDirection: "row",
          justifyContent: "space-between",
          alignItems: "center"
     },
     blockView: {
          paddingVertical: 10,
          borderBottomWidth: 1
     },
     lottie: {
          width: 248,
          height: 248
     },
});