ObservableKit
ObservableKit is the easiest way to observe values in Swift.
❗️Requirements
⚒ Installation
Swift Package Manager
ObservableKit is available through SPM. To install
it, follow the steps:
Open Xcode project > File > Swift Packages > Add Package Dependecy
After that, put the url in the field: https://github.com/thejohnlima/ObservableKit.git
CocoaPods
ObservableKit is available through CocoaPods. To install
it, simply add the following line to your Podfile:
pod 'ObservableKit'
and run pod install
🎓 How to use
Import library in your swift file:
import ObservableKit
Download image example
Setup ObservableKit in your ViewModel:
let observable: OKObservable<OKState<Data, Error>> = OKObservable(OKState.loading)
func fetchImage() {
let url = URL(string: model.image)!
observable.value = .loading
URLSession.shared.dataTask(with: url, completionHandler: { data, _, error in
if let error = error {
self.observable.value = .errored(error: error)
return
}
self.observable.value = data != nil ? .load(data: data!) : .empty
}).resume()
}
Than, in your view controller call the observer:
@IBOutlet weak var imageView: UIImageView!
private let viewModel = ViewModel()
override func viewDidLoad() {
super.viewDidLoad()
addObservers()
}
private func addObservers() {
viewModel.observable.didChange = { [weak self] status in
DispatchQueue.main.async {
switch status {
case .load(data: let data):
print("✅ fetch image with succss")
let image = UIImage(data: data)
self?.imageView.image = image
case .loading:
print("🚀 loading data...")
case .errored(error: let error):
print("❌ get an error: \(error)")
case .empty:
print("❌ data not found")
}
}
}
}
private func loadImage() {
viewModel.fetchImage()
}
🙋🏻 Communication
- If you found a bug, open an issue.
- If you have a feature request, open an issue.
- If you want to contribute, submit a pull request. 👨🏻💻
📜 License
ObservableKit is under MIT license. See the LICENSE file for more info.
ObservableKit
ObservableKit is the easiest way to observe values in Swift.
❗️Requirements
⚒ Installation
Swift Package Manager
ObservableKit is available through SPM. To install it, follow the steps:
After that, put the url in the field:
https://github.com/thejohnlima/ObservableKit.git
CocoaPods
ObservableKit is available through CocoaPods. To install it, simply add the following line to your Podfile:
and run
pod install
🎓 How to use
Import library in your swift file:
Download image example
Setup ObservableKit in your ViewModel:
Than, in your view controller call the observer:
🙋🏻 Communication
📜 License
ObservableKit is under MIT license. See the LICENSE file for more info.