From 4b4049472aca1eec2ab6e04e9af0ce3a78d9d972 Mon Sep 17 00:00:00 2001 From: jcesarmobile Date: Thu, 16 Apr 2020 17:20:07 +0200 Subject: [PATCH] fix(ios): allow Browser popover presentation if supported (#2784) --- ios/Capacitor/Capacitor/CAPPlugin.h | 1 + ios/Capacitor/Capacitor/CAPPlugin.m | 8 ++++++++ ios/Capacitor/Capacitor/Plugins/Browser.swift | 2 +- 3 files changed, 10 insertions(+), 1 deletion(-) diff --git a/ios/Capacitor/Capacitor/CAPPlugin.h b/ios/Capacitor/Capacitor/CAPPlugin.h index 6956d6635..b41c4585b 100644 --- a/ios/Capacitor/Capacitor/CAPPlugin.h +++ b/ios/Capacitor/Capacitor/CAPPlugin.h @@ -34,5 +34,6 @@ -(NSString *) getString:(CAPPluginCall *)call field:(NSString *)field defaultValue:(NSString *)defaultValue; -(id)getConfigValue:(NSString *) key; -(void)setCenteredPopover:(UIViewController *) vc; +-(BOOL)supportsPopover; @end diff --git a/ios/Capacitor/Capacitor/CAPPlugin.m b/ios/Capacitor/Capacitor/CAPPlugin.m index 5e0c98479..f0fe9e14e 100644 --- a/ios/Capacitor/Capacitor/CAPPlugin.m +++ b/ios/Capacitor/Capacitor/CAPPlugin.m @@ -147,5 +147,13 @@ -(void)setCenteredPopover:(UIViewController *) vc { vc.popoverPresentationController.permittedArrowDirections = 0; } +-(BOOL)supportsPopover { + if (@available(iOS 13, *)) { + return YES; + } else { + return UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPad; + } +} + @end diff --git a/ios/Capacitor/Capacitor/Plugins/Browser.swift b/ios/Capacitor/Capacitor/Plugins/Browser.swift index f7be28a67..0a1a91529 100644 --- a/ios/Capacitor/Capacitor/Plugins/Browser.swift +++ b/ios/Capacitor/Capacitor/Plugins/Browser.swift @@ -23,7 +23,7 @@ public class CAPBrowserPlugin : CAPPlugin, SFSafariViewControllerDelegate { self.vc = SFSafariViewController.init(url: url!) self.vc!.delegate = self let presentationStyle = call.getString("presentationStyle") - if presentationStyle != nil && presentationStyle == "popover" && UIDevice.current.userInterfaceIdiom == .pad { + if presentationStyle != nil && presentationStyle == "popover" && self.supportsPopover() { self.vc!.modalPresentationStyle = .popover self.setCenteredPopover(self.vc) } else {