An alternative to SwiftUI's Picker that supports custom styles.
struct Item: Identifiable {
let id: Int
init(id: Int) {
self.id = id
}
}
struct ItemLabel: View {
private let itemId: String
init(item: Item) {
self.itemId = item.id
}
var body: some View {
Text("Cell - \(itemId)")
}
}
struct ItemPicker: View {
private let items: [Item] = 0..<100
@State private var selection: Item.ID = 0
var body: some View {
BetterPicker(items, selection: $selection, content: ItemLabel.init)
}
}Currently, only Swift Package Manager is supported. Add it as a package via the URL:
https://github.com/MFB-Technologies-Inc/swiftui-pick-better.git
or
git@github.com:MFB-Technologies-Inc/swiftui-pick-better.git
The options displayed in a picker must conform to Identifiable as that is how they are correlated to the current selection.
Selection values must conform to Hashable. Where T is the selection value for a given selectable item, the selection may be:
TOptional<T>K<T> where K: RandomAccessCollection, K.Element == T
Unlike SwiftUI's PickerStyle, BetterPicker supports custom styles. The BetterPickerStyle protocol can be implemented to create reusable styles similar to SwiftUI's ButtonStyle.
BetterPicker currently includes one builtin style PlainInlineBetterPickerStyle which is similar to the default iOS style of items in a vertical list.
BetterPicker includes a resultBuilder type StyleBuilder for conditionally applying a style in a familiar way.
BetterPicker does make use of view type erasure with AnyView. This can have side-effects for various things including animations. However, no problems have been encountered so far.
BetterPicker does not apply styles through a ViewModifier. Instead, an instance function on the view is used. Therefore, a style can only be applied directly on the instance of a picker. This practice does not exactly align with how SwiftUI is intended to be used. There is potential for this to cause stability problems. However, no problems of this nature have been encountered so far.
- Add support for selection values that are
EquatablewithoutHashable - Add support for options that are not
Identifiable - Change to apply styles through a ViewModifier instead of instance function
The package includes an example app in the Example directory with iOS, macOS, tvOS, and watchOS targets. Additionally, the example includes a more sophisticated style, GridBetterPickerStyle.