react-native-1app
Version:
165 lines (152 loc) • 5.46 kB
JavaScript
'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= '';