123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315 |
- import Foundation
- import NCCommunication
- class NCActivityCollectionViewCell: UICollectionViewCell {
- @IBOutlet weak var imageView: UIImageView!
- override func awakeFromNib() {
- super.awakeFromNib()
- }
- }
- class NCActivityTableViewCell: UITableViewCell, NCCellProtocol {
- private let appDelegate = UIApplication.shared.delegate as! AppDelegate
- @IBOutlet weak var collectionView: UICollectionView!
- @IBOutlet weak var icon: UIImageView!
- @IBOutlet weak var avatar: UIImageView!
- @IBOutlet weak var subject: UILabel!
- @IBOutlet weak var subjectTrailingConstraint: NSLayoutConstraint!
- @IBOutlet weak var collectionViewHeightConstraint: NSLayoutConstraint!
- private var user: String = ""
- var idActivity: Int = 0
- var account: String = ""
- var activityPreviews: [tableActivityPreview] = []
- var didSelectItemEnable: Bool = true
- var viewController: UIViewController?
- var fileAvatarImageView: UIImageView? {
- get {
- return avatar
- }
- }
- var fileObjectId: String? {
- get {
- return nil
- }
- set {}
- }
- var filePreviewImageView: UIImageView? {
- get {
- return nil
- }
- }
- var fileUser: String? {
- get {
- return user
- }
- set {
- user = newValue ?? ""
- }
- }
- var title: UILabel? {
- get { return nil }
- set {}
- }
- var info: UILabel? {
- get { return nil }
- set {}
- }
- var progress: UIProgressView? {
- get { return nil }
- set {}
- }
- override func awakeFromNib() {
- super.awakeFromNib()
- collectionView.delegate = self
- collectionView.dataSource = self
- let avatarRecognizer = UITapGestureRecognizer(target: self, action: #selector(tapAvatarImage))
- avatar.addGestureRecognizer(avatarRecognizer)
- }
- @objc func tapAvatarImage() {
- guard let fileUser = fileUser else { return }
- viewController?.showProfileMenu(userId: fileUser)
- }
- func writeInfoDateSize(date: NSDate, totalBytes: Int64) {}
- func setButtonMore(named: String, image: UIImage) {}
- }
- extension NCActivityTableViewCell: UICollectionViewDelegate {
- func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
-
- if !didSelectItemEnable {
- return
- }
- let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "collectionCell", for: indexPath) as? NCActivityCollectionViewCell
- let activityPreview = activityPreviews[indexPath.row]
- if activityPreview.view == "trashbin" {
- var responder: UIResponder? = collectionView
- while !(responder is UIViewController) {
- responder = responder?.next
- if responder == nil {
- break
- }
- }
- if (responder as? UIViewController)!.navigationController != nil {
- if let viewController = UIStoryboard(name: "NCTrash", bundle: nil).instantiateInitialViewController() as? NCTrash {
- if let result = NCManageDatabase.shared.getTrashItem(fileId: String(activityPreview.fileId), account: activityPreview.account) {
- viewController.blinkFileId = result.fileId
- viewController.trashPath = result.filePath
- (responder as? UIViewController)!.navigationController?.pushViewController(viewController, animated: true)
- } else {
- NCContentPresenter.shared.messageNotification("_error_", description: "_trash_file_not_found_", delay: NCGlobal.shared.dismissAfterSecond, type: NCContentPresenter.messageType.info, errorCode: NCGlobal.shared.errorInternalError)
- }
- }
- }
- return
- }
- if activityPreview.view == NCGlobal.shared.appName && activityPreview.mimeType != "dir" {
- guard let activitySubjectRich = NCManageDatabase.shared.getActivitySubjectRich(account: activityPreview.account, idActivity: activityPreview.idActivity, id: String(activityPreview.fileId)) else {
- return
- }
- if let metadata = NCManageDatabase.shared.getMetadata(predicate: NSPredicate(format: "fileId == %@", activitySubjectRich.id)) {
- if let filePath = CCUtility.getDirectoryProviderStorageOcId(metadata.ocId, fileNameView: metadata.fileNameView) {
- do {
- let attr = try FileManager.default.attributesOfItem(atPath: filePath)
- let fileSize = attr[FileAttributeKey.size] as! UInt64
- if fileSize > 0 {
- if let viewController = self.viewController {
- NCViewer.shared.view(viewController: viewController, metadata: metadata, metadatas: [metadata], imageIcon: cell?.imageView.image)
- }
- return
- }
- } catch {
- print("Error: \(error)")
- }
- }
- }
- var pathComponents = activityPreview.link.components(separatedBy: "?")
- pathComponents = pathComponents[1].components(separatedBy: "&")
- var serverUrlFileName = pathComponents[0].replacingOccurrences(of: "dir=", with: "").removingPercentEncoding!
- serverUrlFileName = appDelegate.urlBase + "/" + NCUtilityFileSystem.shared.getWebDAV(account: activityPreview.account) + serverUrlFileName + "/" + activitySubjectRich.name
- let fileNameLocalPath = CCUtility.getDirectoryProviderStorageOcId(activitySubjectRich.id, fileNameView: activitySubjectRich.name)!
- NCUtility.shared.startActivityIndicator(backgroundView: (appDelegate.window?.rootViewController?.view)!, blurEffect: true)
- NCCommunication.shared.download(serverUrlFileName: serverUrlFileName, fileNameLocalPath: fileNameLocalPath, requestHandler: { _ in
- }, taskHandler: { _ in
- }, progressHandler: { _ in
- }) { account, _, _, _, _, _, errorCode, _ in
- if account == self.appDelegate.account && errorCode == 0 {
- let serverUrl = (serverUrlFileName as NSString).deletingLastPathComponent
- let fileName = (serverUrlFileName as NSString).lastPathComponent
- let serverUrlFileName = serverUrl + "/" + fileName
- NCNetworking.shared.readFile(serverUrlFileName: serverUrlFileName) { account, metadata, errorCode, _ in
- NCUtility.shared.stopActivityIndicator()
- if account == self.appDelegate.account && errorCode == 0 {
-
- let atPath = CCUtility.getDirectoryProviderStorage()! + "/" + activitySubjectRich.id
- let toPath = CCUtility.getDirectoryProviderStorage()! + "/" + metadata!.ocId
- CCUtility.moveFile(atPath: atPath, toPath: toPath)
- NCManageDatabase.shared.addMetadata(metadata!)
- if let viewController = self.viewController {
- NCViewer.shared.view(viewController: viewController, metadata: metadata!, metadatas: [metadata!], imageIcon: cell?.imageView.image)
- }
- }
- }
- } else {
- NCUtility.shared.stopActivityIndicator()
- }
- }
- }
- }
- }
- extension NCActivityTableViewCell: UICollectionViewDataSource {
- func numberOfSections(in collectionView: UICollectionView) -> Int {
- return 1
- }
- func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
- return activityPreviews.count
- }
- func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
- let cell: NCActivityCollectionViewCell = collectionView.dequeueReusableCell(withReuseIdentifier: "collectionCell", for: indexPath) as! NCActivityCollectionViewCell
- cell.imageView.image = nil
- let activityPreview = activityPreviews[indexPath.row]
- let fileId = String(activityPreview.fileId)
-
- if activityPreview.view == "trashbin" {
- let source = activityPreview.source
- NCUtility.shared.convertSVGtoPNGWriteToUserData(svgUrlString: source, fileName: nil, width: 100, rewrite: false, account: appDelegate.account) { imageNamePath in
- if imageNamePath != nil {
- if let image = UIImage(contentsOfFile: imageNamePath!) {
- cell.imageView.image = image
- }
- } else {
- cell.imageView.image = UIImage(named: "file")
- }
- }
- } else {
- if activityPreview.isMimeTypeIcon {
- let source = activityPreview.source
- NCUtility.shared.convertSVGtoPNGWriteToUserData(svgUrlString: source, fileName: nil, width: 100, rewrite: false, account: appDelegate.account) { imageNamePath in
- if imageNamePath != nil {
- if let image = UIImage(contentsOfFile: imageNamePath!) {
- cell.imageView.image = image
- }
- } else {
- cell.imageView.image = UIImage(named: "file")
- }
- }
- } else {
- if let activitySubjectRich = NCManageDatabase.shared.getActivitySubjectRich(account: account, idActivity: idActivity, id: fileId) {
- let fileNamePath = CCUtility.getDirectoryUserData() + "/" + activitySubjectRich.name
- if FileManager.default.fileExists(atPath: fileNamePath) {
- if let image = UIImage(contentsOfFile: fileNamePath) {
- cell.imageView.image = image
- }
- } else {
- NCCommunication.shared.downloadPreview(fileNamePathOrFileId: activityPreview.source, fileNamePreviewLocalPath: fileNamePath, widthPreview: 0, heightPreview: 0, etag: nil, useInternalEndpoint: false) { _, imagePreview, _, _, _, errorCode, _ in
- if errorCode == 0 && imagePreview != nil {
- self.collectionView.reloadData()
- }
- }
- }
- }
- }
- }
- return cell
- }
- }
- extension NCActivityTableViewCell: UICollectionViewDelegateFlowLayout {
- func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
- return CGSize(width: 50, height: 50)
- }
- func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, minimumLineSpacingForSectionAt section: Int) -> CGFloat {
- return 20
- }
- func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, insetForSectionAt section: Int) -> UIEdgeInsets {
- return UIEdgeInsets(top: 0, left: 0, bottom: 10, right: 0)
- }
- }
|