diff --git a/Source/PermissionTypes/Location.swift b/Source/PermissionTypes/Location.swift index 6e6ffd4..fa7fc54 100644 --- a/Source/PermissionTypes/Location.swift +++ b/Source/PermissionTypes/Location.swift @@ -25,7 +25,7 @@ #if PERMISSION_LOCATION import CoreLocation -internal let LocationManager = CLLocationManager() +internal var LocationManager: CLLocationManager? private var requestedLocation = false private var triggerCallbacks = false @@ -51,6 +51,7 @@ extension CLLocationManager { delegate = permission requestedLocation = true + triggerCallbacks = false if case .locationAlways = permission.type { requestAlwaysAuthorization() diff --git a/Source/PermissionTypes/LocationAlways.swift b/Source/PermissionTypes/LocationAlways.swift index 898117a..99eca51 100644 --- a/Source/PermissionTypes/LocationAlways.swift +++ b/Source/PermissionTypes/LocationAlways.swift @@ -50,7 +50,8 @@ internal extension Permission { UserDefaults.standard.requestedLocationAlwaysWithWhenInUse = true } - LocationManager.request(self) + LocationManager = CLLocationManager() + LocationManager?.request(self) } } #endif diff --git a/Source/PermissionTypes/LocationWhenInUse.swift b/Source/PermissionTypes/LocationWhenInUse.swift index bbaaedc..82d72e2 100644 --- a/Source/PermissionTypes/LocationWhenInUse.swift +++ b/Source/PermissionTypes/LocationWhenInUse.swift @@ -44,7 +44,8 @@ internal extension Permission { return } - LocationManager.request(self) + LocationManager = CLLocationManager() + LocationManager?.request(self) } } #endif