Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/AckeeCZ/ReactiveLocation
ReactiveCocoa wrapper for CLLocationManager.
https://github.com/AckeeCZ/ReactiveLocation
ios swift
Last synced: about 1 month ago
JSON representation
ReactiveCocoa wrapper for CLLocationManager.
- Host: GitHub
- URL: https://github.com/AckeeCZ/ReactiveLocation
- Owner: AckeeCZ
- License: mit
- Created: 2016-08-07T20:45:19.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-01-26T10:56:04.000Z (almost 2 years ago)
- Last Synced: 2024-04-29T18:06:30.210Z (9 months ago)
- Topics: ios, swift
- Language: Swift
- Homepage:
- Size: 407 KB
- Stars: 24
- Watchers: 4
- Forks: 4
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios-star - ReactiveLocation - CoreLocation made reactive (Reactive Programming / Prototyping)
- awesome-ios - ReactiveLocation - CoreLocation made reactive (Reactive Programming / Prototyping)
README
![ackee|ReactiveLocation](Logo.png)
![Build](https://github.com/AckeeCZ/ReactiveLocation/workflows/Build/badge.svg)
[![Version](https://img.shields.io/cocoapods/v/ReactiveLocation.svg?style=flat)](http://cocoapods.org/pods/ReactiveLocation)
[![License](https://img.shields.io/cocoapods/l/ReactiveLocation.svg?style=flat)](http://cocoapods.org/pods/ReactiveLocation)
[![Platform](https://img.shields.io/cocoapods/p/ReactiveLocation.svg?style=flat)](http://cocoapods.org/pods/ReactiveLocation)> ⚠️ **This repository is no longer maintained**
## ReactiveSwift wrapper to observe location
Our wrapper automatically asks for permission. It determines what kind of permission your app requires by checking the Info.plist of your app.
By using our wrapper you can use a single instance of `CLLocationManager` and it will automatically start and stop updating location based on the number of observers so your app doesn't drain device battery unnecessarily.
## Example usage
For example usage you can check our example that is part of this repository.
For simplest cases you are provided a `shared` instance:
```swift
ReactiveLocation.shared.locationProducer().startWithValues { location in
print(location)
}
```If you need more different setups for your `CLLocationManager` you can create additional instances simply by creating new instances of `ReactiveLocation` and adding your desired setup to the `locationManager` which is provided to you (but it's up to you to make sure that the instance is alive as long as you need it):
```swift
let reactiveLocation = ReactiveLocation()
reactiveLocation.locationManager.distanceFilter = 100 // do your custom setup
reactiveLocation.locationProducer().startWithValues {
print($0)
}
// store `reactiveLocation` instance somewhere
```## Testing support
All features of `ReactiveLocation` are wrapped into `ReactiveLocationService` protocol so you should use this protocol as dependency inside your project so you're able to inject any testing implementation you like.
## Installation
`ReactiveLocation` is available through Carthage so adding it to your Cartfile works just fine.
```ruby
github "AckeeCZ/ReactiveLocation"
```If you're not familiar with Carthage, we also support Cocoapods.
```ruby
pod "ReactiveLocation"
```Well if you're not familiar with any dependency manager, you're free to integrate it manually. 😎 But keep in mind that we depend on `ReactiveSwift`.
## Forking this repository
If you use ReactiveLocation in your projects drop us a tweet at [@ackeecz][1] or leave a star here on Github. We would love to hear about it!## Sharing is caring
This tool and repo has been opensourced within our `#sharingiscaring` action when we have decided to opensource our internal projects## Author
[Ackee](www.ackee.cz) team
## License
ReactiveLocation is available under the MIT license. See the LICENSE file for more info.
[1]: https://twitter.com/AckeeCZ