123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884 |
- //
- // NCDetailViewController.swift
- // Nextcloud
- //
- // Created by Marino Faggiana on 07/02/2020.
- // Copyright © 2020 Marino Faggiana. All rights reserved.
- //
- // Author Marino Faggiana <marino.faggiana@nextcloud.com>
- //
- // 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 <http://www.gnu.org/licenses/>.
- //
- import Foundation
- import WebKit
- import NCCommunication
- class NCDetailViewController: UIViewController {
-
- @IBOutlet weak var backgroundView: UIImageView!
- private let appDelegate = UIApplication.shared.delegate as! AppDelegate
-
- @objc var isNavigationBarHidden = false
- @objc var metadata: tableMetadata?
- @objc var selector: String?
- @objc var favoriteFilterImage: Bool = false
- @objc var mediaFilterImage: Bool = false
- @objc var offlineFilterImage: Bool = false
-
- @objc var viewerImageViewController: NCViewerImageViewController?
- @objc var metadatas = [tableMetadata]()
-
- private let progressHeight: CGFloat = 1.5
- private var maxProgress: Float = 0
- private var videoLayer: AVPlayerLayer?
- private var viewerImageViewControllerLongPressInProgress = false
-
- private var viewerQuickLook: NCViewerQuickLook?
- //MARK: -
- required init?(coder: NSCoder) {
- super.init(coder: coder)
-
- appDelegate.activeDetail = self
- }
-
- override func viewDidLoad() {
- super.viewDidLoad()
- NotificationCenter.default.addObserver(self, selector: #selector(changeTheming), name: NSNotification.Name(rawValue: k_notificationCenter_changeTheming), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(changeDisplayMode), name: NSNotification.Name(rawValue: k_notificationCenter_splitViewChangeDisplayMode), object: nil)
-
- NotificationCenter.default.addObserver(self, selector: #selector(downloadedFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_downloadedFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(uploadedFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_uploadedFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(deleteFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_deleteFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(renameFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_renameFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(moveFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_moveFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(triggerProgressTask(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_progressTask), object:nil)
-
- NotificationCenter.default.addObserver(self, selector: #selector(synchronizationMedia(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_synchronizationMedia), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(downloadImage(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_menuDownloadImage), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(saveLivePhoto(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_menuSaveLivePhoto), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(viewUnload), name: NSNotification.Name(rawValue: k_notificationCenter_menuDetailClose), object: nil)
-
- changeTheming()
- if metadata != nil {
- viewFile(metadata: metadata!, selector: selector)
- }
- }
-
- override func viewWillAppear(_ animated: Bool) {
- super.viewWillAppear(animated)
-
- setProgressBar()
- navigateControllerBarHidden(isNavigationBarHidden)
- }
-
- override func viewDidDisappear(_ animated: Bool) {
- super.viewDidDisappear(animated)
-
- if appDelegate.player != nil && appDelegate.player.rate != 0 {
- appDelegate.player.pause()
- }
-
- if appDelegate.isMediaObserver {
- appDelegate.isMediaObserver = false
- NCViewerVideo.sharedInstance.removeObserver()
- }
- }
-
- override func viewWillTransition(to size: CGSize, with coordinator: UIViewControllerTransitionCoordinator) {
- super.viewWillTransition(to: size, with: coordinator)
-
- coordinator.animate(alongsideTransition: nil) { _ in
- self.setProgressBar()
- }
- }
-
- //MARK: - ProgressBar
- @objc func setProgressBar() {
-
- appDelegate.progressViewDetail.removeFromSuperview()
- guard let navigationController = splitViewController?.viewControllers.last as? UINavigationController else { return }
-
- appDelegate.progressViewDetail.frame = CGRect(x: 0, y: navigationController.navigationBar.frame.height - (progressHeight*2), width: navigationController.navigationBar.frame.width, height: progressHeight)
- progress(0)
-
- if NCBrandColor.sharedInstance.brand.isLight() {
- appDelegate.progressViewDetail.tintColor = NCBrandColor.sharedInstance.brand.darker(by: 10)
- } else {
- appDelegate.progressViewDetail.tintColor = NCBrandColor.sharedInstance.brand.lighter(by: 20)
- }
-
- appDelegate.progressViewDetail.trackTintColor = .clear
- appDelegate.progressViewDetail.transform = CGAffineTransform(scaleX: 1, y: progressHeight)
-
- navigationController.navigationBar.addSubview(appDelegate.progressViewDetail)
- }
-
- @objc func progress(_ progress: Float) {
- DispatchQueue.main.async {
- if progress == 0 {
- self.maxProgress = 0
- self.appDelegate.progressViewDetail.progress = 0
- } else if progress > self.maxProgress {
- self.appDelegate.progressViewDetail.progress = progress
- self.maxProgress = progress
- }
- }
- }
-
- //MARK: - Utility
- @objc func navigateControllerBarHidden(_ state: Bool) {
-
- if state {
- view.backgroundColor = .black
- } else {
- view.backgroundColor = NCBrandColor.sharedInstance.backgroundView
- }
-
- navigationController?.setNavigationBarHidden(state, animated: false)
- isNavigationBarHidden = state
- }
-
- //MARK: - NotificationCenter
- @objc func changeTheming() {
-
- if backgroundView.image != nil {
- backgroundView.image = CCGraphics.changeThemingColorImage(UIImage.init(named: "logo"), multiplier: 2, color: NCBrandColor.sharedInstance.brand.withAlphaComponent(0.4))
- }
-
- if navigationController?.isNavigationBarHidden == false {
- view.backgroundColor = NCBrandColor.sharedInstance.backgroundView
- }
- }
-
- @objc func changeDisplayMode() {
- if self.view?.window == nil { return }
-
- NCViewerImageCommon.shared.imageChangeSizeView(viewerImageViewController: viewerImageViewController, size: self.backgroundView.frame.size, metadata: metadata)
-
- DispatchQueue.main.asyncAfter(deadline: .now() + .milliseconds(100)) {
- self.setProgressBar()
- }
- }
-
- @objc func triggerProgressTask(_ notification: NSNotification) {
- if self.view?.window == nil { return }
- guard let metadata = self.metadata else { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let account = userInfo["account"] as? String, let serverUrl = userInfo["serverUrl"] as? String, let progress = userInfo["progress"] as? Float {
- if account == metadata.account && serverUrl == metadata.serverUrl {
- self.progress(progress)
- }
- }
- }
- }
-
- @objc func synchronizationMedia(_ notification: NSNotification) {
- if self.view?.window == nil { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let type = userInfo["type"] as? String {
-
- if (self.metadata?.typeFile == k_metadataTypeFile_image || self.metadata?.typeFile == k_metadataTypeFile_video || self.metadata?.typeFile == k_metadataTypeFile_audio) && self.mediaFilterImage {
-
- if let metadatas = appDelegate.activeMedia.sectionDatasource.metadatas as? [tableMetadata] {
- self.metadatas = metadatas
- }
-
- if type == "delete" {
- if metadatas.count > 0 {
- var index = viewerImageViewController!.index - 1
- if index < 0 { index = 0}
- self.metadata = metadatas[index]
- viewImage()
- } else {
- viewUnload()
- }
- }
-
- if type == "rename" || type == "move" {
- viewerImageViewController?.reloadContentViews()
- }
- }
- }
- }
- }
-
- @objc func moveFile(_ notification: NSNotification) {
- if self.view?.window == nil { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let metadataNew = userInfo["metadataNew"] as? tableMetadata, let errorCode = userInfo["errorCode"] as? Int, let errorDescription = userInfo["errorDescription"] as? String {
- if metadata.account != self.metadata?.account { return }
-
- if errorCode == 0 {
-
- // IMAGE
- if (metadata.typeFile == k_metadataTypeFile_image || metadata.typeFile == k_metadataTypeFile_video || metadata.typeFile == k_metadataTypeFile_audio) && !mediaFilterImage {
-
- deleteFile(notification)
- }
-
- // OTHER
- if (metadata.typeFile == k_metadataTypeFile_document || metadata.typeFile == k_metadataTypeFile_unknown) && metadataNew.ocId == self.metadata?.ocId {
-
- self.metadata = metadataNew
-
- // update subview
- for view in backgroundView.subviews {
- if view is NCViewerNextcloudText {
- (view as! NCViewerNextcloudText).metadata = self.metadata
- }
- else if view is NCViewerRichdocument {
- (view as! NCViewerRichdocument).metadata = self.metadata
- }
- }
- }
-
- } else {
- NCContentPresenter.shared.messageNotification("_error_", description: errorDescription, delay: TimeInterval(k_dismissAfterSecond), type: NCContentPresenter.messageType.error, errorCode: errorCode)
- }
- }
- }
- }
-
- @objc func deleteFile(_ notification: NSNotification) {
- if self.view?.window == nil { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let errorCode = userInfo["errorCode"] as? Int, let errorDescription = userInfo["errorDescription"] as? String{
- if metadata.account != self.metadata?.account || metadata.serverUrl != self.metadata?.serverUrl { return }
-
- if errorCode == 0 {
-
- // IMAGE
- if (metadata.typeFile == k_metadataTypeFile_image || metadata.typeFile == k_metadataTypeFile_video || metadata.typeFile == k_metadataTypeFile_audio) && !mediaFilterImage {
-
- if let metadatas = NCViewerImageCommon.shared.getMetadatasDatasource(metadata: self.metadata, metadatas: self.metadatas, favoriteDatasorce: favoriteFilterImage, mediaDatasorce: mediaFilterImage, offLineDatasource: offlineFilterImage) {
- var index = viewerImageViewController!.index - 1
- if index < 0 { index = 0}
- self.metadata = metadatas[index]
- viewImage()
- } else {
- viewUnload()
- }
- }
-
- // OTHER
- if (metadata.typeFile == k_metadataTypeFile_document || metadata.typeFile == k_metadataTypeFile_unknown) && metadata.ocId == self.metadata?.ocId {
- viewUnload()
- }
- } else {
- NCContentPresenter.shared.messageNotification("_error_", description: errorDescription, delay: TimeInterval(k_dismissAfterSecond), type: NCContentPresenter.messageType.error, errorCode: errorCode)
- }
- }
- }
- }
-
- @objc func renameFile(_ notification: NSNotification) {
- if self.view?.window == nil { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let errorCode = userInfo["errorCode"] as? Int, let errorDescription = userInfo["errorDescription"] as? String {
- if metadata.account != self.metadata?.account || metadata.serverUrl != self.metadata?.serverUrl { return }
-
- if errorCode == 0 {
- if let metadata = NCManageDatabase.sharedInstance.getMetadata(predicate: NSPredicate(format: "ocId == %@", metadata.ocId)) {
- self.metadata = metadata
-
- // IMAGE
- if (metadata.typeFile == k_metadataTypeFile_image || metadata.typeFile == k_metadataTypeFile_video || metadata.typeFile == k_metadataTypeFile_audio) && !mediaFilterImage {
-
- viewImage()
- }
-
- // OTHER
- if (metadata.typeFile == k_metadataTypeFile_document || metadata.typeFile == k_metadataTypeFile_unknown) && metadata.ocId == self.metadata?.ocId {
- self.navigationController?.navigationBar.topItem?.title = metadata.fileNameView
- }
- }
- } else {
- NCContentPresenter.shared.messageNotification("_error_", description: errorDescription, delay: TimeInterval(k_dismissAfterSecond), type: NCContentPresenter.messageType.error, errorCode: errorCode)
- }
- }
- }
- }
-
- @objc func downloadedFile(_ notification: NSNotification) {
- if self.view?.window == nil { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let errorCode = userInfo["errorCode"] as? Int {
- if metadata.account != self.metadata?.account || metadata.serverUrl != self.metadata?.serverUrl { return }
-
- // IMAGE
- if metadata.typeFile == k_metadataTypeFile_image || metadata.typeFile == k_metadataTypeFile_video || metadata.typeFile == k_metadataTypeFile_audio && errorCode != 0 {
- viewerImageViewController?.reloadContentViews()
- }
-
- progress(0)
- }
- }
- }
-
- @objc func uploadedFile(_ notification: NSNotification) {
- if self.view?.window == nil { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let _ = userInfo["errorCode"] as? Int {
- if metadata.serverUrl != self.metadata?.serverUrl { return }
- progress(0)
- }
- }
- }
-
- @objc func downloadImage(_ notification: NSNotification) {
- if self.view?.window == nil { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata {
- metadata.session = k_download_session
- metadata.sessionError = ""
- metadata.sessionSelector = ""
- metadata.status = Int(k_metadataStatusWaitDownload)
-
- self.metadata = NCManageDatabase.sharedInstance.addMetadata(metadata)
-
- if let index = metadatas.firstIndex(where: { $0.ocId == metadata.ocId }) {
- metadatas[index] = self.metadata!
- }
-
- appDelegate.startLoadAutoDownloadUpload()
- }
- }
- }
-
- @objc func saveLivePhoto(_ notification: NSNotification) {
- if self.view?.window == nil { return }
-
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let metadataMov = userInfo["metadataMov"] as? tableMetadata {
- let fileNameImage = URL(fileURLWithPath: CCUtility.getDirectoryProviderStorageOcId(metadata.ocId, fileNameView: metadata.fileNameView)!)
- let fileNameMov = URL(fileURLWithPath: CCUtility.getDirectoryProviderStorageOcId(metadataMov.ocId, fileNameView: metadataMov.fileNameView)!)
-
- NCLivePhoto.generate(from: fileNameImage, videoURL: fileNameMov, progress: { progress in
- self.progress(Float(progress))
- }, completion: { livePhoto, resources in
- self.progress(0)
- if resources != nil {
- NCLivePhoto.saveToLibrary(resources!) { (result) in
- if !result {
- NCContentPresenter.shared.messageNotification("_error_", description: "_livephoto_save_error_", delay: TimeInterval(k_dismissAfterSecond), type: NCContentPresenter.messageType.error, errorCode: Int(k_CCErrorInternalError))
- }
- }
- } else {
- NCContentPresenter.shared.messageNotification("_error_", description: "_livephoto_save_error_", delay: TimeInterval(k_dismissAfterSecond), type: NCContentPresenter.messageType.error, errorCode: Int(k_CCErrorInternalError))
- }
- })
- }
- }
- }
-
- @objc func viewUnload() {
- self.unload(checkWindow: true)
- }
-
- private func unload(checkWindow: Bool) {
- if checkWindow && self.view?.window == nil { return }
- metadata = nil
- selector = nil
-
- if let splitViewController = self.splitViewController as? NCSplitViewController {
- if splitViewController.isCollapsed {
- if let navigationController = splitViewController.viewControllers.last as? UINavigationController {
- navigationController.popToRootViewController(animated: true)
- }
- } else {
-
- closeAllSubView()
- self.navigationController?.navigationBar.topItem?.title = ""
- }
- }
-
- self.splitViewController?.preferredDisplayMode = .allVisible
- self.navigationController?.isNavigationBarHidden = false
- view.backgroundColor = NCBrandColor.sharedInstance.backgroundView
-
- backgroundView.image = CCGraphics.changeThemingColorImage(UIImage.init(named: "logo"), multiplier: 2, color: NCBrandColor.sharedInstance.brand.withAlphaComponent(0.4))
- }
-
- private func closeAllSubView() {
-
- if backgroundView != nil {
- for view in backgroundView.subviews {
- view.removeFromSuperview()
- }
- }
- viewerImageViewController?.willMove(toParent: nil)
- viewerImageViewController?.view.removeFromSuperview()
- viewerImageViewController?.removeFromParent()
- }
-
- //MARK: - View File
-
- @objc func viewFile(metadata: tableMetadata, selector: String?) {
-
- self.metadata = metadata
- self.selector = selector
- self.backgroundView.image = nil
-
- closeAllSubView()
- if appDelegate.isMediaObserver {
- appDelegate.isMediaObserver = false
- NCViewerVideo.sharedInstance.removeObserver()
- }
-
- // IMAGE VIDEO AUDIO
- if metadata.typeFile == k_metadataTypeFile_image || metadata.typeFile == k_metadataTypeFile_audio || metadata.typeFile == k_metadataTypeFile_video {
-
- viewImage()
-
- return
- }
-
- // DOCUMENT
- if metadata.typeFile == k_metadataTypeFile_document {
-
- // PDF
- if metadata.contentType == "application/pdf" {
-
- let frame = CGRect(x: 0, y: 0, width: self.backgroundView.frame.width, height: self.backgroundView.frame.height)
- let viewerPDF = NCViewerPDF.init(frame: frame)
-
- let filePath = CCUtility.getDirectoryProviderStorageOcId(metadata.ocId, fileNameView: metadata.fileNameView)!
- if CCUtility.fileProviderStorageExists(metadata.ocId, fileNameView: metadata.fileNameView) == false {
-
- return
- }
-
- viewerPDF.setupPdfView(filePath: URL(fileURLWithPath: filePath), view: backgroundView)
- return
- }
-
- // DirectEditinf: Nextcloud Text - OnlyOffice
- if NCUtility.sharedInstance.isDirectEditing(metadata) != nil && appDelegate.reachability.isReachable() {
-
- let editor = NCUtility.sharedInstance.isDirectEditing(metadata)!
- if editor == k_editor_text || editor == k_editor_onlyoffice {
-
- NCUtility.sharedInstance.startActivityIndicator(view: backgroundView, bottom: 0)
- if metadata.url == "" {
-
- var customUserAgent: String?
- let fileNamePath = CCUtility.returnFileNamePath(fromFileName: metadata.fileName, serverUrl: metadata.serverUrl, activeUrl: appDelegate.activeUrl)!
-
- if editor == k_editor_onlyoffice {
- customUserAgent = NCUtility.sharedInstance.getCustomUserAgentOnlyOffice()
- self.navigationController?.navigationBar.topItem?.title = ""
- }
-
- NCCommunication.sharedInstance.NCTextOpenFile(serverUrl: appDelegate.activeUrl, fileNamePath: fileNamePath, editor: editor, customUserAgent: customUserAgent, addCustomHeaders: nil, account: appDelegate.activeAccount) { (account, url, errorCode, errorMessage) in
-
- if errorCode == 0 && account == self.appDelegate.activeAccount && url != nil {
-
- let frame = CGRect(x: 0, y: 0, width: self.backgroundView.frame.width, height: self.backgroundView.frame.height)
- let nextcloudText = NCViewerNextcloudText.init(frame: frame, configuration: WKWebViewConfiguration())
- nextcloudText.viewerAt(url!, metadata: metadata, editor: editor, view: self.backgroundView, viewController: self)
-
- } else if errorCode != 0 {
-
- NCContentPresenter.shared.messageNotification("_error_", description: errorMessage, delay: TimeInterval(k_dismissAfterSecond), type: NCContentPresenter.messageType.error, errorCode: errorCode)
- self.navigationController?.popViewController(animated: true)
-
- } else {
-
- self.navigationController?.popViewController(animated: true)
- }
- }
-
- } else {
-
- if editor == k_editor_onlyoffice {
- self.navigationController?.navigationBar.topItem?.title = ""
- }
-
- let frame = CGRect(x: 0, y: 0, width: self.backgroundView.frame.width, height: self.backgroundView.frame.height)
- let nextcloudText = NCViewerNextcloudText.init(frame: frame, configuration: WKWebViewConfiguration())
- nextcloudText.viewerAt(metadata.url, metadata: metadata, editor: editor, view: backgroundView, viewController: self)
- }
- }
-
- return
- }
-
- // RichDocument: Collabora
- if NCUtility.sharedInstance.isRichDocument(metadata) && appDelegate.reachability.isReachable() {
-
- NCUtility.sharedInstance.startActivityIndicator(view: backgroundView, bottom: 0)
-
- if metadata.url == "" {
-
- OCNetworking.sharedManager()?.createLinkRichdocuments(withAccount: appDelegate.activeAccount, fileId: metadata.fileId, completion: { (account, url, errorMessage, errorCode) in
-
- if errorCode == 0 && account == self.appDelegate.activeAccount && url != nil {
-
- let frame = CGRect(x: 0, y: 0, width: self.backgroundView.frame.width, height: self.backgroundView.frame.height)
- let richDocument = NCViewerRichdocument.init(frame: frame, configuration: WKWebViewConfiguration())
- richDocument.viewRichDocumentAt(url!, metadata: metadata, view: self.backgroundView, viewController: self)
-
- } else if errorCode != 0 {
-
- NCContentPresenter.shared.messageNotification("_error_", description: errorMessage, delay: TimeInterval(k_dismissAfterSecond), type: NCContentPresenter.messageType.error, errorCode: errorCode)
- self.navigationController?.popViewController(animated: true)
-
- } else {
-
- self.navigationController?.popViewController(animated: true)
- }
- })
-
- } else {
-
- let richDocument = NCViewerRichdocument.init(frame: backgroundView.frame, configuration: WKWebViewConfiguration())
- richDocument.viewRichDocumentAt(metadata.url, metadata: metadata, view: backgroundView, viewController: self)
- }
-
- return
- }
- }
-
- // OTHER
-
- let fileNamePath = NSTemporaryDirectory() + metadata.fileNameView
- CCUtility.copyFile(atPath: CCUtility.getDirectoryProviderStorageOcId(metadata.ocId, fileNameView: metadata.fileNameView), toPath: fileNamePath)
- viewerQuickLook = NCViewerQuickLook.init()
- viewerQuickLook?.quickLook(url: URL(fileURLWithPath: fileNamePath), viewController: self)
-
- DispatchQueue.main.asyncAfter(deadline: .now() + 1) {
- self.unload(checkWindow: false)
- }
- }
- }
- //MARK: - viewerImageViewController - Delegate/DataSource
- extension NCDetailViewController: NCViewerImageViewControllerDelegate, NCViewerImageViewControllerDataSource {
-
- func viewImage() {
-
- closeAllSubView()
-
- if let metadatas = NCViewerImageCommon.shared.getMetadatasDatasource(metadata: self.metadata, metadatas: self.metadatas, favoriteDatasorce: favoriteFilterImage, mediaDatasorce: mediaFilterImage, offLineDatasource: offlineFilterImage) {
-
- var index = 0
- if let indexFound = metadatas.firstIndex(where: { $0.ocId == self.metadata?.ocId }) { index = indexFound }
- // Video -> is a Live Photo ?
- if metadata?.typeFile == k_metadataTypeFile_video && metadata != nil {
- let filename = (metadata!.fileNameView as NSString).deletingPathExtension.lowercased()
- if let indexFound = metadatas.firstIndex(where: { (($0.fileNameView as NSString).deletingPathExtension.lowercased() as String) == filename && $0.typeFile == k_metadataTypeFile_image }) { index = indexFound }
- }
- self.metadatas = metadatas
-
- viewerImageViewController = NCViewerImageViewController(index: index, dataSource: self, delegate: self)
- if viewerImageViewController != nil {
-
- self.backgroundView.image = nil
- viewerImageViewController!.view.isHidden = true
-
- viewerImageViewController!.enableInteractiveDismissal = true
-
- addChild(viewerImageViewController!)
- view.addSubview(viewerImageViewController!.view)
-
- viewerImageViewController!.view.frame = CGRect(x: 0, y: 0, width: view.frame.width, height: view.frame.height)
- viewerImageViewController!.view.autoresizingMask = [.flexibleWidth, .flexibleHeight]
-
- viewerImageViewController!.didMove(toParent: self)
-
- DispatchQueue.main.asyncAfter(deadline: .now() + .milliseconds(100)) {
- self.viewerImageViewController!.changeInViewSize(to: self.backgroundView.frame.size)
- self.viewerImageViewController!.view.isHidden = false
- }
- }
- }
- }
-
- func numberOfItems(in viewerImageViewController: NCViewerImageViewController) -> Int {
- return metadatas.count
- }
- func viewerImageViewController(_ viewerImageViewController: NCViewerImageViewController, imageAt index: Int, completion: @escaping (_ index: Int, _ image: UIImage?, _ metadata: tableMetadata, _ zoomScale: ZoomScale?, _ error: Error?) -> Void) {
-
- if index >= metadatas.count { return }
- let metadata = metadatas[index]
- let isPreview = CCUtility.fileProviderStorageIconExists(metadata.ocId, fileNameView: metadata.fileNameView)
- let isImage = CCUtility.fileProviderStorageSize(metadata.ocId, fileNameView: metadata.fileNameView) > 0
- let ext = CCUtility.getExtension(metadata.fileNameView)
- let isFolderEncrypted = CCUtility.isFolderEncrypted(metadata.serverUrl, e2eEncrypted: metadata.e2eEncrypted, account: metadata.account)
-
- // Refresh self metadata && title
- if viewerImageViewController.index < metadatas.count {
- self.metadata = metadatas[viewerImageViewController.index]
- self.navigationController?.navigationBar.topItem?.title = self.metadata!.fileNameView
- }
-
- // Status Current
- if index == viewerImageViewController.currentItemIndex {
- statusViewImage(metadata: metadata, viewerImageViewController: viewerImageViewController)
- }
-
- // Preview for Video
- if metadata.typeFile == k_metadataTypeFile_video && !isPreview && isImage {
-
- CCGraphics.createNewImage(from: metadata.fileNameView, ocId: metadata.ocId, filterGrayScale: false, typeFile: metadata.typeFile, writeImage: true)
- }
-
- // Original only for actual
- if metadata.typeFile == k_metadataTypeFile_image && isImage && index == viewerImageViewController.index {
-
- if let image = NCViewerImageCommon.shared.getImage(metadata: metadata) {
- completion(index, image, metadata, ZoomScale.default, nil)
- } else {
- completion(index, NCViewerImageCommon.shared.getImageOffOutline(frame: self.view.frame, type: metadata.typeFile), metadata, ZoomScale.default, nil)
- }
-
- // Automatic download for: Encripted
- } else if metadata.session == "" && CCUtility.fileProviderStorageSize(metadata.ocId, fileNameView: metadata.fileNameView) == 0 && isFolderEncrypted{
-
- if NCManageDatabase.sharedInstance.getMetadata(predicate: NSPredicate(format: "ocId == %@ AND session != ''", metadata.ocId)) == nil {
-
- let metadata = NCManageDatabase.sharedInstance.initNewMetadata(metadata)
-
- metadata.session = k_download_session
- metadata.sessionError = ""
- metadata.sessionSelector = ""
- metadata.status = Int(k_metadataStatusWaitDownload)
-
- NCManageDatabase.sharedInstance.addMetadata(metadata)
- appDelegate.startLoadAutoDownloadUpload()
- }
-
- completion(index, NCViewerImageCommon.shared.getImageOffOutline(frame: self.view.frame, type: metadata.typeFile), metadata, ZoomScale.default, nil)
-
- // Automatic download for: HEIC - GIF - SVG
- } else if metadata.session == "" && CCUtility.fileProviderStorageSize(metadata.ocId, fileNameView: metadata.fileNameView) == 0 && ((metadata.contentType == "image/heic" && metadata.hasPreview == false) || ext == "GIF" || ext == "SVG") {
-
- let serverUrlFileName = metadata.serverUrl + "/" + metadata.fileName
- let fileNameLocalPath = CCUtility.getDirectoryProviderStorageOcId(metadata.ocId, fileNameView: metadata.fileName)!
-
- metadata.session = k_download_session_foreground
-
- _ = NCCommunication.sharedInstance.download(serverUrlFileName: serverUrlFileName, fileNameLocalPath: fileNameLocalPath, customUserAgent: nil, addCustomHeaders: nil, account: metadata.account, progressHandler: { (progress) in
-
- self.progress(Float(progress.fractionCompleted))
-
- }) { (account, etag, date, length, errorCode, errorDescription) in
-
- if errorCode == 0 && account == metadata.account {
-
- _ = NCManageDatabase.sharedInstance.addLocalFile(metadata: metadata)
-
- if let image = NCViewerImageCommon.shared.getImage(metadata: metadata) {
- completion(index, image, metadata, ZoomScale.default, nil)
- } else {
- completion(index, NCViewerImageCommon.shared.getImageOffOutline(frame: self.view.frame, type: metadata.typeFile), metadata, ZoomScale.default, nil)
- }
- } else if errorCode != 0 {
- completion(index, NCViewerImageCommon.shared.getImageOffOutline(frame: self.view.frame, type: metadata.typeFile), metadata, ZoomScale.default, nil)
- }
-
- metadata.session = ""
- self.progress(0)
- }
-
- // Preview
- } else if isPreview {
-
- if let image = NCViewerImageCommon.shared.getThumbnailImage(metadata: metadata) {
- completion(index, image, metadata, ZoomScale.default, nil)
- } else {
- completion(index, NCViewerImageCommon.shared.getImageOffOutline(frame: self.view.frame, type: metadata.typeFile), metadata, ZoomScale.default, nil)
- }
-
- } else if metadata.hasPreview {
-
- let fileNamePath = CCUtility.returnFileNamePath(fromFileName: metadata.fileName, serverUrl: metadata.serverUrl, activeUrl: appDelegate.activeUrl)!
- let fileNameLocalPath = CCUtility.getDirectoryProviderStorageIconOcId(metadata.ocId, fileNameView: metadata.fileNameView)!
-
- NCCommunication.sharedInstance.downloadPreview(serverUrl: appDelegate.activeUrl, fileNamePath: fileNamePath, fileNameLocalPath: fileNameLocalPath, width: Int(k_sizePreview), height: Int(k_sizePreview), customUserAgent: nil, addCustomHeaders: nil, account: metadata.account) { (account, data, errorCode, errorMessage) in
- if errorCode == 0 && data != nil {
- completion(index, UIImage.init(data: data!), metadata, ZoomScale.default, nil)
- } else {
- completion(index, NCViewerImageCommon.shared.getImageOffOutline(frame: self.view.frame, type: metadata.typeFile), metadata, ZoomScale.default, nil)
- }
- }
-
- } else {
- completion(index, NCViewerImageCommon.shared.getImageOffOutline(frame: self.view.frame, type: metadata.typeFile), metadata, ZoomScale.default, nil)
- }
- }
-
- func viewerImageViewController(_ viewerImageViewController: NCViewerImageViewController, willChangeFocusTo index: Int, view: NCViewerImageContentView, metadata: tableMetadata) {
-
- statusViewImage(metadata: metadata, viewerImageViewController: viewerImageViewController)
- }
-
- func viewerImageViewController(_ viewerImageViewController: NCViewerImageViewController, didChangeFocusTo index: Int, view: NCViewerImageContentView, metadata: tableMetadata) {
-
- if metadata.typeFile == k_metadataTypeFile_image && !view.isLoading {
- DispatchQueue.global().async {
- if let image = NCViewerImageCommon.shared.getImage(metadata: metadata) {
- DispatchQueue.main.async {
- view.image = image
- }
- }
- }
- }
- }
-
- func viewerImageViewControllerTap(_ viewerImageViewController: NCViewerImageViewController, metadata: tableMetadata) {
-
- guard let navigationController = self.navigationController else { return }
-
- if metadata.typeFile == k_metadataTypeFile_image {
-
- if navigationController.isNavigationBarHidden {
- navigateControllerBarHidden(false)
- viewerImageViewController.statusView.isHidden = false
- } else {
- navigateControllerBarHidden(true)
- viewerImageViewController.statusView.isHidden = true
- }
-
- NCViewerImageCommon.shared.imageChangeSizeView(viewerImageViewController: viewerImageViewController, size: self.backgroundView.frame.size, metadata: metadata)
-
- } else {
-
- if let viewerImageVideo = UIStoryboard(name: "NCViewerImageVideo", bundle: nil).instantiateInitialViewController() as? NCViewerImageVideo {
- viewerImageVideo.metadata = metadata
- present(viewerImageVideo, animated: false) { }
- }
- }
-
- statusViewImage(metadata: metadata, viewerImageViewController: viewerImageViewController)
- }
-
- func viewerImageViewControllerLongPressBegan(_ viewerImageViewController: NCViewerImageViewController, metadata: tableMetadata) {
-
- viewerImageViewControllerLongPressInProgress = true
-
- let fileName = (metadata.fileNameView as NSString).deletingPathExtension + ".mov"
- if let metadata = NCManageDatabase.sharedInstance.getMetadata(predicate: NSPredicate(format: "account == %@ AND serverUrl == %@ AND fileNameView LIKE[c] %@", metadata.account, metadata.serverUrl, fileName)) {
-
- if CCUtility.fileProviderStorageSize(metadata.ocId, fileNameView: metadata.fileNameView) > 0 {
-
- viewMOV(viewerImageViewController: viewerImageViewController, metadata: metadata)
-
- } else {
-
- let serverUrlFileName = metadata.serverUrl + "/" + metadata.fileNameView
- let fileNameLocalPath = CCUtility.getDirectoryProviderStorageOcId(metadata.ocId, fileNameView: metadata.fileNameView)!
-
- _ = NCCommunication.sharedInstance.download(serverUrlFileName: serverUrlFileName, fileNameLocalPath: fileNameLocalPath, customUserAgent: nil, addCustomHeaders: nil, account: metadata.account, progressHandler: { (progress) in
-
- self.progress(Float(progress.fractionCompleted))
-
- }) { (account, etag, date, length, errorCode, errorDescription) in
-
- self.progress(0)
-
- if errorCode == 0 && account == metadata.account {
-
- _ = NCManageDatabase.sharedInstance.addLocalFile(metadata: metadata)
- self.viewMOV(viewerImageViewController: viewerImageViewController, metadata: metadata)
- }
- }
- }
- }
- }
-
- func viewerImageViewControllerLongPressEnded(_ viewerImageViewController: NCViewerImageViewController, metadata: tableMetadata) {
-
- viewerImageViewControllerLongPressInProgress = false
-
- appDelegate.player?.pause()
- videoLayer?.removeFromSuperlayer()
- }
-
- func viewerImageViewControllerDismiss() {
- viewUnload()
- }
-
- func statusViewImage(metadata: tableMetadata, viewerImageViewController: NCViewerImageViewController) {
-
- var colorStatus: UIColor = UIColor.white.withAlphaComponent(0.8)
- if view.backgroundColor?.isLight() ?? true { colorStatus = UIColor.black.withAlphaComponent(0.8) }
-
- if NCUtility.sharedInstance.isLivePhoto(metadata: metadata) != nil {
- viewerImageViewController.statusView.image = CCGraphics.changeThemingColorImage(UIImage.init(named: "livePhoto"), width: 100, height: 100, color: colorStatus)
- } else if metadata.typeFile == k_metadataTypeFile_video || metadata.typeFile == k_metadataTypeFile_audio {
- viewerImageViewController.statusView.image = CCGraphics.changeThemingColorImage(UIImage.init(named: "play"), width: 100, height: 100, color: colorStatus)
- } else {
- viewerImageViewController.statusView.image = nil
- }
- }
-
- func viewMOV(viewerImageViewController: NCViewerImageViewController, metadata: tableMetadata) {
-
- if !viewerImageViewControllerLongPressInProgress { return }
-
- appDelegate.player = AVPlayer(url: URL(fileURLWithPath: CCUtility.getDirectoryProviderStorageOcId(metadata.ocId, fileNameView: metadata.fileNameView)!))
- videoLayer = AVPlayerLayer(player: appDelegate.player)
- if videoLayer != nil {
- videoLayer!.frame = viewerImageViewController.view.frame
- videoLayer!.videoGravity = AVLayerVideoGravity.resizeAspect
- viewerImageViewController.view.layer.addSublayer(videoLayer!)
- appDelegate.player?.play()
- }
- }
- }
- //MARK: -
- extension NCDetailViewController: NCSelectDelegate {
-
- func dismissSelect(serverUrl: String?, metadata: tableMetadata?, type: String, buttonType: String, overwrite: Bool) {
- if let metadata = self.metadata, let serverUrl = serverUrl {
- if buttonType == "done" {
- NCNetworking.sharedInstance.moveMetadata(metadata, serverUrlTo: serverUrl, overwrite: overwrite) { (errorCode, errorDescription) in }
- } else {
- NCNetworking.sharedInstance.copyMetadata(metadata, serverUrlTo: serverUrl, overwrite: overwrite) { (errorCode, errorDescription) in }
- }
- }
- }
- }
|