From ab1ffd576d541c2423adf422b54d0b1b0483d00e Mon Sep 17 00:00:00 2001 From: jcesarmobile Date: Thu, 26 Sep 2019 13:30:25 +0200 Subject: [PATCH] fix(ios): make StatusBar Light style work on Dark mode (#1996) --- ios/Capacitor/Capacitor/CAPBridge.swift | 8 ++++ .../Capacitor/CAPBridgeViewController.swift | 2 +- .../Capacitor/Plugins/StatusBar.swift | 43 ++++++++++++++----- 3 files changed, 42 insertions(+), 11 deletions(-) diff --git a/ios/Capacitor/Capacitor/CAPBridge.swift b/ios/Capacitor/Capacitor/CAPBridge.swift index 691fc2660..91842bdef 100644 --- a/ios/Capacitor/Capacitor/CAPBridge.swift +++ b/ios/Capacitor/Capacitor/CAPBridge.swift @@ -94,6 +94,14 @@ enum BridgeError: Error { } return bridgeVC.preferredStatusBarStyle } + + @available(iOS 12.0, *) + public func getUserInterfaceStyle() -> UIUserInterfaceStyle { + guard let bridgeVC = self.viewController as? CAPBridgeViewController else { + return UIUserInterfaceStyle.unspecified + } + return bridgeVC.traitCollection.userInterfaceStyle + } /** * Get the last URL that triggered an open or continue activity event. diff --git a/ios/Capacitor/Capacitor/CAPBridgeViewController.swift b/ios/Capacitor/Capacitor/CAPBridgeViewController.swift index 22a3fe204..b103df6af 100644 --- a/ios/Capacitor/Capacitor/CAPBridgeViewController.swift +++ b/ios/Capacitor/Capacitor/CAPBridgeViewController.swift @@ -179,7 +179,7 @@ public class CAPBridgeViewController: UIViewController, CAPBridgeDelegate, WKScr } } if let statusBarStyle = plist["UIStatusBarStyle"] as? String { - if (statusBarStyle != "UIStatusBarStyleDefault") { + if (statusBarStyle != "UIStatusBarStyleDefault" && statusBarStyle != "UIStatusBarStyleDarkContent") { self.statusBarStyle = .lightContent } } diff --git a/ios/Capacitor/Capacitor/Plugins/StatusBar.swift b/ios/Capacitor/Capacitor/Plugins/StatusBar.swift index c2df127ec..4b60bdbaf 100644 --- a/ios/Capacitor/Capacitor/Plugins/StatusBar.swift +++ b/ios/Capacitor/Capacitor/Plugins/StatusBar.swift @@ -20,7 +20,12 @@ public class CAPStatusBarPlugin: CAPPlugin { if style == "DARK" { bridge.setStatusBarStyle(.lightContent) } else if style == "LIGHT" { - bridge.setStatusBarStyle(.default) + if #available(iOS 13.0, *) { + // TODO - use .darkContent instead of rawValue once Xcode 10 support is dropped + bridge.setStatusBarStyle(UIStatusBarStyle.init(rawValue: 3) ?? .default) + } else { + bridge.setStatusBarStyle(.default) + } } } @@ -42,16 +47,34 @@ public class CAPStatusBarPlugin: CAPPlugin { } @objc func getInfo(_ call: CAPPluginCall) { - let style: String - if bridge.getStatusBarStyle() == .default { - style = "LIGHT" - } else { - style = "DARK" + DispatchQueue.main.async { + let style: String + if #available(iOS 13.0, *) { + switch self.bridge.getStatusBarStyle() { + case .default: + if self.bridge.getUserInterfaceStyle() == UIUserInterfaceStyle.dark { + style = "DARK" + } else { + style = "LIGHT" + } + case .lightContent: + style = "DARK" + default: + style = "LIGHT" + } + } else { + if self.bridge.getStatusBarStyle() == .lightContent { + style = "DARK" + } else { + style = "LIGHT" + } + } + + call.success([ + "visible": self.bridge.getStatusBarVisible(), + "style": style + ]) } - call.success([ - "visible": bridge.getStatusBarVisible(), - "style": style - ]) } }