Reputation: 2345
Under iOS 14, the date/time pickers in my app are broken. Nothing changed in the project. They're defined in a storyboard and worked fine until I updated a few days ago.
Now they're not spinners; they're large grey boxes with static text in them.
UPDATE: Apple broke existing projects by defaulting date/time pickers' style to "automatic", instead of "wheel" (the only style that previously existed, and for which everyone's existing screen layouts were designed). See Sanzio's answer below.
Upvotes: 50
Views: 31990
Reputation: 191
If anyone is looking for Objective-C:
if (@available(iOS 13.4, *)) {
datePicker.preferredDatePickerStyle = UIDatePickerStyleWheels;
}
Upvotes: 19
Reputation: 211
if #available(iOS 13.4, *) {
datePicker.preferredDatePickerStyle = .wheels
}
Upvotes: 20
Reputation: 11254
in iOS appDelegate.m
didFinishLaunchingWithOptions . () inside
if (@available(iOS 14, *)) {
UIDatePicker *picker = [UIDatePicker appearance];
picker.preferredDatePickerStyle = UIDatePickerStyleWheels;
}
<DateTimePickerModal
datePickerContainerStyleIOS={{paddingHorizontal: 40}}
// display={Platform.OS === "ios" ? "spinner" : "default"}
isVisible={isDatePickerVisible}
mode={mode}
maximumDate={new Date()}
onConfirm={handleConfirm}
onCancel={hideDatePicker}
/>
Upvotes: 3
Reputation: 3942
To add some additional information to Oscar's answer...
UIDatePicker
now has three different styles, as per documentation here and here. The date picker's style is accessible by the .preferredDatePickerStyle
property which can be set to four different cases:
.automatic
- A style indicating that the system picks the concrete style based on the current platform and date picker mode..compact
- A style indicating that the date picker displays as a label that when tapped displays a calendar-style editor..inline
- A style indicating that the date pickers displays as an inline, editable field..wheels
- A style indicating that the date picker displays as a wheel picker.If you want things to look how they did pre iOS 14, stick with the .wheels
style. It is also worth noting that not all styles can accommodate all date and time settings, hence why you can only set a preferred style.
Lastly, this property is only available in iOS 13.4 or newer, so you will have to accomplish version control with something like:
if #available(iOS 13.4, *) {
yourDatePicker.preferredDatePickerStyle = UIDatePickerStyle.automatic
} else {
// Fallback on earlier versions
}
Upvotes: 69
Reputation: 2345
It turns out that Apple added a second and very different style of UIDatePicker, and inexplicably made it the default for old projects.
You now have to go into the settings for all of your date/time pickers and change Style from "Automatic" to "Wheels." What "Automatic" is based on and why it doesn't default to the only previously existing style is unknown.
Upvotes: 8