123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614 |
- 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?
- private var metadatas = [tableMetadata]()
- private var progressView: UIProgressView?
- private let progressHeight: CGFloat = 1
-
-
- required init?(coder: NSCoder) {
- super.init(coder: coder)
-
- appDelegate.activeDetail = self
- }
-
- override func viewDidLoad() {
- super.viewDidLoad()
-
- NotificationCenter.default.addObserver(self, selector: #selector(self.changeTheming), name: NSNotification.Name(rawValue: k_notificationCenter_changeTheming), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(self.changeDisplayMode), name: NSNotification.Name(rawValue: k_notificationCenter_splitViewChangeDisplayMode), object: nil)
-
- NotificationCenter.default.addObserver(self, selector: #selector(self.downloadFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_downloadFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(self.deleteFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_deleteFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(self.uploadFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_uploadFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(self.renameFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_renameFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(self.moveFile(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_moveFile), object: nil)
- NotificationCenter.default.addObserver(self, selector: #selector(self.triggerProgressTask(_:)), name: NSNotification.Name(rawValue: k_notificationCenter_progressTask), object:nil)
-
- changeTheming()
- if metadata != nil {
- viewFile(metadata: metadata!, selector: selector)
- }
- }
-
- override func viewWillAppear(_ animated: Bool) {
- super.viewWillAppear(animated)
-
- setProgressBar()
- navigateControllerBarHidden(isNavigationBarHidden)
- }
-
- override func viewDidAppear(_ animated: Bool) {
- super.viewDidAppear(animated)
-
- }
-
- 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
- NCViewerMedia.sharedInstance.removeObserver()
- }
- }
-
- override func viewWillTransition(to size: CGSize, with coordinator: UIViewControllerTransitionCoordinator) {
- super.viewWillTransition(to: size, with: coordinator)
-
- coordinator.animate(alongsideTransition: nil) { _ in
- self.setProgressBar()
- }
- }
-
-
- @objc func setProgressBar() {
-
- if self.progressView != nil { progressView?.removeFromSuperview() }
- self.progressView = UIProgressView.init(progressViewStyle: .bar)
- guard let navigationController = splitViewController?.viewControllers.last as? UINavigationController else { return }
- guard let progressView = self.progressView else { return }
-
- progressView.frame = CGRect(x: 0, y: navigationController.navigationBar.frame.height-progressHeight, width: navigationController.navigationBar.frame.width, height: progressHeight)
- progressView.setProgress(0, animated: false)
-
- if NCBrandColor.sharedInstance.brand.isLight() {
- progressView.tintColor = NCBrandColor.sharedInstance.brand.darker(by: 10)
- } else {
- progressView.tintColor = NCBrandColor.sharedInstance.brand.lighter(by: 20)
- }
-
- progressView.trackTintColor = .clear
- progressView.transform = CGAffineTransform(scaleX: 1, y: progressHeight)
-
- navigationController.navigationBar.addSubview(progressView)
- }
-
- @objc func progress(_ progress: Float) {
- guard let progressView = self.progressView else { return }
- progressView.progress = progress
- }
-
-
- func subViewActive() -> UIView? {
- return backgroundView.subviews.first
- }
-
- @objc func viewUnload() {
-
- 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 {
- if backgroundView != nil {
- for view in backgroundView.subviews {
- view.removeFromSuperview()
- }
- }
- 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))
- }
-
- @objc func navigateControllerBarHidden(_ state: Bool) {
- if state {
- view.backgroundColor = .black
- } else {
- view.backgroundColor = NCBrandColor.sharedInstance.backgroundView
- }
-
- navigationController?.setNavigationBarHidden(state, animated: false)
- isNavigationBarHidden = state
- }
-
-
- @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() {
-
- NCViewerImageCommon.shared.imageChangeSizeView(viewerImageViewController: viewerImageViewController, size: self.backgroundView.frame.size, metadata: metadata)
- }
-
- @objc func triggerProgressTask(_ notification: NSNotification) {
- 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 downloadFile(_ notification: NSNotification) {
- 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 {
-
- if errorCode == 0 && metadata.typeFile == k_metadataTypeFile_image && viewerImageViewController != nil {
- viewerImageViewController?.reloadContentViews()
- }
-
- setProgressBar()
- }
- }
- }
- }
-
- @objc func moveFile(_ notification: NSNotification) {
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let errorCode = userInfo["errorCode"] as? Int {
-
- if errorCode == 0 && metadata.account == self.metadata?.account && metadata.serverUrl == self.metadata?.serverUrl {
-
- self.deleteFile(notification)
- }
- }
- }
- }
-
- @objc func deleteFile(_ notification: NSNotification) {
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let errorCode = userInfo["errorCode"] as? Int {
-
- if errorCode != 0 { return }
-
-
- if viewerImageViewController != nil && metadata.account == self.metadata?.account && metadata.serverUrl == self.metadata?.serverUrl && metadata.typeFile == k_metadataTypeFile_image {
-
- if let metadatas = NCViewerImageCommon.shared.getMetadatasDatasource(metadata: self.metadata, favoriteDatasorce: favoriteFilterImage, mediaDatasorce: mediaFilterImage, offLineDatasource: offlineFilterImage) {
-
- var index = viewerImageViewController!.index - 1
- if index < 0 { index = 0}
- self.metadata = metadatas[index]
-
- viewImage()
-
- } else {
-
- viewUnload()
- }
-
-
- } else if metadata.ocId == self.metadata?.ocId {
-
- viewUnload()
- }
- }
- }
- }
-
- @objc func uploadFile(_ notification: NSNotification) {
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let errorCode = userInfo["errorCode"] as? Int {
-
- if errorCode != 0 { return }
-
-
- if viewerImageViewController != nil && metadata.account == self.metadata?.account && metadata.serverUrl == self.metadata?.serverUrl && metadata.typeFile == k_metadataTypeFile_image {
-
- if NCViewerImageCommon.shared.getMetadatasDatasource(metadata: self.metadata, favoriteDatasorce: favoriteFilterImage, mediaDatasorce: mediaFilterImage, offLineDatasource: offlineFilterImage) != nil {
- viewImage()
- } else {
- viewUnload()
- }
- }
- }
- }
- }
-
- @objc func renameFile(_ notification: NSNotification) {
- if let userInfo = notification.userInfo as NSDictionary? {
- if let metadata = userInfo["metadata"] as? tableMetadata, let errorCode = userInfo["errorCode"] as? Int {
-
- if errorCode != 0 { return }
-
-
- if viewerImageViewController != nil && metadata.account == self.metadata?.account && metadata.serverUrl == self.metadata?.serverUrl && metadata.typeFile == k_metadataTypeFile_image {
-
- if NCViewerImageCommon.shared.getMetadatasDatasource(metadata: self.metadata, favoriteDatasorce: favoriteFilterImage, mediaDatasorce: mediaFilterImage, offLineDatasource: offlineFilterImage) != nil {
- viewImage()
- } else {
- viewUnload()
- }
-
-
- } else if metadata.ocId == self.metadata?.ocId {
-
- self.navigationController?.navigationBar.topItem?.title = metadata.fileNameView
- }
- }
- }
- }
-
-
-
- @objc func viewFile(metadata: tableMetadata, selector: String?) {
-
- self.metadata = metadata
- self.selector = selector
- self.backgroundView.image = nil
- for view in backgroundView.subviews { view.removeFromSuperview() }
- self.navigationController?.navigationBar.topItem?.title = metadata.fileNameView
-
- if FileManager().fileExists(atPath: CCUtility.getDirectoryProviderStorageIconOcId(metadata.ocId, fileNameView: metadata.fileNameView)) == false {
- CCGraphics.createNewImage(from: metadata.fileNameView, ocId: metadata.ocId, extension: (metadata.fileNameView as NSString).pathExtension, filterGrayScale: false, typeFile: metadata.typeFile, writeImage: true)
- }
-
- if appDelegate.isMediaObserver {
- appDelegate.isMediaObserver = false
- NCViewerMedia.sharedInstance.removeObserver()
- }
-
-
- if metadata.typeFile == k_metadataTypeFile_image {
-
- viewImage()
- return
- }
-
-
- if metadata.typeFile == k_metadataTypeFile_audio || metadata.typeFile == k_metadataTypeFile_video {
-
- let frame = CGRect(x: 0, y: 0, width: self.backgroundView.frame.width, height: self.backgroundView.frame.height)
- NCViewerMedia.sharedInstance.viewMedia(metadata, view: backgroundView, frame: frame)
- return
- }
-
-
- if metadata.typeFile == k_metadataTypeFile_document && selector != nil && selector == selectorLoadFileInternalView {
-
- let frame = CGRect(x: 0, y: 0, width: self.backgroundView.frame.width, height: self.backgroundView.frame.height)
- NCViewerDocumentWeb.sharedInstance.viewDocumentWebAt(metadata, view: backgroundView, frame: frame)
- return
- }
-
-
- if metadata.typeFile == k_metadataTypeFile_document {
-
-
- if metadata.contentType == "application/pdf" {
- if #available(iOS 11.0, *) {
-
- 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
- }
-
-
- 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()
- }
-
- NCCommunication.sharedInstance.NCTextOpenFile(urlString: appDelegate.activeUrl, fileNamePath: fileNamePath, editor: editor, customUserAgent: customUserAgent, 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 {
-
- 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
- }
-
-
- 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)
- }
- }
- }
-
-
- let frame = CGRect(x: 0, y: 0, width: self.backgroundView.frame.width, height: self.backgroundView.frame.height)
- NCViewerDocumentWeb.sharedInstance.viewDocumentWebAt(metadata, view: backgroundView, frame: frame)
- }
- }
- extension NCDetailViewController: NCViewerImageViewControllerDelegate, NCViewerImageViewControllerDataSource {
-
- func viewImage() {
-
- for view in backgroundView.subviews { view.removeFromSuperview() }
-
- if let metadatas = NCViewerImageCommon.shared.getMetadatasDatasource(metadata: self.metadata, favoriteDatasorce: favoriteFilterImage, mediaDatasorce: mediaFilterImage, offLineDatasource: offlineFilterImage) {
-
- var counter = 0, index = 0
- for metadata in metadatas {
- if metadata.ocId == self.metadata!.ocId { index = counter }
- counter += 1
- }
- 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!)
- backgroundView.addSubview(viewerImageViewController!.view)
-
- viewerImageViewController!.view.frame = CGRect(x: 0, y: 0, width: backgroundView.frame.width, height: backgroundView.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]
-
-
- if viewerImageViewController.index < metadatas.count {
- self.metadata = metadatas[viewerImageViewController.index]
- self.navigationController?.navigationBar.topItem?.title = self.metadata!.fileNameView
- }
-
-
- if CCUtility.fileProviderStorageSize(metadata.ocId, fileNameView: metadata.fileNameView) > 0 && index == viewerImageViewController.index {
-
- if let image = NCViewerImageCommon.shared.getImage(metadata: metadata) {
- DispatchQueue.main.asyncAfter(deadline: .now() + .milliseconds(100)) {
- completion(index, image, metadata, ZoomScale.default, nil)
- }
- } else {
- completion(index, self.getImageOffOutline(), metadata, ZoomScale.default, nil)
- }
-
-
- } else if CCUtility.fileProviderStorageIconExists(metadata.ocId, fileNameView: metadata.fileNameView) {
-
- if let image = NCViewerImageCommon.shared.getThumbnailImage(metadata: metadata) {
- completion(index, image, metadata, ZoomScale.default, nil)
- } else {
- completion(index, self.getImageOffOutline(), metadata, ZoomScale.default, nil)
- }
-
- } else {
-
- 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: NCUtility.sharedInstance.getScreenWidthForPreview(), height: NCUtility.sharedInstance.getScreenHeightForPreview(), account: metadata.account) { (account, data, errorCode, errorMessage) in
- if errorCode == 0 && data != nil {
- do {
- let url = URL.init(fileURLWithPath: fileNameLocalPath)
- try data!.write(to: url, options: .atomic)
- completion(index, UIImage.init(data: data!), metadata, ZoomScale.default, nil)
- } catch {
- completion(index, self.getImageOffOutline(), metadata, ZoomScale.default, nil)
- }
- } else {
- completion(index, self.getImageOffOutline(), metadata, ZoomScale.default, nil)
- }
- }
- }
- }
-
- func viewerImageViewController(_ viewerImageViewController: NCViewerImageViewController, didChangeFocusTo index: Int, view: NCViewerImageContentView, metadata: tableMetadata) {
-
- if index >= metadatas.count { return }
- let metadata = metadatas[index]
-
- DispatchQueue.global().async {
- if let image = NCViewerImageCommon.shared.getImage(metadata: metadata) {
- DispatchQueue.main.asyncAfter(deadline: .now() + .milliseconds(400)) {
- view.image = image
- }
- }
- }
- }
-
- func viewerImageViewControllerTap(_ viewerImageViewController: NCViewerImageViewController, metadata: tableMetadata) {
- guard let navigationController = self.navigationController else { return }
-
- if navigationController.isNavigationBarHidden {
- navigateControllerBarHidden(false)
- } else {
- navigateControllerBarHidden(true)
- }
-
- NCViewerImageCommon.shared.imageChangeSizeView(viewerImageViewController: viewerImageViewController, size: self.backgroundView.frame.size, metadata: metadata)
- }
-
- func viewerImageViewControllerDismiss() {
- viewUnload()
- }
-
- func getImageOffOutline() -> UIImage {
-
- let image = CCGraphics.changeThemingColorImage(UIImage.init(named: "imageOffOutline"), width: self.view.frame.width, height: self.view.frame.width, color: NCBrandColor.sharedInstance.brand)
- return image!
- }
-
- @objc func downloadImage() {
-
- guard let metadata = self.metadata else {return }
-
- metadata.session = k_download_session
- metadata.sessionError = ""
- metadata.sessionSelector = ""
- metadata.status = Int(k_metadataStatusWaitDownload)
-
- self.metadata = NCManageDatabase.sharedInstance.addMetadata(metadata)
-
-
- if let metadatas = NCViewerImageCommon.shared.getMetadatasDatasource(metadata: self.metadata, favoriteDatasorce: favoriteFilterImage, mediaDatasorce: mediaFilterImage, offLineDatasource: offlineFilterImage) {
- self.metadatas = metadatas
- }
- }
- }
|