react-native-1app
Version:
280 lines (258 loc) • 7.87 kB
JavaScript
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 =
"";