mirror of
https://github.com/status-im/react-native.git
synced 2025-02-24 23:28:12 +00:00
Summary: Thank you for sending the PR! We appreciate you spending the time to work on these changes. Help us understand your motivation by explaining why you decided to make this change: Changelog: ---------- [iOS] [Changed] - As mentioned in #22990, I have moved native components required by DatePickerIOS.ios.js into separate files and added Flow Typing. Pull Request resolved: https://github.com/facebook/react-native/pull/23013 Differential Revision: D13697591 Pulled By: TheSavior fbshipit-source-id: 5aec5a2270cbfc708f3e3a67662abd8071f1333f
192 lines
5.0 KiB
JavaScript
192 lines
5.0 KiB
JavaScript
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
*
|
|
* This is a controlled component version of RCTDatePickerIOS
|
|
*
|
|
* @format
|
|
* @flow strict-local
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const React = require('React');
|
|
const StyleSheet = require('StyleSheet');
|
|
const View = require('View');
|
|
|
|
const invariant = require('invariant');
|
|
|
|
import type {ViewProps} from 'ViewPropTypes';
|
|
import type {SyntheticEvent} from 'CoreEventTypes';
|
|
|
|
const RCTDatePickerNativeComponent = require('RCTDatePickerNativeComponent');
|
|
|
|
type Event = SyntheticEvent<
|
|
$ReadOnly<{|
|
|
timestamp: number,
|
|
|}>,
|
|
>;
|
|
|
|
type Props = $ReadOnly<{|
|
|
...ViewProps,
|
|
|
|
/**
|
|
* The currently selected date.
|
|
*/
|
|
date?: ?Date,
|
|
|
|
/**
|
|
* Provides an initial value that will change when the user starts selecting
|
|
* a date. It is useful for simple use-cases where you do not want to deal
|
|
* with listening to events and updating the date prop to keep the
|
|
* controlled state in sync. The controlled state has known bugs which
|
|
* causes it to go out of sync with native. The initialDate prop is intended
|
|
* to allow you to have native be source of truth.
|
|
*/
|
|
initialDate?: ?Date,
|
|
|
|
/**
|
|
* The date picker locale.
|
|
*/
|
|
locale?: ?string,
|
|
|
|
/**
|
|
* Maximum date.
|
|
*
|
|
* Restricts the range of possible date/time values.
|
|
*/
|
|
maximumDate?: ?Date,
|
|
|
|
/**
|
|
* Minimum date.
|
|
*
|
|
* Restricts the range of possible date/time values.
|
|
*/
|
|
minimumDate?: ?Date,
|
|
|
|
/**
|
|
* The interval at which minutes can be selected.
|
|
*/
|
|
minuteInterval?: ?(1 | 2 | 3 | 4 | 5 | 6 | 10 | 12 | 15 | 20 | 30),
|
|
|
|
/**
|
|
* The date picker mode.
|
|
*/
|
|
mode?: ?('date' | 'time' | 'datetime'),
|
|
|
|
/**
|
|
* Date change handler.
|
|
*
|
|
* This is called when the user changes the date or time in the UI.
|
|
* The first and only argument is an Event. For getting the date the picker
|
|
* was changed to, use onDateChange instead.
|
|
*/
|
|
onChange?: ?(event: Event) => void,
|
|
|
|
/**
|
|
* Date change handler.
|
|
*
|
|
* This is called when the user changes the date or time in the UI.
|
|
* The first and only argument is a Date object representing the new
|
|
* date and time.
|
|
*/
|
|
onDateChange: (date: Date) => void,
|
|
|
|
/**
|
|
* Timezone offset in minutes.
|
|
*
|
|
* By default, the date picker will use the device's timezone. With this
|
|
* parameter, it is possible to force a certain timezone offset. For
|
|
* instance, to show times in Pacific Standard Time, pass -7 * 60.
|
|
*/
|
|
timeZoneOffsetInMinutes?: ?number,
|
|
|}>;
|
|
|
|
/**
|
|
* Use `DatePickerIOS` to render a date/time picker (selector) on iOS. This is
|
|
* a controlled component, so you must hook in to the `onDateChange` callback
|
|
* and update the `date` prop in order for the component to update, otherwise
|
|
* the user's change will be reverted immediately to reflect `props.date` as the
|
|
* source of truth.
|
|
*/
|
|
class DatePickerIOS extends React.Component<Props> {
|
|
static DefaultProps = {
|
|
mode: 'datetime',
|
|
};
|
|
|
|
// $FlowFixMe How to type a native component to be able to call setNativeProps
|
|
_picker: ?React.ElementRef<typeof RCTDatePickerNativeComponent> = null;
|
|
|
|
componentDidUpdate() {
|
|
if (this.props.date) {
|
|
const propsTimeStamp = this.props.date.getTime();
|
|
if (this._picker) {
|
|
this._picker.setNativeProps({
|
|
date: propsTimeStamp,
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
_onChange = (event: Event) => {
|
|
const nativeTimeStamp = event.nativeEvent.timestamp;
|
|
this.props.onDateChange &&
|
|
this.props.onDateChange(new Date(nativeTimeStamp));
|
|
this.props.onChange && this.props.onChange(event);
|
|
};
|
|
|
|
render() {
|
|
const props = this.props;
|
|
invariant(
|
|
props.date || props.initialDate,
|
|
'A selected date or initial date should be specified.',
|
|
);
|
|
return (
|
|
<View style={props.style}>
|
|
<RCTDatePickerNativeComponent
|
|
testID={props.testID}
|
|
ref={picker => {
|
|
this._picker = picker;
|
|
}}
|
|
style={styles.datePickerIOS}
|
|
date={
|
|
props.date
|
|
? props.date.getTime()
|
|
: props.initialDate
|
|
? props.initialDate.getTime()
|
|
: undefined
|
|
}
|
|
locale={
|
|
props.locale != null && props.locale !== ''
|
|
? props.locale
|
|
: undefined
|
|
}
|
|
maximumDate={
|
|
props.maximumDate ? props.maximumDate.getTime() : undefined
|
|
}
|
|
minimumDate={
|
|
props.minimumDate ? props.minimumDate.getTime() : undefined
|
|
}
|
|
mode={props.mode}
|
|
minuteInterval={props.minuteInterval}
|
|
timeZoneOffsetInMinutes={props.timeZoneOffsetInMinutes}
|
|
onChange={this._onChange}
|
|
onStartShouldSetResponder={() => true}
|
|
onResponderTerminationRequest={() => false}
|
|
/>
|
|
</View>
|
|
);
|
|
}
|
|
}
|
|
|
|
const styles = StyleSheet.create({
|
|
datePickerIOS: {
|
|
height: 216,
|
|
},
|
|
});
|
|
|
|
module.exports = DatePickerIOS;
|