📅 TVDatePicker
A SwiftUI
DatePicker
view for tvOS
data:image/s3,"s3://crabby-images/2ce42/2ce426e405ada91fd899988fab2fc673fcb0c3a8" alt="License"
❤️ Motivation
Currently there is no native SwiftUI
DatePicker
for tvOS
. That’s why I created this Swift package to fill the hole 😊
The API
mimics the one of the native SwiftUI
DatePicker
available for iOS
, macOS
and macCatalyst
.
ℹ️ Installation
Just add this Swift package as a dependency to your Package.swift
:
.package(url: "https://github.com/crelies/TVDatePicker.git", from: "0.1.0")
🧭 Usage
The following code snippet shows how to use the DatePicker
view
in your tvOS
application:
TVDatePicker(
_ titleKey: LocalizedStringKey,
selection: Binding<Date>,
minimumDate: Date,
displayedComponents: Components = .all,
calendar: Calendar = .current,
dateFormatter: DateFormatter = DateFormatters.defaultFormatter,
label: () -> Label
) // Available when Label conforms to View.
At first the view appears as a button with a horizontal stack containing the specified label
, a Text
view representing the current selection
date string and a disclosure indicator
Image
view. If you press the button a sheet with the actual date picker view appears. The following screenshot is an example:
data:image/s3,"s3://crabby-images/e0291/e0291abb9e8061f47b491e48402b5da9f7b0669b" alt="Screenshot of a date picker view usage example"
📖 Implementation
The DatePicker
view is implemented by using multiple Picker
s with the SegmentedPickerStyle
inside a List
/ VStack
.
Each Picker
represents a date component like year
, month
or date
. Due to issues with the focus engine the implementation slightly differs for the supported tvOS versions 13.0
, 14.0
and > 14.0
. But I think that you can ignore this detail in most cases.
🔒 Limitations
- ⚠️ The
DatePicker
was only tested with the Gregorian calendar
.
- The
year
component displays only 10
years at a time (selected year +/- 5 years
with respect to the year of the specified minimum date
).
- ⚠️ Currently only the
year
component respects the minimum date
. On the contrary all months of a year
and all days of a month
are visible at all time.
- Currently the
hourAndMinute
component always displays all 24 hours
of a day.
- The
hourAndMinute
component supports only steps by five for the minute
.
📅 TVDatePicker
A
SwiftUI
DatePicker
view fortvOS
❤️ Motivation
Currently there is no native
SwiftUI
DatePicker
fortvOS
. That’s why I created this Swift package to fill the hole 😊 TheAPI
mimics the one of the nativeSwiftUI
DatePicker
available foriOS
,macOS
andmacCatalyst
.ℹ️ Installation
Just add this Swift package as a dependency to your
Package.swift
:🧭 Usage
The following code snippet shows how to use the
DatePicker
view
in yourtvOS
application:At first the view appears as a button with a horizontal stack containing the specified
label
, aText
view representing the currentselection
date string and adisclosure indicator
Image
view. If you press the button a sheet with the actual date picker view appears. The following screenshot is an example:📖 Implementation
The
DatePicker
view is implemented by using multiplePicker
s with theSegmentedPickerStyle
inside aList
/VStack
. EachPicker
represents a date component likeyear
,month
ordate
. Due to issues with the focus engine the implementation slightly differs for the supported tvOS versions13.0
,14.0
and >14.0
. But I think that you can ignore this detail in most cases.🔒 Limitations
DatePicker
was only tested with theGregorian calendar
.year
component displays only10
years at a time (selected year +/- 5 years
with respect to the year of the specifiedminimum date
).year
component respects theminimum date
. On the contraryall months of a year
andall days of a month
are visible at all time.hourAndMinute
component always displays all24 hours
of a day.hourAndMinute
component supports only steps by five for theminute
.