123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- import Foundation
- import UIKit
- class NCListCell: UICollectionViewCell, UIGestureRecognizerDelegate, NCImageCellProtocol {
-
- @IBOutlet weak var imageItem: UIImageView!
- @IBOutlet weak var imageItemLeftConstraint: NSLayoutConstraint!
-
- @IBOutlet weak var imageSelect: UIImageView!
- @IBOutlet weak var imageStatus: UIImageView!
- @IBOutlet weak var imageFavorite: UIImageView!
- @IBOutlet weak var imageLocal: UIImageView!
- @IBOutlet weak var labelTitle: UILabel!
- @IBOutlet weak var labelInfo: UILabel!
- @IBOutlet weak var imageShared: UIImageView!
- @IBOutlet weak var buttonShared: UIButton!
- @IBOutlet weak var imageMore: UIImageView!
- @IBOutlet weak var buttonMore: UIButton!
-
- @IBOutlet weak var progressView: UIProgressView!
-
- @IBOutlet weak var separator: UIView!
-
- var filePreviewImageView : UIImageView {
- get{
- return imageItem
- }
- }
- var delegate: NCListCellDelegate?
- var objectId = ""
- var indexPath = IndexPath()
- var namedButtonMore = ""
- override func awakeFromNib() {
- super.awakeFromNib()
-
- imageItem.layer.cornerRadius = 6
- imageItem.layer.masksToBounds = true
-
- progressView.tintColor = NCBrandColor.shared.brandElement
- progressView.transform = CGAffineTransform(scaleX: 1.0, y: 0.5)
- progressView.trackTintColor = .clear
- let longPressedGesture = UILongPressGestureRecognizer(target: self, action: #selector(longPress(gestureRecognizer:)))
- longPressedGesture.minimumPressDuration = 0.5
- longPressedGesture.delegate = self
- longPressedGesture.delaysTouchesBegan = true
- self.addGestureRecognizer(longPressedGesture)
-
- let longPressedGestureMore = UILongPressGestureRecognizer(target: self, action: #selector(longPressInsideMore(gestureRecognizer:)))
- longPressedGestureMore.minimumPressDuration = 0.5
- longPressedGestureMore.delegate = self
- longPressedGestureMore.delaysTouchesBegan = true
- buttonMore.addGestureRecognizer(longPressedGestureMore)
- }
-
- override func prepareForReuse() {
- super.prepareForReuse()
- imageItem.backgroundColor = nil
- }
-
- @IBAction func touchUpInsideShare(_ sender: Any) {
- delegate?.tapShareListItem(with: objectId, sender: sender)
- }
-
- @IBAction func touchUpInsideMore(_ sender: Any) {
- delegate?.tapMoreListItem(with: objectId, namedButtonMore: namedButtonMore, sender: sender)
- }
-
- @objc func longPressInsideMore(gestureRecognizer: UILongPressGestureRecognizer) {
- delegate?.longPressMoreListItem(with: objectId, namedButtonMore: namedButtonMore, gestureRecognizer: gestureRecognizer)
- }
-
- @objc func longPress(gestureRecognizer: UILongPressGestureRecognizer) {
- delegate?.longPressListItem(with: objectId, gestureRecognizer: gestureRecognizer)
- }
-
- func setButtonMore(named: String, image: UIImage) {
- namedButtonMore = named
- imageMore.image = image
- }
-
- func hideButtonMore(_ status: Bool) {
- imageMore.isHidden = status
- buttonMore.isHidden = status
- }
-
- func hideButtonShare(_ status: Bool) {
- imageShared.isHidden = status
- buttonShared.isHidden = status
- }
-
- func selectMode(_ status: Bool) {
- if status {
- imageItemLeftConstraint.constant = 45
- imageSelect.isHidden = false
- } else {
- imageItemLeftConstraint.constant = 10
- imageSelect.isHidden = true
- backgroundView = nil
- }
- }
-
- func selected(_ status: Bool) {
- if status {
- imageSelect.image = NCCollectionCommon.images.cellCheckedYes
- backgroundView = NCUtility.shared.cellBlurEffect(with: self.bounds)
- separator.isHidden = true
- } else {
- imageSelect.image = NCCollectionCommon.images.cellCheckedNo
- backgroundView = nil
- separator.isHidden = false
- }
- }
- }
- protocol NCListCellDelegate {
- func tapShareListItem(with objectId: String, sender: Any)
- func tapMoreListItem(with objectId: String, namedButtonMore: String, sender: Any)
- func longPressMoreListItem(with objectId: String, namedButtonMore: String, gestureRecognizer: UILongPressGestureRecognizer)
- func longPressListItem(with objectId: String, gestureRecognizer: UILongPressGestureRecognizer)
- }
|