219 lines
6.8 KiB
Swift
219 lines
6.8 KiB
Swift
//
|
|
// CLLocationManager+Rx.swift
|
|
// RxCocoa
|
|
//
|
|
// Created by Carlos García on 8/7/15.
|
|
// Copyright © 2015 Krunoslav Zaher. All rights reserved.
|
|
//
|
|
|
|
import CoreLocation
|
|
#if !RX_NO_MODULE
|
|
import RxSwift
|
|
#endif
|
|
|
|
|
|
extension Reactive where Base: CLLocationManager {
|
|
|
|
/**
|
|
Reactive wrapper for `delegate`.
|
|
|
|
For more information take a look at `DelegateProxyType` protocol documentation.
|
|
*/
|
|
public var delegate: DelegateProxy {
|
|
return RxCLLocationManagerDelegateProxy.proxyForObject(base)
|
|
}
|
|
|
|
// MARK: Responding to Location Events
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didUpdateLocations: Observable<[CLLocation]> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didUpdateLocations:)))
|
|
.map { a in
|
|
return try castOrThrow([CLLocation].self, a[1])
|
|
}
|
|
}
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didFailWithError: Observable<NSError> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didFailWithError:)))
|
|
.map { a in
|
|
return try castOrThrow(NSError.self, a[1])
|
|
}
|
|
}
|
|
|
|
#if os(iOS) || os(OSX)
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didFinishDeferredUpdatesWithError: Observable<NSError?> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didFinishDeferredUpdatesWithError:)))
|
|
.map { a in
|
|
return try castOptionalOrThrow(NSError.self, a[1])
|
|
}
|
|
}
|
|
#endif
|
|
|
|
#if os(iOS)
|
|
|
|
// MARK: Pausing Location Updates
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didPauseLocationUpdates: Observable<Void> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManagerDidPauseLocationUpdates(_:)))
|
|
.map { _ in
|
|
return ()
|
|
}
|
|
}
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didResumeLocationUpdates: Observable<Void> {
|
|
return delegate.observe( #selector(CLLocationManagerDelegate.locationManagerDidResumeLocationUpdates(_:)))
|
|
.map { _ in
|
|
return ()
|
|
}
|
|
}
|
|
|
|
// MARK: Responding to Heading Events
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didUpdateHeading: Observable<CLHeading> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didUpdateHeading:)))
|
|
.map { a in
|
|
return try castOrThrow(CLHeading.self, a[1])
|
|
}
|
|
}
|
|
|
|
// MARK: Responding to Region Events
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didEnterRegion: Observable<CLRegion> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didEnterRegion:)))
|
|
.map { a in
|
|
return try castOrThrow(CLRegion.self, a[1])
|
|
}
|
|
}
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didExitRegion: Observable<CLRegion> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didExitRegion:)))
|
|
.map { a in
|
|
return try castOrThrow(CLRegion.self, a[1])
|
|
}
|
|
}
|
|
|
|
#endif
|
|
|
|
#if os(iOS) || os(OSX)
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
@available(OSX 10.10, *)
|
|
public var didDetermineStateForRegion: Observable<(state: CLRegionState, region: CLRegion)> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didDetermineState:for:)))
|
|
.map { a in
|
|
let stateNumber = try castOrThrow(NSNumber.self, a[1])
|
|
let state = CLRegionState(rawValue: stateNumber.intValue) ?? CLRegionState.unknown
|
|
let region = try castOrThrow(CLRegion.self, a[2])
|
|
return (state: state, region: region)
|
|
}
|
|
}
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var monitoringDidFailForRegionWithError: Observable<(region: CLRegion?, error: NSError)> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:monitoringDidFailFor:withError:)))
|
|
.map { a in
|
|
let region = try castOptionalOrThrow(CLRegion.self, a[1])
|
|
let error = try castOrThrow(NSError.self, a[2])
|
|
return (region: region, error: error)
|
|
}
|
|
}
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didStartMonitoringForRegion: Observable<CLRegion> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didStartMonitoringFor:)))
|
|
.map { a in
|
|
return try castOrThrow(CLRegion.self, a[1])
|
|
}
|
|
}
|
|
|
|
#endif
|
|
|
|
#if os(iOS)
|
|
|
|
// MARK: Responding to Ranging Events
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didRangeBeaconsInRegion: Observable<(beacons: [CLBeacon], region: CLBeaconRegion)> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didRangeBeacons:in:)))
|
|
.map { a in
|
|
let beacons = try castOrThrow([CLBeacon].self, a[1])
|
|
let region = try castOrThrow(CLBeaconRegion.self, a[2])
|
|
return (beacons: beacons, region: region)
|
|
}
|
|
}
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var rangingBeaconsDidFailForRegionWithError: Observable<(region: CLBeaconRegion, error: NSError)> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:rangingBeaconsDidFailFor:withError:)))
|
|
.map { a in
|
|
let region = try castOrThrow(CLBeaconRegion.self, a[1])
|
|
let error = try castOrThrow(NSError.self, a[2])
|
|
return (region: region, error: error)
|
|
}
|
|
}
|
|
|
|
// MARK: Responding to Visit Events
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
@available(iOS 8.0, *)
|
|
public var didVisit: Observable<CLVisit> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didVisit:)))
|
|
.map { a in
|
|
return try castOrThrow(CLVisit.self, a[1])
|
|
}
|
|
}
|
|
|
|
#endif
|
|
|
|
// MARK: Responding to Authorization Changes
|
|
|
|
/**
|
|
Reactive wrapper for `delegate` message.
|
|
*/
|
|
public var didChangeAuthorizationStatus: Observable<CLAuthorizationStatus> {
|
|
return delegate.observe(#selector(CLLocationManagerDelegate.locationManager(_:didChangeAuthorization:)))
|
|
.map { a in
|
|
let number = try castOrThrow(NSNumber.self, a[1])
|
|
return CLAuthorizationStatus(rawValue: Int32(number.intValue)) ?? .notDetermined
|
|
}
|
|
}
|
|
|
|
|
|
|
|
}
|