EditValueView
Library that makes easy to display property edit screens for SwiftUI.
Demo
Array |
Dictionary |
data:image/s3,"s3://crabby-images/08b72/08b727fe0b921ee078f6c08a17443fdd387ae3f7" alt="Array-light" |
data:image/s3,"s3://crabby-images/b9471/b9471a45ad034aeb9aacccd1f151d48802bb472d" alt="Dictionary-light" |
Enum(CaseIterable) |
Enum(CaseIterable & RawRepresentable) |
data:image/s3,"s3://crabby-images/5d47e/5d47e9c601bc1bb381e03ce537ec8380de973b70" alt="Enum(CaseIterable)-light" |
data:image/s3,"s3://crabby-images/dcce9/dcce9f51784f36bfab5cf55aecf2bc76dc5638fd" alt="Enum(CaseIterable RawRepresentable)-light" |
Codable |
data:image/s3,"s3://crabby-images/df106/df106d38b8f7ae8c3d6875d8fe82dd07665c8d64" alt="Codable-light" |
Usage
SwiftUI
EditValueView(target, key: "name", keyPath: \Item.name)
.onUpdate { target, newValue in
// update
}
.validate { target, newValue -> Bool in
// input validation
}
UIKit
let vc = EditValueViewController(target, key: "name", keyPath: \Item.name)
vc.onUpdate = { target, newValue in
// update
}
vc.validate = { target, newValue -> Bool in
// input validation
}
Protocol
If you use a keypath of an optional type, either define a default value according to the DefaultRepresentable
protocol or give the default value in the initilalize
struct Item: Codable {
var name: String
var date: Date
}
struct Message: Codable {
var content: String
var item: Item?
}
// Confirm to `DefaultRepresentable` protocol
extension Item: DefaultRepresentable {
static var defaultValue: Self {
.init(name: "name", date: Date())
}
}
// give default value
EditValueView(target, key: "item", keyPath: \Message.item, defaultValue: .init(name: "name", date: Date()))
EditValueView
Library that makes easy to display property edit screens for SwiftUI.
Demo
Usage
SwiftUI
UIKit
Protocol
If you use a keypath of an optional type, either define a default value according to the
DefaultRepresentable
protocol or give the default value in the initilalize