2024-04-19 13:59:15 +03:00
|
|
|
//
|
2024-09-06 16:34:30 +03:00
|
|
|
// Copyright 2024 New Vector Ltd.
|
2024-04-19 13:59:15 +03:00
|
|
|
//
|
2024-09-06 16:34:30 +03:00
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
// Please see LICENSE in the repository root for full details.
|
2024-04-19 13:59:15 +03:00
|
|
|
//
|
|
|
|
|
2024-05-29 17:07:17 +02:00
|
|
|
import AVFoundation
|
2024-04-19 13:59:15 +03:00
|
|
|
import UIKit
|
|
|
|
|
|
|
|
class AppMediator: AppMediatorProtocol {
|
2024-04-22 18:10:24 +03:00
|
|
|
let windowManager: WindowManagerProtocol
|
2024-08-08 18:29:39 +02:00
|
|
|
let networkMonitor: NetworkMonitorProtocol
|
2024-04-19 17:25:43 +03:00
|
|
|
|
2024-08-08 18:29:39 +02:00
|
|
|
init(windowManager: WindowManagerProtocol, networkMonitor: NetworkMonitorProtocol) {
|
2024-04-19 17:25:43 +03:00
|
|
|
self.windowManager = windowManager
|
2024-08-08 18:29:39 +02:00
|
|
|
self.networkMonitor = networkMonitor
|
2024-04-19 17:25:43 +03:00
|
|
|
}
|
2024-04-19 13:59:15 +03:00
|
|
|
|
|
|
|
// UIApplication.State won't update if we store this e.g. in the constructor
|
|
|
|
private var application: UIApplication {
|
|
|
|
UIApplication.shared
|
|
|
|
}
|
2024-04-19 17:25:43 +03:00
|
|
|
|
|
|
|
var appState: UIApplication.State {
|
|
|
|
switch application.applicationState {
|
|
|
|
case .active:
|
|
|
|
windowManager.mainWindow.traitCollection.activeAppearance == .active ? .active : .inactive
|
|
|
|
case .inactive:
|
|
|
|
.inactive
|
|
|
|
case .background:
|
|
|
|
.background
|
|
|
|
default:
|
|
|
|
.inactive
|
|
|
|
}
|
|
|
|
}
|
2024-04-19 13:59:15 +03:00
|
|
|
|
2024-04-22 18:10:24 +03:00
|
|
|
func beginBackgroundTask(expirationHandler handler: (() -> Void)?) -> UIBackgroundTaskIdentifier {
|
|
|
|
application.beginBackgroundTask(expirationHandler: handler)
|
2024-04-19 13:59:15 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func endBackgroundTask(_ identifier: UIBackgroundTaskIdentifier) {
|
|
|
|
application.endBackgroundTask(identifier)
|
|
|
|
}
|
|
|
|
|
|
|
|
func open(_ url: URL) {
|
|
|
|
application.open(url, options: [:], completionHandler: nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
func openAppSettings() {
|
|
|
|
guard let url = URL(string: UIApplication.openSettingsURLString) else {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
open(url)
|
|
|
|
}
|
2024-04-19 17:25:43 +03:00
|
|
|
|
|
|
|
func setIdleTimerDisabled(_ disabled: Bool) {
|
|
|
|
application.isIdleTimerDisabled = disabled
|
2024-04-19 13:59:15 +03:00
|
|
|
}
|
2024-05-29 17:07:17 +02:00
|
|
|
|
|
|
|
func requestAuthorizationIfNeeded() async -> Bool {
|
|
|
|
let status = AVCaptureDevice.authorizationStatus(for: .video)
|
|
|
|
|
|
|
|
// Determine if the user previously authorized camera access.
|
|
|
|
if status == .authorized {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
var isAuthorized = false
|
|
|
|
// If the system hasn't determined the user's authorization status,
|
|
|
|
// explicitly prompt them for approval.
|
|
|
|
if status == .notDetermined {
|
|
|
|
isAuthorized = await AVCaptureDevice.requestAccess(for: .video)
|
|
|
|
}
|
|
|
|
|
|
|
|
return isAuthorized
|
|
|
|
}
|
2024-04-19 13:59:15 +03:00
|
|
|
}
|