mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-06-16 05:55:20 +00:00
130 lines
4.2 KiB
Swift
130 lines
4.2 KiB
Swift
import Foundation
|
|
import UIKit
|
|
import ComponentFlow
|
|
import Display
|
|
import SolidRoundedButtonNode
|
|
import AppBundle
|
|
|
|
public final class SolidRoundedButtonComponent: Component {
|
|
public typealias Theme = SolidRoundedButtonTheme
|
|
|
|
public let title: String?
|
|
public let icon: UIImage?
|
|
public let theme: SolidRoundedButtonTheme
|
|
public let font: SolidRoundedButtonFont
|
|
public let fontSize: CGFloat
|
|
public let height: CGFloat
|
|
public let cornerRadius: CGFloat
|
|
public let gloss: Bool
|
|
public let iconName: String?
|
|
public let iconPosition: SolidRoundedButtonIconPosition
|
|
public let action: () -> Void
|
|
|
|
public init(
|
|
title: String? = nil,
|
|
icon: UIImage? = nil,
|
|
theme: SolidRoundedButtonTheme,
|
|
font: SolidRoundedButtonFont = .bold,
|
|
fontSize: CGFloat = 17.0,
|
|
height: CGFloat = 48.0,
|
|
cornerRadius: CGFloat = 24.0,
|
|
gloss: Bool = false,
|
|
iconName: String? = nil,
|
|
iconPosition: SolidRoundedButtonIconPosition = .left,
|
|
action: @escaping () -> Void
|
|
) {
|
|
self.title = title
|
|
self.icon = icon
|
|
self.theme = theme
|
|
self.font = font
|
|
self.fontSize = fontSize
|
|
self.height = height
|
|
self.cornerRadius = cornerRadius
|
|
self.gloss = gloss
|
|
self.iconName = iconName
|
|
self.iconPosition = iconPosition
|
|
self.action = action
|
|
}
|
|
|
|
public static func ==(lhs: SolidRoundedButtonComponent, rhs: SolidRoundedButtonComponent) -> Bool {
|
|
if lhs.title != rhs.title {
|
|
return false
|
|
}
|
|
if lhs.icon !== rhs.icon {
|
|
return false
|
|
}
|
|
if lhs.theme != rhs.theme {
|
|
return false
|
|
}
|
|
if lhs.font != rhs.font {
|
|
return false
|
|
}
|
|
if lhs.fontSize != rhs.fontSize {
|
|
return false
|
|
}
|
|
if lhs.height != rhs.height {
|
|
return false
|
|
}
|
|
if lhs.cornerRadius != rhs.cornerRadius {
|
|
return false
|
|
}
|
|
if lhs.gloss != rhs.gloss {
|
|
return false
|
|
}
|
|
if lhs.iconName != rhs.iconName {
|
|
return false
|
|
}
|
|
if lhs.iconPosition != rhs.iconPosition {
|
|
return false
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
public final class View: UIView {
|
|
private var component: SolidRoundedButtonComponent?
|
|
private var button: SolidRoundedButtonView?
|
|
|
|
public func update(component: SolidRoundedButtonComponent, availableSize: CGSize, transition: Transition) -> CGSize {
|
|
if self.button == nil {
|
|
let button = SolidRoundedButtonView(
|
|
title: component.title,
|
|
icon: component.icon,
|
|
theme: component.theme,
|
|
font: component.font,
|
|
fontSize: component.fontSize,
|
|
height: component.height,
|
|
cornerRadius: component.cornerRadius,
|
|
gloss: component.gloss
|
|
)
|
|
button.iconPosition = component.iconPosition
|
|
button.icon = component.iconName.flatMap { UIImage(bundleImageName: $0) }
|
|
self.button = button
|
|
self.addSubview(button)
|
|
|
|
button.pressed = { [weak self] in
|
|
self?.component?.action()
|
|
}
|
|
}
|
|
|
|
if let button = self.button {
|
|
button.updateTheme(component.theme)
|
|
let height = button.updateLayout(width: availableSize.width, transition: .immediate)
|
|
transition.setFrame(view: button, frame: CGRect(origin: CGPoint(), size: CGSize(width: availableSize.width, height: height)), completion: nil)
|
|
}
|
|
|
|
self.component = component
|
|
|
|
return availableSize
|
|
}
|
|
}
|
|
|
|
public func makeView() -> View {
|
|
return View()
|
|
}
|
|
|
|
public func update(view: View, availableSize: CGSize, state: EmptyComponentState, environment: Environment<Empty>, transition: Transition) -> CGSize {
|
|
return view.update(component: self, availableSize: availableSize, transition: transition)
|
|
}
|
|
}
|