mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-06-16 05:55:20 +00:00
125 lines
4.4 KiB
Swift
125 lines
4.4 KiB
Swift
import Foundation
|
|
import UIKit
|
|
import Display
|
|
import AsyncDisplayKit
|
|
import UIKit
|
|
import SwiftSignalKit
|
|
import TelegramCore
|
|
import SyncCore
|
|
import TelegramPresentationData
|
|
import TelegramStringFormatting
|
|
import AccountContext
|
|
|
|
final class PeerBanTimeoutController: ActionSheetController {
|
|
private var presentationDisposable: Disposable?
|
|
|
|
private let _ready = Promise<Bool>()
|
|
override var ready: Promise<Bool> {
|
|
return self._ready
|
|
}
|
|
|
|
init(context: AccountContext, currentValue: Int32, applyValue: @escaping (Int32?) -> Void) {
|
|
let presentationData = context.sharedContext.currentPresentationData.with { $0 }
|
|
let theme = presentationData.theme
|
|
let strings = presentationData.strings
|
|
|
|
super.init(theme: ActionSheetControllerTheme(presentationTheme: theme))
|
|
|
|
self._ready.set(.single(true))
|
|
|
|
self.presentationDisposable = context.sharedContext.presentationData.start(next: { [weak self] presentationData in
|
|
if let strongSelf = self {
|
|
strongSelf.theme = ActionSheetControllerTheme(presentationTheme: presentationData.theme)
|
|
}
|
|
})
|
|
|
|
var updatedValue = currentValue
|
|
var items: [ActionSheetItem] = []
|
|
items.append(PeerBanTimeoutActionSheetItem(strings: strings, currentValue: currentValue, valueChanged: { value in
|
|
updatedValue = value
|
|
}))
|
|
items.append(ActionSheetButtonItem(title: strings.Wallpaper_Set, action: { [weak self] in
|
|
self?.dismissAnimated()
|
|
applyValue(updatedValue)
|
|
}))
|
|
self.setItemGroups([
|
|
ActionSheetItemGroup(items: items),
|
|
ActionSheetItemGroup(items: [
|
|
ActionSheetButtonItem(title: strings.Common_Cancel, action: { [weak self] in
|
|
self?.dismissAnimated()
|
|
}),
|
|
])
|
|
])
|
|
}
|
|
|
|
required init(coder aDecoder: NSCoder) {
|
|
fatalError("init(coder:) has not been implemented")
|
|
}
|
|
|
|
deinit {
|
|
self.presentationDisposable?.dispose()
|
|
}
|
|
}
|
|
|
|
private final class PeerBanTimeoutActionSheetItem: ActionSheetItem {
|
|
let strings: PresentationStrings
|
|
|
|
let currentValue: Int32
|
|
let valueChanged: (Int32) -> Void
|
|
|
|
init(strings: PresentationStrings, currentValue: Int32, valueChanged: @escaping (Int32) -> Void) {
|
|
self.strings = strings
|
|
self.currentValue = roundDateToDays(currentValue)
|
|
self.valueChanged = valueChanged
|
|
}
|
|
|
|
func node(theme: ActionSheetControllerTheme) -> ActionSheetItemNode {
|
|
return PeerBanTimeoutActionSheetItemNode(theme: theme, strings: self.strings, currentValue: self.currentValue, valueChanged: self.valueChanged)
|
|
}
|
|
|
|
func updateNode(_ node: ActionSheetItemNode) {
|
|
}
|
|
}
|
|
|
|
private final class PeerBanTimeoutActionSheetItemNode: ActionSheetItemNode {
|
|
private let theme: ActionSheetControllerTheme
|
|
private let strings: PresentationStrings
|
|
|
|
private let valueChanged: (Int32) -> Void
|
|
private let pickerView: UIDatePicker
|
|
|
|
init(theme: ActionSheetControllerTheme, strings: PresentationStrings, currentValue: Int32, valueChanged: @escaping (Int32) -> Void) {
|
|
self.theme = theme
|
|
self.strings = strings
|
|
self.valueChanged = valueChanged
|
|
|
|
self.pickerView = UIDatePicker()
|
|
self.pickerView.datePickerMode = .date
|
|
self.pickerView.date = Date(timeIntervalSince1970: Double(roundDateToDays(currentValue)))
|
|
self.pickerView.locale = localeWithStrings(strings)
|
|
self.pickerView.minimumDate = Date()
|
|
self.pickerView.maximumDate = Date(timeIntervalSince1970: Double(Int32.max - 1))
|
|
|
|
self.pickerView.setValue(theme.primaryTextColor, forKey: "textColor")
|
|
|
|
super.init(theme: theme)
|
|
|
|
self.view.addSubview(self.pickerView)
|
|
self.pickerView.addTarget(self, action: #selector(self.datePickerUpdated), for: .valueChanged)
|
|
}
|
|
|
|
override func calculateSizeThatFits(_ constrainedSize: CGSize) -> CGSize {
|
|
return CGSize(width: constrainedSize.width, height: 216.0)
|
|
}
|
|
|
|
override func layout() {
|
|
super.layout()
|
|
|
|
self.pickerView.frame = CGRect(origin: CGPoint(), size: CGSize(width: self.bounds.size.width, height: 216.0))
|
|
}
|
|
|
|
@objc private func datePickerUpdated() {
|
|
self.valueChanged(roundDateToDays(Int32(self.pickerView.date.timeIntervalSince1970)))
|
|
}
|
|
}
|