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.
		
		
		
		
		
			
		
			
				
	
	
		
			138 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Swift
		
	
			
		
		
	
	
			138 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Swift
		
	
// Copyright © 2022 Rangeproof Pty Ltd. All rights reserved.
 | 
						|
 | 
						|
import UIKit
 | 
						|
import SessionUIKit
 | 
						|
 | 
						|
class ThemeSelectionView: UIView {
 | 
						|
    private static let selectionBorderSize: CGFloat = 26
 | 
						|
    private static let selectionSize: CGFloat = 20
 | 
						|
    
 | 
						|
    public let theme: Theme
 | 
						|
    private let onSelected: (Theme) -> ()
 | 
						|
    
 | 
						|
    // MARK: - Components
 | 
						|
    
 | 
						|
    private lazy var backgroundButton: UIButton = {
 | 
						|
        let result: UIButton = UIButton()
 | 
						|
        result.translatesAutoresizingMaskIntoConstraints = false
 | 
						|
        result.setThemeBackgroundColor(.appearance_buttonBackground, for: .normal)
 | 
						|
        result.setThemeBackgroundColor(.highlighted(.appearance_buttonBackground), for: .highlighted)
 | 
						|
        result.addTarget(self, action: #selector(itemSelected), for: .touchUpInside)
 | 
						|
        
 | 
						|
        return result
 | 
						|
    }()
 | 
						|
    
 | 
						|
    private let previewView: UIView = {
 | 
						|
        let result: UIView = UIView()
 | 
						|
        result.translatesAutoresizingMaskIntoConstraints = false
 | 
						|
        result.isUserInteractionEnabled = false
 | 
						|
        result.layer.cornerRadius = 6
 | 
						|
        result.layer.borderWidth = 1
 | 
						|
        
 | 
						|
        return result
 | 
						|
    }()
 | 
						|
    
 | 
						|
    private let previewIncomingMessageView: UIView = {
 | 
						|
        let result: UIView = UIView()
 | 
						|
        result.translatesAutoresizingMaskIntoConstraints = false
 | 
						|
        result.isUserInteractionEnabled = false
 | 
						|
        result.layer.cornerRadius = 6
 | 
						|
        
 | 
						|
        return result
 | 
						|
    }()
 | 
						|
    
 | 
						|
    private let previewOutgoingMessageView: UIView = {
 | 
						|
        let result: UIView = UIView()
 | 
						|
        result.translatesAutoresizingMaskIntoConstraints = false
 | 
						|
        result.isUserInteractionEnabled = false
 | 
						|
        result.layer.cornerRadius = 6
 | 
						|
        
 | 
						|
        return result
 | 
						|
    }()
 | 
						|
    
 | 
						|
    private let selectionView: RadioButton = {
 | 
						|
        let result: RadioButton = RadioButton(size: .medium)
 | 
						|
        result.translatesAutoresizingMaskIntoConstraints = false
 | 
						|
        result.isUserInteractionEnabled = false
 | 
						|
        result.font = .systemFont(ofSize: Values.mediumFontSize, weight: .bold)
 | 
						|
        
 | 
						|
        return result
 | 
						|
    }()
 | 
						|
    
 | 
						|
    // MARK: - Initializtion
 | 
						|
    
 | 
						|
    init(theme: Theme, onSelected: @escaping (Theme) -> ()) {
 | 
						|
        self.theme = theme
 | 
						|
        self.onSelected = onSelected
 | 
						|
        
 | 
						|
        super.init(frame: .zero)
 | 
						|
        
 | 
						|
        setupUI(theme: theme)
 | 
						|
    }
 | 
						|
    
 | 
						|
    required init?(coder: NSCoder) {
 | 
						|
        fatalError("Use init(theme:) instead")
 | 
						|
    }
 | 
						|
    
 | 
						|
    // MARK: - Layout
 | 
						|
    
 | 
						|
    private func setupUI(theme: Theme) {
 | 
						|
        self.themeBackgroundColor = .appearance_sectionBackground
 | 
						|
        
 | 
						|
        // Set the appropriate colours
 | 
						|
        previewView.themeBackgroundColorForced = .theme(theme, color: .backgroundPrimary)
 | 
						|
        previewView.themeBorderColorForced = .theme(theme, color: .borderSeparator)
 | 
						|
        previewIncomingMessageView.themeBackgroundColorForced = .theme(theme, color: .messageBubble_incomingBackground)
 | 
						|
        previewOutgoingMessageView.themeBackgroundColorForced = .theme(theme, color: .defaultPrimary)
 | 
						|
        selectionView.text = theme.title
 | 
						|
        
 | 
						|
        // Add the UI
 | 
						|
        addSubview(backgroundButton)
 | 
						|
        addSubview(previewView)
 | 
						|
        addSubview(selectionView)
 | 
						|
        
 | 
						|
        previewView.addSubview(previewIncomingMessageView)
 | 
						|
        previewView.addSubview(previewOutgoingMessageView)
 | 
						|
        
 | 
						|
        setupLayout()
 | 
						|
    }
 | 
						|
    
 | 
						|
    private func setupLayout() {
 | 
						|
        backgroundButton.pin(to: self)
 | 
						|
        
 | 
						|
        previewView.pin(.top, to: .top, of: self, withInset: Values.smallSpacing)
 | 
						|
        previewView.pin(.leading, to: .leading, of: self, withInset: Values.largeSpacing)
 | 
						|
        previewView.pin(.bottom, to: .bottom, of: self, withInset: -Values.smallSpacing)
 | 
						|
        previewView.set(.width, to: 76)
 | 
						|
        previewView.set(.height, to: 70)
 | 
						|
        
 | 
						|
        previewIncomingMessageView.bottomAnchor
 | 
						|
            .constraint(equalTo: previewView.centerYAnchor, constant: -1)
 | 
						|
            .isActive = true
 | 
						|
        previewIncomingMessageView.pin(.leading, to: .leading, of: previewView, withInset: Values.smallSpacing)
 | 
						|
        previewIncomingMessageView.set(.width, to: 40)
 | 
						|
        previewIncomingMessageView.set(.height, to: 12)
 | 
						|
        
 | 
						|
        previewOutgoingMessageView.topAnchor
 | 
						|
            .constraint(equalTo: previewView.centerYAnchor, constant: 1)
 | 
						|
            .isActive = true
 | 
						|
        previewOutgoingMessageView.pin(.trailing, to: .trailing, of: previewView, withInset: -Values.smallSpacing)
 | 
						|
        previewOutgoingMessageView.set(.width, to: 40)
 | 
						|
        previewOutgoingMessageView.set(.height, to: 12)
 | 
						|
        
 | 
						|
        selectionView.center(.vertical, in: self)
 | 
						|
        selectionView.pin(.leading, to: .trailing, of: previewView, withInset: Values.mediumSpacing)
 | 
						|
        selectionView.pin(.trailing, to: .trailing, of: self, withInset: -Values.veryLargeSpacing)
 | 
						|
    }
 | 
						|
    
 | 
						|
    // MARK: - Content
 | 
						|
    
 | 
						|
    func update(isSelected: Bool) {
 | 
						|
        selectionView.update(isSelected: isSelected)
 | 
						|
    }
 | 
						|
    
 | 
						|
    @objc func itemSelected() {
 | 
						|
        onSelected(theme)
 | 
						|
    }
 | 
						|
}
 |