12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- import UIKit
- import FileProvider
- import NCCommunication
- extension FileProviderExtension {
- override func fetchThumbnails(for itemIdentifiers: [NSFileProviderItemIdentifier], requestedSize size: CGSize, perThumbnailCompletionHandler: @escaping (NSFileProviderItemIdentifier, Data?, Error?) -> Void, completionHandler: @escaping (Error?) -> Void) -> Progress {
-
- let progress = Progress(totalUnitCount: Int64(itemIdentifiers.count))
- var counterProgress: Int64 = 0
-
- for itemIdentifier in itemIdentifiers {
-
- guard let metadata = fileProviderUtility.shared.getTableMetadataFromItemIdentifier(itemIdentifier) else {
- counterProgress += 1
- if (counterProgress == progress.totalUnitCount) { completionHandler(nil) }
- continue
- }
-
- if (metadata.hasPreview) {
-
- let fileNamePath = CCUtility.returnFileNamePath(fromFileName: metadata.fileName, serverUrl: metadata.serverUrl, urlBase: metadata.urlBase, account: metadata.account)!
- let fileNameIconLocalPath = CCUtility.getDirectoryProviderStorageIconOcId(metadata.ocId, etag: metadata.etag)!
-
- NCCommunication.shared.getPreview(fileNamePath: fileNamePath, widthPreview: NCGlobal.shared.sizeIcon, heightPreview: NCGlobal.shared.sizeIcon) { (account, data, errorCode, errorDescription) in
- if errorCode == 0 && data != nil {
- do {
- try data!.write(to: URL.init(fileURLWithPath: fileNameIconLocalPath), options: .atomic)
- } catch { }
- perThumbnailCompletionHandler(itemIdentifier, data, nil)
- } else {
- perThumbnailCompletionHandler(itemIdentifier, nil, NSFileProviderError(.serverUnreachable))
- }
- counterProgress += 1
- if (counterProgress == progress.totalUnitCount) {
- completionHandler(nil)
- }
- }
- } else {
- counterProgress += 1
- if (counterProgress == progress.totalUnitCount) {
- completionHandler(nil)
- }
- }
- }
-
- return progress
- }
-
- }
|