mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-17 18:44:45 +02:00
181 lines
5.1 KiB
TypeScript
181 lines
5.1 KiB
TypeScript
import * as React from 'react';
|
|
import { themeStyle } from './global-style';
|
|
import { _ } from '@joplin/lib/locale';
|
|
const { View, Button, Text, StyleSheet } = require('react-native');
|
|
import time from '@joplin/lib/time';
|
|
import { Platform } from 'react-native';
|
|
import Modal from './Modal';
|
|
import { formatMsToLocal } from '@joplin/utils/time';
|
|
const DateTimePickerModal = require('react-native-modal-datetime-picker').default;
|
|
|
|
const styles = StyleSheet.create({
|
|
centeredView: {
|
|
flex: 1,
|
|
justifyContent: 'center',
|
|
alignItems: 'center',
|
|
},
|
|
modalView: {
|
|
display: 'flex',
|
|
flexDirection: 'column',
|
|
margin: 10,
|
|
backgroundColor: 'white',
|
|
borderRadius: 10,
|
|
alignItems: 'center',
|
|
shadowColor: '#000',
|
|
shadowOffset: {
|
|
width: 0,
|
|
height: 2,
|
|
},
|
|
shadowOpacity: 0.25,
|
|
shadowRadius: 4,
|
|
elevation: 5,
|
|
},
|
|
button: {
|
|
borderRadius: 20,
|
|
padding: 10,
|
|
elevation: 2,
|
|
},
|
|
buttonOpen: {
|
|
backgroundColor: '#F194FF',
|
|
},
|
|
buttonClose: {
|
|
backgroundColor: '#2196F3',
|
|
},
|
|
textStyle: {
|
|
color: 'white',
|
|
fontWeight: 'bold',
|
|
textAlign: 'center',
|
|
},
|
|
modalText: {
|
|
marginBottom: 15,
|
|
textAlign: 'center',
|
|
},
|
|
});
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
|
export default class SelectDateTimeDialog extends React.PureComponent<any, any> {
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
|
public constructor(props: any) {
|
|
super(props);
|
|
|
|
this.state = {
|
|
date: null,
|
|
mode: 'date',
|
|
showPicker: false,
|
|
};
|
|
|
|
this.onReject = this.onReject.bind(this);
|
|
this.onPickerConfirm = this.onPickerConfirm.bind(this);
|
|
this.onPickerCancel = this.onPickerCancel.bind(this);
|
|
this.onSetDate = this.onSetDate.bind(this);
|
|
}
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
|
public UNSAFE_componentWillReceiveProps(newProps: any) {
|
|
if (newProps.date !== this.state.date) {
|
|
this.setState({ date: newProps.date });
|
|
}
|
|
}
|
|
|
|
public onAccept() {
|
|
if (this.props.onAccept) this.props.onAccept(this.state.date);
|
|
}
|
|
|
|
public onReject() {
|
|
if (this.props.onReject) this.props.onReject();
|
|
}
|
|
|
|
public onClear() {
|
|
if (this.props.onAccept) this.props.onAccept(null);
|
|
}
|
|
|
|
public onPickerConfirm(selectedDate: Date) {
|
|
this.setState({ date: selectedDate, showPicker: false });
|
|
}
|
|
|
|
public onPickerCancel() {
|
|
this.setState({ showPicker: false });
|
|
}
|
|
|
|
public onSetDate() {
|
|
this.setState({ showPicker: true });
|
|
}
|
|
|
|
// web
|
|
private onInputChange = (event: React.ChangeEvent<HTMLInputElement>) => {
|
|
this.setState({ date: new Date(event.target.value) });
|
|
};
|
|
|
|
public renderContent() {
|
|
const theme = themeStyle(this.props.themeId);
|
|
|
|
// DateTimePickerModal doesn't support web.
|
|
if (Platform.OS === 'web') {
|
|
// See https://developer.mozilla.org/en-US/docs/Web/HTML/Date_and_time_formats#local_date_and_time_strings
|
|
// for the expected date input format:
|
|
const dateString = this.state.date ? formatMsToLocal(this.state.date.getTime(), 'YYYY-MM-DD[T]HH:mm:ss') : '';
|
|
return <input
|
|
type="datetime-local"
|
|
value={dateString}
|
|
onChange={this.onInputChange}
|
|
></input>;
|
|
}
|
|
|
|
return (
|
|
<View style={{ flex: 0, margin: 20, alignItems: 'center' }}>
|
|
<View style={{ flexDirection: 'row', alignItems: 'center' }}>
|
|
{ this.state.date && <Text style={{ ...theme.normalText, color: theme.color, marginRight: 10 }}>{time.formatDateToLocal(this.state.date)}</Text> }
|
|
<Button title="Set date" onPress={this.onSetDate} />
|
|
</View>
|
|
<DateTimePickerModal
|
|
date={this.state.date ? this.state.date : new Date()}
|
|
is24Hour={time.use24HourFormat()}
|
|
isVisible={this.state.showPicker}
|
|
mode="datetime"
|
|
onConfirm={this.onPickerConfirm}
|
|
onCancel={this.onPickerCancel}
|
|
/>
|
|
</View>
|
|
);
|
|
}
|
|
|
|
public render() {
|
|
const modalVisible = this.props.shown;
|
|
|
|
if (!modalVisible) return null;
|
|
|
|
const theme = themeStyle(this.props.themeId);
|
|
|
|
return (
|
|
<Modal
|
|
transparent={true}
|
|
visible={modalVisible}
|
|
containerStyle={styles.centeredView}
|
|
onRequestClose={() => {
|
|
this.onReject();
|
|
}}
|
|
>
|
|
<View style={{ ...styles.modalView, backgroundColor: theme.backgroundColor }}>
|
|
<View style={{ padding: 15, flexBasis: 'auto', paddingBottom: 0, flexGrow: 0, width: '100%', borderBottomWidth: 1, borderBottomColor: theme.dividerColor, borderBottomStyle: 'solid' }}>
|
|
<Text style={{ ...styles.modalText, color: theme.color, fontSize: 14, fontWeight: 'bold' }}>{_('Set alarm')}</Text>
|
|
</View>
|
|
{this.renderContent()}
|
|
<View style={{ padding: 20, flexBasis: 'auto', borderTopWidth: 1, borderTopStyle: 'solid', borderTopColor: theme.dividerColor }}>
|
|
<View style={{ marginBottom: 10 }}>
|
|
<Button title={_('Save alarm')} onPress={() => this.onAccept()} key="saveButton" />
|
|
</View>
|
|
<View style={{ marginBottom: 10 }}>
|
|
<Button title={_('Clear alarm')} onPress={() => this.onClear()} key="clearButton" />
|
|
</View>
|
|
<View style={{ marginBottom: 10 }}>
|
|
<Button title={_('Cancel')} onPress={() => this.onReject()} key="cancelButton" />
|
|
</View>
|
|
</View>
|
|
</View>
|
|
</Modal>
|
|
);
|
|
}
|
|
|
|
}
|