110 lines
3.7 KiB
Swift
110 lines
3.7 KiB
Swift
import Flutter
|
|
import UIKit
|
|
import WatchConnectivity
|
|
|
|
@main
|
|
@objc class AppDelegate: FlutterAppDelegate {
|
|
let notifyDelegate = NotifyDelegate()
|
|
private static var sharedWatchConnectivityService: WatchConnectivityService?
|
|
|
|
override func application(
|
|
_ application: UIApplication,
|
|
didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
|
|
) -> Bool {
|
|
UNUserNotificationCenter.current().delegate = notifyDelegate
|
|
|
|
let replyableMessageCategory = UNNotificationCategory(
|
|
identifier: "CHAT_MESSAGE",
|
|
actions: [
|
|
UNTextInputNotificationAction(
|
|
identifier: "reply_action",
|
|
title: "Reply",
|
|
options: []
|
|
),
|
|
],
|
|
intentIdentifiers: [],
|
|
options: []
|
|
)
|
|
UNUserNotificationCenter.current().setNotificationCategories([replyableMessageCategory])
|
|
|
|
GeneratedPluginRegistrant.register(with: self)
|
|
|
|
// Always initialize and retain a strong reference
|
|
if WCSession.isSupported() {
|
|
AppDelegate.sharedWatchConnectivityService = WatchConnectivityService.shared
|
|
} else {
|
|
print("[iOS] WCSession not supported on this device.")
|
|
}
|
|
|
|
return super.application(application, didFinishLaunchingWithOptions: launchOptions)
|
|
}
|
|
}
|
|
|
|
final class WatchConnectivityService: NSObject, WCSessionDelegate {
|
|
static let shared = WatchConnectivityService()
|
|
private let session: WCSession = .default
|
|
|
|
private override init() {
|
|
super.init()
|
|
print("[iOS] Activating WCSession...")
|
|
session.delegate = self
|
|
session.activate()
|
|
}
|
|
|
|
// MARK: - WCSessionDelegate
|
|
|
|
func session(_ session: WCSession, activationDidCompleteWith activationState: WCSessionActivationState, error: Error?) {
|
|
if let error = error {
|
|
print("[iOS] WCSession activation failed: \(error.localizedDescription)")
|
|
} else {
|
|
print("[iOS] WCSession activated with state: \(activationState.rawValue)")
|
|
if activationState == .activated {
|
|
sendDataToWatch()
|
|
}
|
|
}
|
|
}
|
|
|
|
func sessionDidBecomeInactive(_ session: WCSession) {}
|
|
|
|
func sessionDidDeactivate(_ session: WCSession) {
|
|
session.activate()
|
|
}
|
|
|
|
func session(_ session: WCSession, didReceiveMessage message: [String : Any], replyHandler: @escaping ([String : Any]) -> Void) {
|
|
print("[iOS] Received message: \(message)")
|
|
if let request = message["request"] as? String, request == "data" {
|
|
let token = UserDefaults.standard.getFlutterToken()
|
|
let serverUrl = UserDefaults.standard.getServerUrl()
|
|
|
|
var data: [String: Any] = ["serverUrl": serverUrl ?? ""]
|
|
if let token = token {
|
|
data["token"] = token
|
|
}
|
|
|
|
print("[iOS] Replying with data: \(data)")
|
|
replyHandler(data)
|
|
}
|
|
}
|
|
|
|
func sendDataToWatch() {
|
|
guard session.activationState == .activated else {
|
|
return
|
|
}
|
|
|
|
let token = UserDefaults.standard.getFlutterToken()
|
|
let serverUrl = UserDefaults.standard.getServerUrl()
|
|
|
|
var data: [String: Any] = ["serverUrl": serverUrl ?? ""]
|
|
if let token = token {
|
|
data["token"] = token
|
|
}
|
|
|
|
do {
|
|
try session.updateApplicationContext(data)
|
|
print("[iOS] Sent application context: \(data)")
|
|
} catch {
|
|
print("[iOS] Failed to send application context: \(error.localizedDescription)")
|
|
}
|
|
}
|
|
}
|