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.
		
		
		
		
		
			
		
			
				
	
	
		
			88 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Swift
		
	
			
		
		
	
	
			88 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Swift
		
	
| // Copyright © 2022 Rangeproof Pty Ltd. All rights reserved.
 | |
| 
 | |
| import UIKit
 | |
| import SessionUIKit
 | |
| 
 | |
| @objc(LKModal)
 | |
| class Modal: BaseVC, UIGestureRecognizerDelegate {
 | |
|     
 | |
|     // MARK: Components
 | |
|     lazy var contentView: UIView = {
 | |
|         let result = UIView()
 | |
|         result.backgroundColor = Colors.modalBackground
 | |
|         result.layer.cornerRadius = Modal.cornerRadius
 | |
|         result.layer.masksToBounds = false
 | |
|         result.layer.borderColor = isLightMode ? UIColor.white.cgColor : Colors.modalBorder.cgColor
 | |
|         result.layer.borderWidth = 1
 | |
|         result.layer.shadowColor = UIColor.black.cgColor
 | |
|         result.layer.shadowRadius = isLightMode ? 2 : 8
 | |
|         result.layer.shadowOpacity = isLightMode ? 0.1 : 0.64
 | |
|         return result
 | |
|     }()
 | |
|     
 | |
|     lazy var cancelButton: UIButton = {
 | |
|         let result = UIButton()
 | |
|         result.set(.height, to: Values.mediumButtonHeight)
 | |
|         result.layer.cornerRadius = Modal.buttonCornerRadius
 | |
|         result.backgroundColor = Colors.buttonBackground
 | |
|         result.titleLabel!.font = .systemFont(ofSize: Values.smallFontSize)
 | |
|         result.setTitleColor(Colors.text, for: UIControl.State.normal)
 | |
|         result.setTitle(NSLocalizedString("cancel", comment: ""), for: UIControl.State.normal)
 | |
|         return result
 | |
|     }()
 | |
|     
 | |
|     // MARK: Settings
 | |
|     private static let cornerRadius: CGFloat = 10
 | |
|     static let buttonCornerRadius = CGFloat(5)
 | |
|     
 | |
|     // MARK: Lifecycle
 | |
|     override func viewDidLoad() {
 | |
|         super.viewDidLoad()
 | |
|         let alpha = isLightMode ? CGFloat(0.1) : Values.highOpacity
 | |
|         view.backgroundColor = UIColor(hex: 0x000000).withAlphaComponent(alpha)
 | |
|         cancelButton.addTarget(self, action: #selector(close), for: UIControl.Event.touchUpInside)
 | |
|         
 | |
|         let swipeGestureRecognizer = UISwipeGestureRecognizer(target: self, action: #selector(close))
 | |
|         swipeGestureRecognizer.direction = .down
 | |
|         view.addGestureRecognizer(swipeGestureRecognizer)
 | |
|         
 | |
|         let tapGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(close))
 | |
|         tapGestureRecognizer.delegate = self
 | |
|         view.addGestureRecognizer(tapGestureRecognizer)
 | |
|         
 | |
|         setUpViewHierarchy()
 | |
|     }
 | |
|     
 | |
|     private func setUpViewHierarchy() {
 | |
|         view.addSubview(contentView)
 | |
|         if UIDevice.current.isIPad {
 | |
|             contentView.set(.width, to: Values.iPadModalWidth)
 | |
|             contentView.center(in: view)
 | |
|         } else {
 | |
|             contentView.leadingAnchor.constraint(equalTo: view.leadingAnchor, constant: Values.veryLargeSpacing).isActive = true
 | |
|             view.trailingAnchor.constraint(equalTo: contentView.trailingAnchor, constant: Values.veryLargeSpacing).isActive = true
 | |
|             contentView.center(.vertical, in: view)
 | |
|         }
 | |
|         populateContentView()
 | |
|     }
 | |
|     
 | |
|     /// To be overridden by subclasses.
 | |
|     func populateContentView() {
 | |
|         preconditionFailure("populateContentView() is abstract and must be overridden.")
 | |
|     }
 | |
|     
 | |
|     // MARK: - Interaction
 | |
|     
 | |
|     @objc func close() {
 | |
|         dismiss(animated: true, completion: nil)
 | |
|     }
 | |
|     
 | |
|     // MARK: - UIGestureRecognizerDelegate
 | |
|     
 | |
|     func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldReceive touch: UITouch) -> Bool {
 | |
|         let location: CGPoint = touch.location(in: contentView)
 | |
|         
 | |
|         return !contentView.point(inside: location, with: nil)
 | |
|     }
 | |
| }
 |