import React, { Component } from 'react';
import {
     Platform,
     StyleSheet,
     AppState,
     FlatList,
     ProgressBarAndroid,
     TouchableOpacity,
     Text,
     View,
     Animated,
     StatusBar
} from 'react-native';
import ActionButton from 'react-native-action-button';
import Icon from 'react-native-vector-icons/MaterialIcons';
import { responsiveFontSize, responsiveHeight, responsiveWidth } from 'react-native-responsive-dimensions';
import { HistoryListItem, HistoryItemSectionned } from '../history-request/HistoryItem';
import { credrequester } from './../../route.json';
import { loadDemandeCredit, loadMyDemandeCredit } from './../../webservice/HistoryRequestApi';
import FontAwesome5 from 'react-native-vector-icons/FontAwesome5';
import BaseScreen from './../../screens/BaseScreen'
import Button from 'apsl-react-native-button'
import { readUser } from "../../webservice/AuthApi";
import Calendar from 'react-native-calendario';
let route = require('./../../route.json')
import 'moment';
import 'moment/locale/fr'
import 'moment/locale/es-us'
import 'moment/locale/en-au'
import 'moment/locale/en-ca'
import 'moment/locale/en-ie'
import 'moment/locale/en-il'
import 'moment/locale/en-nz'
import 'moment/locale/en-gb'
import moment from 'moment-timezone';
let theme = require('./../../utils/theme.json')
import { primary, primaryDark, accent, purpleLight, primaryLight } from './../../utils/theme.json';
import { PagerTabIndicator, PagerTitleIndicator, PagerDotIndicator } from 'react-native-best-viewpager'
var sortIcons;
var sectionIcons;
import I18n from 'react-native-i18n'
require('./../../utils/Translations')
import { SinglePickerMaterialDialog } from 'react-native-material-dialog';
import { Header } from "react-native-elements";
import { withNavigationFocus } from "react-navigation";
import IconWithBadge from "../IconWithBadge";
import { Appbar, Paragraph, Menu, Divider, Provider } from 'react-native-paper';
import DeviceInfo from 'react-native-device-info'
class DemandValidationGroup extends React.Component {
     static navigatorStyle = {
          navBarBackgroundColor: primary,
          statusBarColor: primaryDark,
          navBarTextColor: '#FFFFFF',
          navBarButtonColor: '#FFFFFF',
          contextualMenuStatusBarColor: theme.accent,
          contextualMenuBackgroundColor: theme.accentLight,
          contextualMenuButtonsColor: '#ffffff'
     };
     static navigationOptions = ({ navigation }) => {
          const { routeName } = navigation.state
          return {
               tabBarLabel: routeName === "demandeValidationGroupe" ? I18n.t('MANAGE_GROUP') : I18n.t('DEMAND_RECEIVE'),
               tabBarIcon: ({ focused, horizontal, tintColor }) => {
                    return ()
               },
               drawerLabel: I18n.t('MANAGE_GROUP'),
               drawerIcon: ({ tintColor }) => (
                    
               ),
          }
     };
     constructor(props) {
          super(props, true);
          this.state = this.initState();
          readUser().then((user) => { this.setState({ user: user }) })
          this._populateIcons().then(() => {
          });
          this.navigation = this.props.navigation
          this.currentLocale = DeviceInfo.getDeviceLocale().includes("fr") ? "fr" : "en-gb";
          //moment.locale(this.currentLocale);
     };
     navigationButtonPressed({ buttonId }) {
          if (buttonId === 'id') {
               this.showFilter();
          } else if (buttonId === 'sectionned') {
               this.setState({ isSectionned: !this.state.isSectionned })
          }
     }
     showFilter() {
          /*if (this.state.filter) {
              Navigation.mergeOptions(route.stackRoot,
                  {
                  topBar: {
                      rightButtons: [
                          {
                              title: 'Non Traité',
                          },
                          {
                              title: 'Traité',
                          },
                          {
                              title: 'Période',
                          },
                          {
                              title: 'Tout',
                          },
                          {
                              title: 'Trier par',
                          },
                          {
                              title: '',
                          },
                      ],
                      onButtonPressed: (index) => {
                          let data = this.state.conserve
                          console.log(index)
                          console.log(data);
  
                          if (data !== null) {
                              let filtre = "";
                              if (index < 2) {
                                  switch (index) {
                                      case 0:
                                          filtre = I18n.t('NO_TREAT')
                                          break;
                                      case 1:
                                          filtre = I18n.t('TREAT');
                                          break;
  
                                  }
                                  let fi = data.filter(item => item.statut === filtre)
                                  this.setState({listdata: fi, filter: true})
                              } else if (index === 2) {
                                  this.setState({panelVisible: true})
                              } else {
                                  this.setState({listdata: data, filter: false})
                              }
                          }
                      }
                  }}
              );
  
          } else {
              Navigation.mergeOptions(route.stackRoot,
                  {
                      topBar: {
                          rightButtons: [
                              {
                                  title: I18n.t('NO_TREAT'),
                              },
                              {
                                  title: I18n.t('TREAT'),
                              }
                              , {
                                  title: I18n.t('PERIOD'),
                              },
                              {
                                  title: '',
                              },
                              {
                                  title: 'Trier par',
                              }, {
                                  title: '',
                              },
                          ],
                          onButtonPressed: (index) => {
                              let data = this.state.conserve
                              if (data != null && data.length > 0) {
                                  var filtre = "";
                                  if (index < 2) {
                                      switch (index) {
                                          case 0:
                                              filtre = I18n.t('NO_TREATED');
                                              break;
                                          case 1:
                                              filtre = I18n.t('TREATED');
                                              break;
  
                                      }
                                      let fi = data.filter(item => item.statut === filtre)
                                      this.setState({listdata: fi, filter: true})
                                  } else if (index === 2) {
                                      this.setState({panelVisible: true})
                                      this.props.navigator.showContextualMenu(
                                          {
                                              rightButtons: [
                                                  {
                                                      title: I18n.t('CANCEL'),
                                                  },
                                                  {
                                                      title: I18n.t('FILTER'),
                                                  },
  
                                              ],
                                              onButtonPressed: (index) => {
                                                  console.log(index)
  
                                                  switch (index) {
                                                      case 1:
                                                          let {dateend, datestart} = this.state;
                                                          this.onfilterPress();
                                                  }
                                                  this.setState({panelVisible: false});
                                              }
                                          }
                                      );
                                  } else {
                                      this.setState({listdata: data, filter: false})
                                  }
                              }
                          }
                      }
                  }
              );
  
          }*/
     }
     _populateIcons = function () {
          return new Promise(function (resolve, reject) {
               Promise.all(
                    [
                         Icon.getImageSource('sort', 30),
                         Icon.getImageSource('layer-group', 30),
                    ]
               ).then((values) => {
                    sortIcons = values[0];
                    sectionIcons = values[1];
                    resolve(true);
               }).catch((error) => {
                    console.log(error);
                    reject(error);
               }).done();
          });
     };
     initState() {
          return {
               user: {},
               listdata: [],
               listdataSend: [],
               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
          }
     }
     updateList(data) {
          if (!this.state.filter) {
               let rev = data.reverse()
               this.setState({ listdata: rev, conserve: rev, isLoaded: true });
          }
     }
     updateMyList(data) {
          if (!this.state.filter) {
               let rev = data.reverse()
               this.setState({ listdataSend: rev, conserve: rev, isLoaded: true });
          }
     }
     componentDidMount() {
          const { routeName } = this.navigation.state
          this.setState({ position: routeName === "demandeValidationGroupe" ? 0 : 1 })
          this.refreshData()
          /*           this.intervaller = setInterval(() => {
                         this.refreshData(false)
                    }, 2000) */
          this.animateSlidingUp(false)
          this.props.navigation.addListener("didFocus", () => {
               this.refreshData(false)
               console.warn("loading")
          })
     }
     componentWillUnmount() {
          clearInterval(this.intervaller)
     }
     renderOptionsMenu() {
          return (
               
                    
               
          )
     }
     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 });
     render() {
          return (
               
                    
                         
                         {this.renderSliding()}
                         
                               { this.props.navigation.pop() }}
                              />
                              
                               { this.refreshData() }} />
                               { this._openMenu(); this.renderSliding(); }} />
                         
                         {this.renderOptionsMenu()}
                         {this.state.position === 0 ? this._renderListDemandsSend() : this._renderListDemandReceive()}
                    
               
          );
     }
     renderSliding() {
          return (
               
                     console.log(range)}
                         minDate="2018-04-20"
                         startDate="2018-04-30"
                         endDate="2018-05-05"
                         theme={{
                              activeDayColor: {},
                              monthTitleTextStyle: {
                                   color: '#6d95da',
                                   fontWeight: '300',
                                   fontSize: 16,
                              },
                              emptyMonthContainerStyle: {},
                              emptyMonthTextStyle: {
                                   fontWeight: '200',
                              },
                              weekColumnsContainerStyle: {},
                              weekColumnStyle: {
                                   paddingVertical: 10,
                              },
                              weekColumnTextStyle: {
                                   color: '#b6c1cd',
                                   fontSize: 13,
                              },
                              nonTouchableDayContainerStyle: {},
                              nonTouchableDayTextStyle: {},
                              startDateContainerStyle: {},
                              endDateContainerStyle: {},
                              dayContainerStyle: {},
                              dayTextStyle: {
                                   color: '#2d4150',
                                   fontWeight: '200',
                                   fontSize: 15,
                              },
                              dayOutOfRangeContainerStyle: {},
                              dayOutOfRangeTextStyle: {},
                              todayContainerStyle: {},
                              todayTextStyle: {
                                   color: '#6d95da',
                              },
                              activeDayContainerStyle: {
                                   backgroundColor: '#6d95da',
                              },
                              activeDayTextStyle: {
                                   color: 'white',
                              },
                              nonTouchableLastMonthDayTextStyle: {}
                         }}
                         style={{ height: responsiveHeight(60) }}
                    />
                    
                         
                         
                    
               )
     }
     renderSectionnedList(list) {
          if (this.state.isLoaded) {
               let data = list;
               if (data !== null) {
                    if (data.length > 0) {
                         return ( this.refreshData()}
                              style={styles.listbackground} />)
                    } else if (this.state.filter) {
                         return (
                              
                                   {I18n.t('NO_ITEMS_REQUEST')}
                              
                         )
                    } else {
                         return (
                              
                                   
                                   {I18n.t('LOADING_DOTS')}
                              
                         )
                    }
               } else {
                    return (
                         
                              {I18n.t('EMPTY_LIST_REQUEST')}
                         
                    )
               }
          }
     }
     renderList(list) {
          if (this.state.isLoaded && list instanceof Array) {
               let data = list;
               if (data !== null) {
                    if (data.length > 0) {
                         return ( { this.refreshData() }}
                              refresh={() => this.refreshData()}
                              isRefreshing={this.state.isRefreshing}
                              navigator={this.props.navigation}
                              style={styles.listbackground}
                              isDemandSend={this.state.position === 0} />)
                    } else if (this.state.filter) {
                         return (
                              
                                   {I18n.t('NO_ITEM_REQUEST')}
                              
                         )
                    } else if (data.length === 0) {
                         return (
                              
                                   {I18n.t('NO_ITEM_REQUEST')}
                              
                         )
                    } else {
                         return (
                              
                                   
                                   {I18n.t('LOADING_DOTS')}
                              
                         )
                    }
               } else {
                    return (
                         
                              {I18n.t('EMPTY_LIST_REQUEST')} 
                         
                    )
               }
          } else if (list.length === 0) {
               return (
                    
                         {I18n.t('NO_ITEM_REQUEST')}
                    
               )
          }
     }
     renderLoading() {
          return ({I18n.t('LOADING_DOTS')})
     }
     showSlidingUpPanel() {
          /*  return ( this.panel = c}
                draggableRange={{top: responsiveHeight(100), bottom: 0}}
                onRequestClose={() => this.setState({panelVisible: false})}>
                
                    {this.showSlidingUpView()}
                
            )
        }
  
        showSlidingUpView() {
          /*  return (
                
                    
                     this._handleDatePicked(fromdate,untildate)}
                            dayHeadings={['D', 'L', 'M', 'M', 'J', 'V', 'S']}
                            maxMonth={12}
                            startdate={moment('20180101').format('YYYYMMDD')}
                            untilDate='20181231'
                            minDate='20180101'
                            maxDate='20181231'
                            buttonColor='green'
                            showReset={false}
                    showClose={false}
                    placeHolderStart= 'Date de debut'
                    placeHolderUntil= 'Date fin'
                    selectedBackgroundColor= 'green'
                    selectedTextColor='white'
                        />
                
                
  
                    )*/
     }
     /*
     onfilterPress() {
          let { datestart, dateend } = this.state;
          let data = this.state.conserve;
          if (data !== null) {
               data = data.filter(item => {
                    let mda = moment(item.dateAjout)
                    return moment(item.dateAjout).isAfter(moment(datestart).toDate()) && (mda.isBefore(moment(dateend).toDate()))
               })
               this.setState({ listdata: data, panelVisible: false, filter: true })
          }
     }
     */
     _showDateTimePicker = (type) => {
          if (type === 1)
               this.setState({
                    isDateTimePickerVisible: true
               });
          else this.setState({
               isDateEndTimePickerVisible: true
          });
     }
     _showDateEndPicker = () => this.setState({ isDateEndTimePickerVisible: true });
     _hideDateTimePicker = () => this.setState({ isDateTimePickerVisible: false, isDateEndTimePickerVisible: false });
     /*
     _handleDatePicked = (fromdate, enddate) => {
          console.log([fromdate, enddate]);
          this.setState({
               datestart: fromdate,
               datestartformated: moment(fromdate).format('dddd Do ,MMMM YYYY'),
               dateend: enddate,
               dateendformated: moment(enddate).format('dddd Do ,MMMM YYYY')
          });
          let startdate = this.state.datestart;
          let enddatemo = moment(enddate);
          let dif = moment(enddatemo).diff(startdate);
          if (dif < 0) {
               this.setState({ filder_disable: true });
               this.props.navigator.showSnackbar({
                    text: I18n.t('DATE_WRONG'),
                    duration: 'long',
                    backgroundColor: 'red',
                    textColor: 'white'
               })
          } else {
               this.setState({ filder_disable: false });
          }
          this._hideDateTimePicker();
     };
     */
     printOptions() {
          if (this.state.user.category === "hyper") {
               return (
                     {
                    }}>
                         
                    
               );
          } else {
               return (
                     {
                              this.props.navigation.push(route.credrequester, {
                                   onGoBack: () => this.refreshData()
                              })
                         }}
                    >
                         
                    
                     {
                    }}>
                         
                    
               )
          }
     }
     _renderListDemandsSend() {
          console.log('this.state', this.state);
          return (
               {
                    this.state.isLoaded ?
                         this.state.isSectionned ?
                              this.renderSectionnedList(this.state.listdataSend) :
                              this.renderList(this.state.listdataSend) : this.renderLoading()
               }
               {this.printOptions()}
               {this.showSlidingUpPanel()}
          
          )
     }
     _renderListDemandReceive() {
          return (
               {
                    this.state.isLoaded ?
                         this.state.isSectionned ?
                              this.renderSectionnedList(this.state.listdata) :
                              this.renderList(this.state.listdata) : this.renderLoading()
               }
               {this.printOptions()}
               {this.showSlidingUpPanel()}
          
          )
     }
     _renderTabGeolocated() {
          let tabs = [{
               text: I18n.t('DEMAND_SEND'),
          }]
          return ;
     }
     _renderTabHyper() {
          let tabs = [{
               text: I18n.t('DEMAND_RECEIVE'),
          }]
          return ;
     }
     _renderTabs() {
          let tabs = [{
               text: I18n.t('VALIDATION_DEMAND'),
               iconSource: this.state.usersicon
          }, {
               text: I18n.t('DELETE_DEMAND'),
               iconSource: this.state.charticon
          }]
          return ;
     }
     refreshData(autoref = true) {
          if (autoref)
               this.setState({ isRefreshing: true })
          loadDemandeCredit().then((data) => {
               if (data.success !== undefined) {
                    this.setState({ listdata: [] })
                    this.updateList(data.demands);
                    if (this.state.position !== 0) this.props.navigation.setParams({ count: data.demands.length })
                    this.setState({ isRefreshing: false })
               }
          }).catch((e) => {
               console.warn(e)
          });
          loadMyDemandeCredit().then((data) => {
               if (data.success !== undefined) {
                    this.setState({ listdataSend: [] })
                    this.setState({ isRefreshing: false })
                    if (this.state.position === 0) this.props.navigation.setParams({ count: data.demands.length })
                    this.updateMyList(data.demands)
               }
          }).catch((e) => {
               console.warn(e)
          });
     }
}
export default DemandValidationGroup;
const datefilter = StyleSheet.create({
     titleHeader: {
          fontSize: 20,
          fontWeight: 'bold',
          color: 'black',
          flex: 1,
     },
     datetitle: {
          fontSize: 17,
          color: 'black',
          marginLeft: responsiveWidth(2),
     },
     datetext: {
          fontSize: 16,
          marginLeft: responsiveWidth(5)
     },
     content: {
          flex: 2,
     },
     btnContainer: {
          flexDirection: 'row',
          width: responsiveWidth(100),
          alignSelf: 'flex-end',
          flex: 2,
     },
     btn: {
          flex: 1,
          borderColor: 'transparent',
          borderRadius: 0,
     },
     btntext: {
          fontWeight: 'bold',
          color: accent
     },
     container: {
          flex: 1,
          justifyContent: 'space-evenly'
     }
})
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',
     },
     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'
     },
     content: {
          flex: 8
     },
     title: {
          fontSize: 20,
          marginLeft: 20,
          marginTop: 20,
          color: 'black',
          fontWeight: 'bold'
     },
});