// // NCSectionFirstHeader.swift // Nextcloud // // Created by Marino Faggiana on 09/10/2018. // Copyright © 2018 Marino Faggiana. All rights reserved. // // Author Marino Faggiana // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // import UIKit import MarkdownKit protocol NCSectionFirstHeaderDelegate: AnyObject { func tapRichWorkspace(_ sender: Any) } class NCSectionFirstHeader: UICollectionReusableView, UIGestureRecognizerDelegate { @IBOutlet weak var buttonTransfer: UIButton! @IBOutlet weak var imageTransfer: UIImageView! @IBOutlet weak var labelTransfer: UILabel! @IBOutlet weak var progressTransfer: UIProgressView! @IBOutlet weak var transferSeparatorBottom: UIView! @IBOutlet weak var textViewRichWorkspace: UITextView! @IBOutlet weak var labelSection: UILabel! @IBOutlet weak var viewTransfer: UIView! @IBOutlet weak var viewRichWorkspace: UIView! @IBOutlet weak var viewSection: UIView! @IBOutlet weak var viewTransferHeightConstraint: NSLayoutConstraint! @IBOutlet weak var viewRichWorkspaceHeightConstraint: NSLayoutConstraint! @IBOutlet weak var viewSectionHeightConstraint: NSLayoutConstraint! @IBOutlet weak var transferSeparatorBottomHeightConstraint: NSLayoutConstraint! weak var delegate: NCSectionFirstHeaderDelegate? let utility = NCUtility() private var markdownParser = MarkdownParser() private var richWorkspaceText: String? private var textViewColor: UIColor? private let gradient: CAGradientLayer = CAGradientLayer() override func awakeFromNib() { super.awakeFromNib() backgroundColor = .clear // Gradient gradient.startPoint = CGPoint(x: 0, y: 0.8) gradient.endPoint = CGPoint(x: 0, y: 0.9) viewRichWorkspace.layer.addSublayer(gradient) let tap = UITapGestureRecognizer(target: self, action: #selector(touchUpInsideViewRichWorkspace(_:))) tap.delegate = self viewRichWorkspace?.addGestureRecognizer(tap) markdownParser = MarkdownParser(font: UIFont.systemFont(ofSize: 15), color: NCBrandColor.shared.textColor) markdownParser.header.font = UIFont.systemFont(ofSize: 25) if let richWorkspaceText = richWorkspaceText { textViewRichWorkspace.attributedText = markdownParser.parse(richWorkspaceText) } textViewColor = NCBrandColor.shared.textColor labelSection.text = "" viewSectionHeightConstraint.constant = 0 imageTransfer.tintColor = NCBrandColor.shared.iconImageColor imageTransfer.image = NCUtility().loadImage(named: "icloud.and.arrow.up") progressTransfer.progress = 0 progressTransfer.tintColor = NCBrandColor.shared.iconImageColor progressTransfer.trackTintColor = NCBrandColor.shared.customer.withAlphaComponent(0.2) transferSeparatorBottom.backgroundColor = .separator transferSeparatorBottomHeightConstraint.constant = 0.5 } override func layoutSublayers(of layer: CALayer) { super.layoutSublayers(of: layer) gradient.frame = viewRichWorkspace.bounds setInterfaceColor() } override func traitCollectionDidChange(_ previousTraitCollection: UITraitCollection?) { super.traitCollectionDidChange(previousTraitCollection) setInterfaceColor() } // MARK: - RichWorkspace func setRichWorkspaceHeight(_ size: CGFloat) { viewRichWorkspaceHeightConstraint.constant = size if size == 0 { viewRichWorkspace.isHidden = true } else { viewRichWorkspace.isHidden = false } } func setInterfaceColor() { if traitCollection.userInterfaceStyle == .dark { gradient.colors = [UIColor(white: 0, alpha: 0).cgColor, UIColor.black.cgColor] } else { gradient.colors = [UIColor(white: 1, alpha: 0).cgColor, UIColor.white.cgColor] } } func setRichWorkspaceText(_ text: String?) { guard let text = text else { return } if text != self.richWorkspaceText { textViewRichWorkspace.attributedText = markdownParser.parse(text) self.richWorkspaceText = text } } // MARK: - Transfer func setViewTransfer(isHidden: Bool, progress: Float? = nil) { viewTransfer.isHidden = isHidden if isHidden { viewTransferHeightConstraint.constant = 0 progressTransfer.progress = 0 } else { viewTransferHeightConstraint.constant = NCGlobal.shared.heightHeaderTransfer if NCTransferProgress.shared.haveUploadInForeground() { labelTransfer.text = String(format: NSLocalizedString("_upload_foreground_msg_", comment: ""), NCBrandOptions.shared.brand) if let progress { progressTransfer.progress = progress } else if let progress = NCTransferProgress.shared.getLastTransferProgressInForeground() { progressTransfer.progress = progress } else { progressTransfer.progress = 0.0 } } else { labelTransfer.text = NSLocalizedString("_upload_background_msg_", comment: "") progressTransfer.progress = 0.0 } } } // MARK: - Section func setSectionHeight(_ size: CGFloat) { viewSectionHeightConstraint.constant = size if size == 0 { viewSection.isHidden = true } else { viewSection.isHidden = false } } // MARK: - Action @objc func touchUpInsideViewRichWorkspace(_ sender: Any) { delegate?.tapRichWorkspace(sender) } } // https://stackoverflow.com/questions/16278463/darken-an-uiimage public extension UIImage { private enum BlendMode { case multiply // This results in colors that are at least as dark as either of the two contributing sample colors case screen // This results in colors that are at least as light as either of the two contributing sample colors } // A level of zero yeilds the original image, a level of 1 results in black func darken(level: CGFloat = 0.5) -> UIImage? { return blend(mode: .multiply, level: level) } // A level of zero yeilds the original image, a level of 1 results in white func lighten(level: CGFloat = 0.5) -> UIImage? { return blend(mode: .screen, level: level) } private func blend(mode: BlendMode, level: CGFloat) -> UIImage? { let context = CIContext(options: nil) var level = level if level < 0 { level = 0 } else if level > 1 { level = 1 } let filterName: String switch mode { case .multiply: // As the level increases we get less white level = abs(level - 1.0) filterName = "CIMultiplyBlendMode" case .screen: // As the level increases we get more white filterName = "CIScreenBlendMode" } let blender = CIFilter(name: filterName)! let backgroundColor = CIColor(color: UIColor(white: level, alpha: 1)) guard let inputImage = CIImage(image: self) else { return nil } blender.setValue(inputImage, forKey: kCIInputImageKey) guard let backgroundImageGenerator = CIFilter(name: "CIConstantColorGenerator") else { return nil } backgroundImageGenerator.setValue(backgroundColor, forKey: kCIInputColorKey) guard let backgroundImage = backgroundImageGenerator.outputImage?.cropped(to: CGRect(origin: CGPoint.zero, size: self.size)) else { return nil } blender.setValue(backgroundImage, forKey: kCIInputBackgroundImageKey) guard let blendedImage = blender.outputImage else { return nil } guard let cgImage = context.createCGImage(blendedImage, from: blendedImage.extent) else { return nil } return UIImage(cgImage: cgImage) } }