// Copyright © 2022 Rangeproof Pty Ltd. All rights reserved. import UIKit import GRDB import SessionUIKit import SessionUtilitiesKit import SessionMessagingKit final class DownloadAttachmentModal: Modal { private let profile: Profile? // MARK: - Lifecycle init(profile: Profile?) { self.profile = profile super.init(nibName: nil, bundle: nil) } override init(nibName: String?, bundle: Bundle?) { preconditionFailure("Use init(viewItem:) instead.") } required init?(coder: NSCoder) { preconditionFailure("Use init(viewItem:) instead.") } override func populateContentView() { guard let profile: Profile = profile else { return } // Name let name: String = profile.displayName() // Title let titleLabel = UILabel() titleLabel.textColor = Colors.text titleLabel.font = .boldSystemFont(ofSize: Values.mediumFontSize) titleLabel.text = String(format: NSLocalizedString("modal_download_attachment_title", comment: ""), name) titleLabel.textAlignment = .center // Message let messageLabel = UILabel() messageLabel.textColor = Colors.text messageLabel.font = .systemFont(ofSize: Values.smallFontSize) let message = String(format: NSLocalizedString("modal_download_attachment_explanation", comment: ""), name) let attributedMessage = NSMutableAttributedString(string: message) attributedMessage.addAttributes( [.font: UIFont.boldSystemFont(ofSize: Values.smallFontSize) ], range: (message as NSString).range(of: name) ) messageLabel.attributedText = attributedMessage messageLabel.numberOfLines = 0 messageLabel.lineBreakMode = .byWordWrapping messageLabel.textAlignment = .center // Download button let downloadButton = UIButton() downloadButton.set(.height, to: Values.mediumButtonHeight) downloadButton.layer.cornerRadius = Modal.buttonCornerRadius downloadButton.titleLabel!.font = .systemFont(ofSize: Values.smallFontSize) downloadButton.setTitleColor(Colors.text, for: UIControl.State.normal) downloadButton.setTitle(NSLocalizedString("modal_download_button_title", comment: ""), for: UIControl.State.normal) downloadButton.addTarget(self, action: #selector(trust), for: UIControl.Event.touchUpInside) // Button stack view let buttonStackView = UIStackView(arrangedSubviews: [ cancelButton, downloadButton ]) buttonStackView.axis = .horizontal buttonStackView.spacing = Values.mediumSpacing buttonStackView.distribution = .fillEqually // Content stack view let contentStackView = UIStackView(arrangedSubviews: [ titleLabel, messageLabel ]) contentStackView.axis = .vertical contentStackView.spacing = Values.largeSpacing // Main stack view let spacing = Values.largeSpacing - Values.smallFontSize / 2 let mainStackView = UIStackView(arrangedSubviews: [ contentStackView, buttonStackView ]) mainStackView.axis = .vertical mainStackView.spacing = spacing contentView.addSubview(mainStackView) mainStackView.pin(.leading, to: .leading, of: contentView, withInset: Values.largeSpacing) mainStackView.pin(.top, to: .top, of: contentView, withInset: Values.largeSpacing) contentView.pin(.trailing, to: .trailing, of: mainStackView, withInset: Values.largeSpacing) contentView.pin(.bottom, to: .bottom, of: mainStackView, withInset: spacing) } // MARK: - Interaction @objc private func trust() { guard let profileId: String = profile?.id else { return } Storage.shared.writeAsync { db in try Contact .filter(id: profileId) .updateAll(db, Contact.Columns.isTrusted.set(to: true)) // Start downloading any pending attachments for this contact (UI will automatically be // updated due to the database observation) try Attachment .stateInfo(authorId: profileId, state: .pendingDownload) .fetchAll(db) .forEach { attachmentDownloadInfo in JobRunner.add( db, job: Job( variant: .attachmentDownload, threadId: profileId, interactionId: attachmentDownloadInfo.interactionId, details: AttachmentDownloadJob.Details( attachmentId: attachmentDownloadInfo.attachmentId ) ) ) } } presentingViewController?.dismiss(animated: true, completion: nil) } }