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.
session-ios/Session/Settings/Views/ThemeMessagePreviewView.swift

116 lines
3.6 KiB
Swift

// Copyright © 2022 Rangeproof Pty Ltd. All rights reserved.
import UIKit
import SessionUIKit
import SessionMessagingKit
import SessionUtilitiesKit
final class ThemeMessagePreviewView: UIView {
public static let size: SessionCell.Accessory.Size = .fillWidthWrapHeight
private let dependencies: Dependencies
// MARK: - Components
private lazy var incomingMessagePreview: UIView = {
let result: VisibleMessageCell = VisibleMessageCell()
result.translatesAutoresizingMaskIntoConstraints = true
result.update(
with: MessageViewModel(
variant: .standardIncoming,
body: "appearancePreview2".localized(),
quote: Quote(
interactionId: -1,
authorId: "",
timestampMs: 0,
body: "appearancePreview1".localized(),
attachmentId: nil
),
cellType: .textOnlyMessage
),
mediaCache: NSCache(),
playbackInfo: nil,
showExpandedReactions: false,
lastSearchText: nil,
using: dependencies
)
// Remove built-in padding
result.authorLabelTopConstraint.constant = 0
result.contentViewLeadingConstraint1.constant = 0
return result
}()
private lazy var outgoingMessagePreview: UIView = {
let result: VisibleMessageCell = VisibleMessageCell()
result.translatesAutoresizingMaskIntoConstraints = true
result.update(
with: MessageViewModel(
variant: .standardOutgoing,
body: "appearancePreview3".localized(),
cellType: .textOnlyMessage,
isLast: false // To hide the status indicator
),
mediaCache: NSCache(),
playbackInfo: nil,
showExpandedReactions: false,
lastSearchText: nil,
using: dependencies
)
// Remove built-in padding
result.authorLabelTopConstraint.constant = 0
result.contentViewTrailingConstraint1.constant = 0
return result
}()
// MARK: - Initializtion
init(using dependencies: Dependencies) {
self.dependencies = dependencies
super.init(frame: .zero)
setupUI()
}
required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
// MARK: - Layout
private func setupUI() {
addSubview(incomingMessagePreview)
addSubview(outgoingMessagePreview)
setupLayout()
}
private func setupLayout() {
incomingMessagePreview.pin(.top, to: .top, of: self)
incomingMessagePreview.pin(.leading, to: .leading, of: self)
outgoingMessagePreview.pin(.top, to: .bottom, of: incomingMessagePreview, withInset: Values.mediumSpacing)
outgoingMessagePreview.pin(.trailing, to: .trailing, of: self)
outgoingMessagePreview.pin(.bottom, to: .bottom, of: self)
}
}
// MARK: - Info
extension ThemeMessagePreviewView: SessionCell.Accessory.CustomView {
struct Info: Equatable, SessionCell.Accessory.CustomViewInfo {
typealias View = ThemeMessagePreviewView
}
static func create(maxContentWidth: CGFloat, using dependencies: Dependencies) -> ThemeMessagePreviewView {
return ThemeMessagePreviewView(using: dependencies)
}
// No need to do anything (theme with auto-update)
func update(with info: Info) {}
}