From 5723419813b15e1b2790975f102023445b8163ff Mon Sep 17 00:00:00 2001 From: Adam Campbell Date: Tue, 21 Jul 2020 15:33:27 +1000 Subject: [PATCH 1/2] Remove top level namespace enum So that it doesn't clash with the module name when being read as a swift interface --- Sources/Afterpay/Afterpay.swift | 58 +++++++++++++++------------------ 1 file changed, 27 insertions(+), 31 deletions(-) diff --git a/Sources/Afterpay/Afterpay.swift b/Sources/Afterpay/Afterpay.swift index 1fce5222..e8446cc9 100644 --- a/Sources/Afterpay/Afterpay.swift +++ b/Sources/Afterpay/Afterpay.swift @@ -9,38 +9,34 @@ import Foundation import UIKit -public enum Afterpay { +/// Present Afterpay Checkout modally over the specified view controller loading your +/// generated checkout URL. +/// - Parameters: +/// - viewController: The viewController on which `UIViewController.present` will be called. +/// The Afterpay Checkout View Controller will be presented modally over this view controller +/// or it's closest parent that is able to handle the presentation. +/// - checkoutURL: The checkout URL to load generated via the /checkouts endpoint on the +/// Afterpay backend. +/// - animated: Pass true to animate the presentation; otherwise, pass false. +/// - completion: The block executed after the user has completed the checkout. +/// - result: The result of the user's completion (a success or cancellation). +public func presentCheckoutModally( + over viewController: UIViewController, + loading checkoutURL: URL, + animated: Bool = true, + completion: @escaping (_ result: CheckoutResult) -> Void +) { + var viewControllerToPresent: UIViewController = WebViewController( + checkoutUrl: checkoutURL, + completion: completion + ) - /// Present Afterpay Checkout modally over the specified view controller loading your - /// generated checkout URL. - /// - Parameters: - /// - viewController: The viewController on which `UIViewController.present` will be called. - /// The Afterpay Checkout View Controller will be presented modally over this view controller - /// or it's closest parent that is able to handle the presentation. - /// - checkoutURL: The checkout URL to load generated via the /checkouts endpoint on the - /// Afterpay backend. - /// - animated: Pass true to animate the presentation; otherwise, pass false. - /// - completion: The block executed after the user has completed the checkout. - /// - result: The result of the user's completion (a success or cancellation). - public static func presentCheckoutModally( - over viewController: UIViewController, - loading checkoutURL: URL, - animated: Bool = true, - completion: @escaping (_ result: CheckoutResult) -> Void - ) { - var viewControllerToPresent: UIViewController = WebViewController( - checkoutUrl: checkoutURL, - completion: completion - ) - - if #available(iOS 13.0, *) { - } else { - // Wrap the modal in a navigation controller to allow dismiss via a bar button item prior - // to popover modals in iOS13 - viewControllerToPresent = UINavigationController(rootViewController: viewControllerToPresent) - } - - viewController.present(viewControllerToPresent, animated: animated, completion: nil) + if #available(iOS 13.0, *) { + } else { + // Wrap the modal in a navigation controller to allow dismiss via a bar button item prior + // to popover modals in iOS13 + viewControllerToPresent = UINavigationController(rootViewController: viewControllerToPresent) } + viewController.present(viewControllerToPresent, animated: animated, completion: nil) } From d8d3d0406293886f09e883558e9f2bbc419f1176 Mon Sep 17 00:00:00 2001 From: Adam Campbell Date: Tue, 21 Jul 2020 15:35:29 +1000 Subject: [PATCH 2/2] Remove the inability to access the objective-c wrapper from swift This is required when exposing the code via a swift interface and xcframework --- Sources/Afterpay/ObjcWrapper.swift | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/Sources/Afterpay/ObjcWrapper.swift b/Sources/Afterpay/ObjcWrapper.swift index 1122bf43..4afe3f20 100644 --- a/Sources/Afterpay/ObjcWrapper.swift +++ b/Sources/Afterpay/ObjcWrapper.swift @@ -10,8 +10,7 @@ import Foundation import UIKit @objc(APAfterpay) -@available(swift, obsoleted: 1.0, message: "This wrapper should only be used from Objective-C") -public final class AfterpayWrapper: NSObject { +public final class ObjcWrapper: NSObject { @available(*, unavailable) public override init() {}