Swiftgram/TelegramUI/OverlayStatusController.swift
2018-11-11 20:13:03 +04:00

169 lines
5.6 KiB
Swift

import Foundation
import Display
import LegacyComponents
enum OverlayStatusControllerType {
case loading(cancelled: (() -> Void)?)
case success
case proxySettingSuccess
case genericSuccess(String)
}
private enum OverlayStatusContentController {
case loading(TGProgressWindowController)
case progress(TGProgressWindowController)
case proxy(TGProxyWindowController)
case genericSuccess(TGProxyWindowController)
var view: UIView {
switch self {
case let .loading(controller):
return controller.view
case let .progress(controller):
return controller.view
case let .proxy(controller):
return controller.view
case let .genericSuccess(controller):
return controller.view
}
}
func updateLayout() {
switch self {
case let .loading(controller):
controller.updateLayout()
case let .progress(controller):
controller.updateLayout()
case let .proxy(controller):
controller.updateLayout()
case let .genericSuccess(controller):
controller.updateLayout()
}
}
func show(success: @escaping () -> Void) {
switch self {
case let .loading(controller):
controller.show(true)
case let .progress(controller):
controller.dismiss(success: success)
case let .proxy(controller):
controller.dismiss(success: success)
case let .genericSuccess(controller):
controller.dismiss(success: success)
}
}
func dismiss(completion: @escaping () -> Void) {
switch self {
case let .loading(controller):
controller.dismiss(true, completion: {
completion()
})
default:
completion()
}
}
}
private final class OverlayStatusControllerNode: ViewControllerTracingNode {
private let dismissed: () -> Void
private let contentController: OverlayStatusContentController
init(theme: PresentationTheme, strings: PresentationStrings, type: OverlayStatusControllerType, dismissed: @escaping () -> Void) {
self.dismissed = dismissed
switch type {
case let .loading(cancelled):
let controller = TGProgressWindowController(light: theme.actionSheet.backgroundType == .light)!
controller.cancelled = {
cancelled?()
}
self.contentController = .loading(controller)
case .success:
self.contentController = .progress(TGProgressWindowController(light: theme.actionSheet.backgroundType == .light))
case .proxySettingSuccess:
self.contentController = .proxy(TGProxyWindowController(light: theme.actionSheet.backgroundType == .light, text: strings.SocksProxySetup_ProxyEnabled, shield: true))
case let .genericSuccess(text):
self.contentController = .genericSuccess(TGProxyWindowController(light: theme.actionSheet.backgroundType == .light, text: text, shield: false))
}
super.init()
self.backgroundColor = nil
self.isOpaque = false
self.view.addSubview(self.contentController.view)
}
func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) {
self.contentController.view.frame = CGRect(origin: CGPoint(), size: layout.size)
self.contentController.updateLayout()
}
func begin() {
self.contentController.show(success: { [weak self] in
self?.dismissed()
})
}
func dismiss() {
self.contentController.dismiss(completion: { [weak self] in
self?.dismissed()
})
}
}
final class OverlayStatusController: ViewController {
private let theme: PresentationTheme
private let strings: PresentationStrings
private let type: OverlayStatusControllerType
private var animatedDidAppear = false
private var controllerNode: OverlayStatusControllerNode {
return self.displayNode as! OverlayStatusControllerNode
}
init(theme: PresentationTheme, strings: PresentationStrings, type: OverlayStatusControllerType) {
self.theme = theme
self.strings = strings
self.type = type
super.init(navigationBarPresentationData: nil)
self.statusBar.statusBarStyle = .Ignore
}
required init(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
override func loadDisplayNode() {
self.displayNode = OverlayStatusControllerNode(theme: self.theme, strings: self.strings, type: self.type, dismissed: { [weak self] in
self?.presentingViewController?.dismiss(animated: false, completion: nil)
})
self.displayNodeDidLoad()
}
override func containerLayoutUpdated(_ layout: ContainerViewLayout, transition: ContainedViewLayoutTransition) {
super.containerLayoutUpdated(layout, transition: transition)
self.controllerNode.containerLayoutUpdated(layout, transition: transition)
}
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
if !self.animatedDidAppear {
self.animatedDidAppear = true
self.controllerNode.begin()
}
}
func dismiss() {
self.controllerNode.dismiss()
}
}