mirror of https://github.com/oxen-io/session-ios
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
107 lines
3.5 KiB
Swift
107 lines
3.5 KiB
Swift
import UIKit
|
|
|
|
final class ReactionView : UIView {
|
|
let emoji: String
|
|
let number: Int
|
|
let hasCurrentUser: Bool
|
|
|
|
// MARK: Settings
|
|
private static let height: CGFloat = 22
|
|
|
|
// MARK: Lifecycle
|
|
init(emoji: String, value: (Int, Bool)) {
|
|
self.emoji = emoji
|
|
self.number = value.0
|
|
self.hasCurrentUser = value.1
|
|
super.init(frame: CGRect.zero)
|
|
setUpViewHierarchy()
|
|
}
|
|
|
|
override init(frame: CGRect) {
|
|
preconditionFailure("Use init(viewItem:textColor:) instead.")
|
|
}
|
|
|
|
required init?(coder: NSCoder) {
|
|
preconditionFailure("Use init(viewItem:textColor:) instead.")
|
|
}
|
|
|
|
private func setUpViewHierarchy() {
|
|
let emojiLabel = UILabel()
|
|
emojiLabel.text = emoji
|
|
emojiLabel.font = .systemFont(ofSize: Values.verySmallFontSize)
|
|
|
|
let numberLabel = UILabel()
|
|
numberLabel.text = self.number < 1000 ? "\(number)" : String(format: "%.1f", Float(number) / 1000) + "k"
|
|
numberLabel.font = .systemFont(ofSize: Values.verySmallFontSize)
|
|
numberLabel.textColor = Colors.text
|
|
|
|
let stackView = UIStackView(arrangedSubviews: [ emojiLabel, numberLabel ])
|
|
stackView.axis = .horizontal
|
|
stackView.spacing = Values.verySmallSpacing
|
|
stackView.alignment = .center
|
|
stackView.layoutMargins = UIEdgeInsets(top: 0, left: Values.smallSpacing, bottom: 0, right: Values.smallSpacing)
|
|
stackView.isLayoutMarginsRelativeArrangement = true
|
|
addSubview(stackView)
|
|
stackView.pin(to: self)
|
|
|
|
set(.height, to: ReactionView.height)
|
|
backgroundColor = Colors.receivedMessageBackground
|
|
layer.cornerRadius = ReactionView.height / 2
|
|
|
|
if hasCurrentUser {
|
|
layer.borderWidth = 1
|
|
layer.borderColor = Colors.accent.cgColor
|
|
}
|
|
}
|
|
}
|
|
|
|
final class ExpandingReactionButton: UIView {
|
|
private let emojis: [String]
|
|
|
|
// MARK: Settings
|
|
private let size: CGFloat = 22
|
|
private let margin: CGFloat = 15
|
|
|
|
// MARK: Lifecycle
|
|
init(emojis: [String]) {
|
|
self.emojis = emojis
|
|
super.init(frame: CGRect.zero)
|
|
setUpViewHierarchy()
|
|
}
|
|
|
|
override init(frame: CGRect) {
|
|
preconditionFailure("Use init(viewItem:textColor:) instead.")
|
|
}
|
|
|
|
required init?(coder: NSCoder) {
|
|
preconditionFailure("Use init(viewItem:textColor:) instead.")
|
|
}
|
|
|
|
private func setUpViewHierarchy() {
|
|
var rightMargin: CGFloat = 0
|
|
for emoji in self.emojis.reversed() {
|
|
let container = UIView()
|
|
container.set(.width, to: size)
|
|
container.set(.height, to: size)
|
|
container.backgroundColor = Colors.receivedMessageBackground
|
|
container.layer.cornerRadius = size / 2
|
|
container.layer.borderWidth = 1
|
|
container.layer.borderColor = isDarkMode ? UIColor.black.cgColor : UIColor.white.cgColor
|
|
|
|
let emojiLabel = UILabel()
|
|
emojiLabel.text = emoji
|
|
emojiLabel.font = .systemFont(ofSize: Values.verySmallFontSize)
|
|
|
|
container.addSubview(emojiLabel)
|
|
emojiLabel.center(in: container)
|
|
|
|
addSubview(container)
|
|
container.pin([ UIView.VerticalEdge.top, UIView.VerticalEdge.bottom ], to: self)
|
|
container.pin(.right, to: .right, of: self, withInset: -rightMargin)
|
|
rightMargin += margin
|
|
}
|
|
|
|
set(.width, to: rightMargin - margin + size)
|
|
}
|
|
}
|