UNPKG

react-native-1app

Version:

165 lines (152 loc) 5.46 kB
'use strict'; import React, { Component } from 'react'; import { StyleSheet,Animated, View,Image, TouchableOpacity,Text } from 'react-native'; var moment = require("moment"); import DateTimePicker from 'react-native-modal-datetime-picker' export default class DatePicker extends Component { constructor(props) { super(props); this.state = { fontSize: new Animated.Value((this.validarValue(this.props.value)?12:15)), marginTop: new Animated.Value((this.validarValue(this.props.value)?0:14)), }; } getDate(value){ if(this.props.time == "timeOnly"){ return new Date( moment( moment().format("DD/MM/YYYY")+" "+(value?value:"00:00"), "DD/MM/YYYY HH:mm").toJSON()); // return value; }else{ return new Date(value); } } getDateBr(date){ if(!date){ return ""; } date=this.getDate(date); var br = moment(date).format("DD/MM/YYYY"); if(this.props.time == "timeOnly"){ br = moment(date ).format("HH:mm"); } else if(this.props.time){ br = moment(date ).format("DD/MM/YYYY HH:mm"); } // alert(br) return br; } showDateTimePicker () { this.setState({ isDateTimePickerVisible: true }) } hideDateTimePicker () { this.setState({ isDateTimePickerVisible: false }) } handleDatePicked(date){ var value = moment(date).toJSON(); var br = this.getDateBr(value); try { if(this.props.time == "timeOnly"){ value = br; } this.setState({value: value , isDateTimePickerVisible: false,br:br}); if(this.props.onChange){ this.props.onChange( value ,br) } if(this.props.onChangeText){ this.props.onChange(value ,br) } } catch (e) { console.log(e); // alert(e) } } componentWillReceiveProps(props){ let{fontSize,marginTop}=this.state; if(this.validarValue(props.value)&&!this.validarValue(this.props.value)){ Animated.timing(fontSize,{toValue: 12,duration: 300}).start(); Animated.timing(marginTop,{toValue: 0,duration: 200}).start(); } if(!this.validarValue(props.value)&&this.validarValue(this.props.value)){ Animated.timing(fontSize,{toValue: 15,duration: 300}).start(); Animated.timing(marginTop,{toValue: 14,duration: 300}).start(); } } validarValue(v){ return v==0||v; } render() { const {label='-',value='',time,onChange=()=>console.log("onChange"),style={},disabled,disabledClear,datePickerModeAndroid="calendar"}=this.props; let{fontSize,marginTop,isDateTimePickerVisible}=this.state; // let styleLabel={color:style.color?style.color:styles.value.color,fontSize:style.fontSize?style.fontSize:styles.value.fontSize} return( <TouchableOpacity style={[styles.button,style]} disabled={disabled} onPress={()=>this.showDateTimePicker()}> <View style={styles.view}> <Animated.Text style={[styles.label,{marginTop,fontSize}]}>{label}</Animated.Text> <Text style={[styles.value]}>{this.getDateBr(value)}</Text> </View> {disabledClear&&value?( <TouchableOpacity onPress={() => { onChange( null ,null) } }> <Image style={{width: 20, height: 20}} source={{uri: icon}} /> </TouchableOpacity> ):null} <DateTimePicker date={value?this.getDate(value):new Date()} is24Hour={true} datePickerModeAndroid={datePickerModeAndroid} mode={time == "timeOnly" ? "time" : time ? "datetime":"date" } isVisible={isDateTimePickerVisible} onConfirm={(date)=>{ this.handleDatePicked(date); }} onCancel={()=>{ this.hideDateTimePicker(); }} /> </TouchableOpacity> ) } } var styles = StyleSheet.create({ button: { alignSelf: "stretch", justifyContent: "center", alignItems: "center", height: 45, flexDirection: "row", borderStyle: "solid", borderWidth: 0, borderBottomWidth:0.8, borderColor: "rgba(22,22,22,0.7)", paddingRight:5, marginTop:5, }, view: { alignSelf: "stretch", flex:1, flexDirection: "column", }, value: { color: "rgba(0,0,0,1)", alignSelf: "stretch", fontWeight: "normal", paddingTop:2 }, label: { color: "rgba(22,22,22,1)", alignSelf: "stretch", fontWeight: "normal", fontSize:12, marginBottom:2 }, }) const icon= '';