UNPKG

react-native-1app

Version:

280 lines (258 loc) 7.87 kB
import React, { Component } from "react"; import { StyleSheet, Animated, NativeModules, View, Image, TouchableOpacity, Text, LayoutAnimation } from "react-native"; var moment = require("moment"); moment.locale("pt-br"); import { DateTimePickerAndroid } from "@react-native-community/datetimepicker"; const { UIManager } = NativeModules; UIManager.setLayoutAnimationEnabledExperimental && UIManager.setLayoutAnimationEnabledExperimental(true); export default class DatePicker extends Component { constructor(props) { super(props); this.state = { // fontSize: new Animated.Value( // this.validarValue(this.props.value) || this.props.placeholder ? 12 : 15 // ), // marginTop: new Animated.Value( // this.validarValue(this.props.value) || this.props.placeholder ? 0 : 14 // ), fontSize: this.props.placeholder ? 12 : 15, marginTop: this.props.placeholder ? 0 : 14, }; } getDate(value = this.props.init) { // console.log(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 if (!this.props.time) { return new Date(moment(value).set("hour", 12).toJSON()); } return new Date(value); } getDateBr(date) { if (!date) { return ""; } date = this.getDate(date); var br = moment(date).utc().add(5, "hours").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 }); let { value, time } = this.props; console.log("this.getDate=>", this.getDate(value), value); DateTimePickerAndroid.open({ value: this.getDate(value), onChange: (event, selectedDate) => { const currentDate = selectedDate; this.handleDatePicked(currentDate); }, mode: time == "timeOnly" ? "time" : time ? "datetime" : "date", is24Hour: true, }); // <DateTimePicker // date={this.getDate(value)} // is24Hour={true} // datePickerModeAndroid={datePickerModeAndroid} // mode={time == "timeOnly" ? "time" : time ? "datetime" : "date"} // mode="date" // // isVisible={isDateTimePickerVisible} // onConfirm={(date) => { // this.handleDatePicked(date); // }} // onCancel={() => { // this.hideDateTimePicker(); // }} // /> } 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; } else if (!this.props.time) { value = moment(value).set("hour", 12).toJSON(); } 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 (props.placeholder) return; if ( this.validarValue(props.value) && !this.validarValue(this.props.value) ) { LayoutAnimation.spring(); this.setState({fontSize:12,marginTop:0}) // Animated.timing(fontSize, { // toValue: 12, // duration: 300, // useNativeDriver: true, // }).start(); // Animated.timing(marginTop, { // toValue: 0, // duration: 200, // useNativeDriver: true, // }).start(); } if ( !this.validarValue(props.value) && this.validarValue(this.props.value) ) { LayoutAnimation.spring(); this.setState({fontSize:15,marginTop:14}) // Animated.timing(fontSize, { // toValue: 15, // duration: 300, // useNativeDriver: true, // }).start(); // Animated.timing(marginTop, { // toValue: 14, // duration: 300, // useNativeDriver: true, // }).start(); } } validarValue(v) { return v == 0 || v; } render() { let { label = "-", value, time, onChange, style, placeholder, disabled, disabledClear, datePickerModeAndroid, } = this.props; let { fontSize, marginTop, isDateTimePickerVisible } = this.state; console.log("render", value); style = StyleSheet.flatten(style); return ( <TouchableOpacity style={[styles.button, style]} disabled={disabled} onPress={() => this.showDateTimePicker()} > <View style={styles.view}> <Animated.Text style={[ styles.label, { marginTop, fontSize, color: style.color || styles.label.color }, ]} > {label} </Animated.Text> {placeholder && !this.getDateBr(value) ? ( <Text style={[ styles.value, { color: style.color || styles.value.color }, ]} > {placeholder} </Text> ) : null} <Text style={[styles.value, { color: style.color || styles.value.color }]} > {this.getDateBr(value)} </Text> </View> {disabledClear && value ? ( <TouchableOpacity onPress={() => { onChange(null, null); }} > <Image style={{ width: 20, height: 20 }} source={{ uri: icon }} /> </TouchableOpacity> ) : null} </TouchableOpacity> ); } } DatePicker.defaultProps = { label: "-", value: undefined, list: [], style: {}, disabled: false, onChange: () => console.log("onChange"), placeholder: "", datePickerModeAndroid: "calendar", }; 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 = "";