import React from 'react';
import {
    Animated,
    AppState,
    Platform,
    ProgressBarAndroid,
    StatusBar,
    StyleSheet,
    Text,
    TouchableOpacity,
    View
} from 'react-native';
import ActionButton from 'react-native-action-button';
import Icon from 'react-native-vector-icons/MaterialCommunityIcons';
import {responsiveFontSize, responsiveHeight, responsiveWidth} from 'react-native-responsive-dimensions';
import {readUser} from "../../webservice/AuthApi";
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';
import {accent, primary, primaryDark, purpleLight} from './../../utils/theme.json';
import I18n from 'react-native-i18n'
import {Appbar, Provider} from 'react-native-paper';
import {bindActionCreators} from 'redux';
import {connect} from 'react-redux';
import {getNanoCreditDemandsAction, getNanoCreditDemandsReset} from '../../webservice/user/NanoCreditApi';
import {IlinkEmitter} from '../../utils/events';
import {Typography} from '../../config/typography';
import {ScrollView} from 'react-native-gesture-handler';
import {Color} from '../../config/Color';
let route = require('./../../route.json')
let theme = require('./../../utils/theme.json')
var sortIcons;
var sectionIcons;
require('./../../utils/Translations')
class DemandValidationGroup extends React.Component {
    constructor(props) {
        super(props, true);
        this.state = {
            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,
            isDateEndTimePickerVisible: false,
            isDataSubmit: false,
            position: 0
        };
        readUser().then((user) => {
            this.setState({user: user});
            this.props.getNanoCreditDemandsAction(user.id);
        });
        IlinkEmitter.on("langueChange", this.updateLangue.bind(this));
        this.props.getNanoCreditDemandsReset();
        this.navigation = this.props.navigation
        this.currentLocale = I18n.locale.includes("fr") ? "fr" : "en-gb";
        moment.locale(this.currentLocale);
        //IlinkEmitter.on('treatNanoGroupDemand', this.refreshData);
    };
    static navigatorStyle = {
        navBarBackgroundColor: primary,
        statusBarColor: primaryDark,
        navBarTextColor: '#FFFFFF',
        navBarButtonColor: '#FFFFFF',
        contextualMenuStatusBarColor: theme.accent,
        contextualMenuBackgroundColor: theme.accentLight,
        contextualMenuButtonsColor: '#ffffff'
    };
    updateLangue() {
        this.props.navigation.setParams({name: I18n.t('WALLET')})
        this.forceUpdate()
    }
    componentDidMount() {
        const {routeName} = this.navigation.state
        this.setState({
            position: routeName === "demandeValidationGroupe" ? 0
                : routeName === "myNanoCreditGroup" ? 1
                    : 2
        });
        this.animateSlidingUp(false)
    }
    componentWillUnmount() {
        clearInterval(this.intervaller)
    }
    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()
    }
    _openMenu = () => this.setState({visibleMenu: true});
    _closeMenu = () => this.setState({visibleMenu: false});
    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
        }
    }
    renderDemandItem = (item) => {
        let dateFormat = moment.tz(item.date_creation_demande, moment.tz.guess()).format();
        dateFormat = moment(dateFormat).fromNow();
        return (
             {
                this.props.navigation.push(route.demandGroupNanoCreditDetail, {
                    id: item.id
                });
            }}
                              style={[styles.paymentItem]}>
                
                    
                        
                    
                
                
                    {item.nom}
                    {`${I18n.t('CREATOR')}: ${item.createur}`}
                    {/* {`Sponsor 1: ${item.sponsor1}`}
                         {`Sponsor 2:  ${item.sponsor2}`}
                         {`Sponsor 3:  ${item.sponsor3}`} */}
                    
                        
                            
                                {item.nombre_validation === 3 ? I18n.t('VALIDATE') : I18n.t('NO_VALIDATE')}
                                {` (${item.nombre_validation} ${item.nombre_validation > 1 ? I18n.t('VALIDATIONS') : I18n.t('VALIDATION')})`}
                            
                        
                        
                            
                            {item.country}
                            
                             {dateFormat}
                        
                    
                
            
        )
    }
    rendeGetDemandsGroupResponse = () => {
        const {resultGetDemandsGroup, errorGetDemandsGroup} = this.props;
        if (errorGetDemandsGroup !== null) {
            if (typeof errorGetDemandsGroup.data !== 'undefined') {
                return (
                    
                        {errorGetDemandsGroup.data.error}
                    
                )
            } else {
                return (
                    
                        {errorGetDemandsGroup}
                    
                )
            }
        }
        if (resultGetDemandsGroup !== null) {
            if (resultGetDemandsGroup.response !== null) {
                return (
                    Array.isArray(resultGetDemandsGroup.response) && (resultGetDemandsGroup.response.length) > 0 ?
                        (
                            {
                                resultGetDemandsGroup.response.map((item) => (
                                    this.renderDemandItem(item)
                                ))
                            }
                        ) :
                        (
                            
                                {I18n.t('NO_DEMAND_CREATION_GROUP')}
                            
                        )
                )
            }
        }
    }
    renderLoader = () => {
        return (
            
                {Platform.OS === 'android'
                    ?
                    (
                        <>
                            
                            {I18n.t('LOADING_DOTS')}
                        >
                    ) :
                    <>
                        
                        {I18n.t('LOADING_DOTS')}
                    >
                }
            
        )
    }
    printOptions() {
        return (
             {
                                   this.props.navigation.push(route.createGroupNanoCredit);
                               }}
            >
                
            
             {
                                   this.props.navigation.push(route.adhererGroupNanoCredit);
                               }}
            >
                
            
        )
    }
    refreshData() {
        this.props.getNanoCreditDemandsAction(this.state.user.id);
    }
    render() {
        console.warn("POSITION", this.state.position);
        return (
            
                
                    
                    
                         {
                                this.props.navigation.pop()
                            }}
                        />
                        
                         {
                            this.refreshData()
                        }}/>
                        {/*  { this._openMenu(); this.renderSliding(); }} /> */}
                    
                    {this.state.position === 0 ?
                        this.props.loadingGetDemandsGroup ?
                            this.renderLoader() :
                            this.rendeGetDemandsGroupResponse()
                        : null}
                    {this.state.position === 0 && this.printOptions()}
                
            
        );
    }
}
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);
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',
    },
    descriptionIcon: {
        fontSize: 10,
        height: 12,
        top: 10
    },
    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'
    },
    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,
    },
    paymentItem: {
        flexDirection: "row",
        alignItems: "center",
        justifyContent: "space-between",
        width: "100%",
        borderBottomColor: '#EEE',
        borderBottomWidth: 1
    },
    iconContent: {
        width: 40,
        marginRight: 5,
        alignItems: "center"
    }
});