扩展中的快速关闭

扩展中的快速关闭

当从另一个类(例如,网络状态管理器)调用setInteractionEnabled方法时,我想装饰UIViewController并具有调整其界面的功能。应该通过覆盖onInteractionChanged在具体控制器中提供所有更改(如果有)。这是我的代码:

import Foundation

typealias InteractionClosure = ((enabled: Bool) -> Void)

protocol Interaction: class {

    var onInteractionChanged: InteractionClosure? { get set }

    func setInteractionEnabled(enabled: Bool)

}

extension Interaction where Self: UIViewController {

    // Default: Do nothing
    // Throws: - Extensions may not contain stored properties
    var onInteractionChanged: InteractionClosure? = nil

    func setInteractionEnabled(enabled: Bool) {
        onInteractionChanged?(enabled: enabled)
    }

}

extension UIViewController : Interaction {}

如何为onInteractionChanged添加默认实现?

最佳答案

我通常不会回答我自己的问题,但这是我的解决方案:

typealias InteractionClosure = (enabled: Bool) -> Void

protocol Interaction: class {

    func addOnInteractionChanged(closure: InteractionClosure)
    func setInteractionEnabled(enabled: Bool)

}

extension Interaction where Self: UIViewController {

    func addOnInteractionChanged(closure: InteractionClosure) {
        onInteractionChanged = closure
    }

    func setInteractionEnabled(enabled: Bool) {
        onInteractionChanged?(enabled: enabled)
    }

    // MARK: - Private

    private var onInteractionChanged: InteractionClosure? {
        get {
            let wrapper =
                objc_getAssociatedObject(self, &icAssociationKey) as? ClosureWrapper
            return wrapper?.closure
        }
        set(newValue) {
            objc_setAssociatedObject(self,
                                     &icAssociationKey,
                                     ClosureWrapper(newValue),
                                     .OBJC_ASSOCIATION_RETAIN)
        }
    }

}

extension UIViewController : Interaction {}

// Helpers

private var icAssociationKey: UInt8 = 0

private class ClosureWrapper {
    var closure: InteractionClosure?

    init(_ closure: InteractionClosure?) {
        self.closure = closure
    }
}

客户类别:
class LoginViewController: UIViewController {

    // MARK: - Lifecycle

    override func viewDidLoad() {
        super.viewDidLoad()
        self.setup()
    }

    // MARK: - Private

    private func setup() {
        // ...

        addOnInteractionChanged { [unowned self] (enabled) in
            self.signInButton.enabled = enabled
            self.activityIndicatorView.hidden = !enabled
        }
    }

}

在经理班:
visibleViewController?.setInteractionEnabled(true)

关于ios - 协议(protocol)扩展中的快速关闭,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/38072248/

10-11 18:27