From 779fe062861dcf0b07805a27c694e67d13f333dc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E3=82=A8=E3=83=AA=E3=82=B9?= Date: Thu, 26 Dec 2024 10:31:36 +0900 Subject: [PATCH] fix(ios): correctly set foreground flag when forceShow is enabled (#338) --- src/ios/PushPlugin.m | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/src/ios/PushPlugin.m b/src/ios/PushPlugin.m index 3d25f23f4..616e0205d 100644 --- a/src/ios/PushPlugin.m +++ b/src/ios/PushPlugin.m @@ -38,7 +38,7 @@ @interface PushPlugin () @property (nonatomic, strong) UNNotification *previousNotification; @property (nonatomic, assign) BOOL isInitialized; -@property (nonatomic, assign) BOOL isInline; +@property (nonatomic, assign) BOOL isForeground; @property (nonatomic, assign) BOOL clearBadge; @property (nonatomic, assign) BOOL forceShow; @property (nonatomic, assign) BOOL coldstart; @@ -161,7 +161,7 @@ - (void)init:(CDVInvokedUrlCommand *)command { [self.commandDelegate runInBackground:^ { NSLog(@"[PushPlugin] register called"); - self.isInline = NO; + self.isForeground = NO; self.forceShow = [settings forceShowEnabled]; self.clearBadge = [settings clearBadgeEnabled]; if (self.clearBadge) { @@ -309,7 +309,7 @@ - (void)didReceiveRemoteNotification:(NSNotification *)notification { NSLog(@"[PushPlugin] Stored the completion handler for the background processing of notId %@", notIdKey); self.notificationMessage = [mutableUserInfo copy]; - self.isInline = NO; + self.isForeground = NO; [self notificationReceived]; } else { NSLog(@"[PushPlugin] Application is not active, saving notification for later."); @@ -388,7 +388,7 @@ - (void)willPresentNotification:(NSNotification *)notification { } self.notificationMessage = [modifiedUserInfo copy]; - self.isInline = YES; + self.isForeground = YES; UNNotificationPresentationOptions presentationOption = UNNotificationPresentationOptionNone; @@ -427,7 +427,7 @@ - (void)didReceiveNotificationResponse:(NSNotification *)notification { { NSLog(@"[PushPlugin] App is active. Notification message set with: %@", modifiedUserInfo); - self.isInline = NO; + self.isForeground = YES; self.notificationMessage = [modifiedUserInfo copy]; [self notificationReceived]; if (completionHandler) { @@ -440,6 +440,7 @@ - (void)didReceiveNotificationResponse:(NSNotification *)notification { NSLog(@"[PushPlugin] App is inactive. Storing notification message for later launch with: %@", modifiedUserInfo); self.coldstart = YES; + self.isForeground = NO; self.launchNotification = [modifiedUserInfo copy]; if (completionHandler) { completionHandler(); @@ -478,7 +479,7 @@ - (void)didReceiveNotificationResponse:(NSNotification *)notification { NSLog(@"[PushPlugin] Stored the completion handler for the background processing of notId %@", notIdKey); - self.isInline = NO; + self.isForeground = NO; self.notificationMessage = [modifiedUserInfo copy]; [self performSelectorOnMainThread:@selector(notificationReceived) withObject:self waitUntilDone:NO]; @@ -547,7 +548,7 @@ - (void)notificationReceived { } } - if (self.isInline) { + if (self.isForeground) { [additionalData setObject:[NSNumber numberWithBool:YES] forKey:@"foreground"]; } else { [additionalData setObject:[NSNumber numberWithBool:NO] forKey:@"foreground"]; @@ -567,7 +568,7 @@ - (void)notificationReceived { [self.commandDelegate sendPluginResult:pluginResult callbackId:self.callbackId]; self.coldstart = NO; - self.isInline = NO; + self.isForeground = NO; self.notificationMessage = nil; } }