123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- import Foundation
- class NCSectionDataSourceMetadata: NSObject {
-
- override init() {
- super.init()
- }
-
- @objc func creataDataSourseSectionMetadata(metadatasSource: [tableMetadata], sort: String, ascending: Bool, groupBy: String? = nil, directoryOnTop: Bool, filterLivePhoto: Bool) -> [tableMetadata] {
-
- var metadatas: [tableMetadata] = []
- var metadatasFavorite: [tableMetadata] = []
- var numDirectory: Int = 0
- var numDirectoryFavorite:Int = 0
-
-
-
- let metadatasSourceSorted = metadatasSource.sorted { (obj1:tableMetadata, obj2:tableMetadata) -> Bool in
- if sort == "date" {
- if ascending {
- return obj1.date.compare(obj2.date as Date) == ComparisonResult.orderedAscending
- } else {
- return obj1.date.compare(obj2.date as Date) == ComparisonResult.orderedDescending
- }
- } else if sort == "sessionTaskIdentifier" {
- if ascending {
- return obj1.sessionTaskIdentifier < obj2.sessionTaskIdentifier
- } else {
- return obj1.sessionTaskIdentifier > obj2.sessionTaskIdentifier
- }
- } else if sort == "size" {
- if ascending {
- return obj1.size < obj2.size
- } else {
- return obj1.size > obj2.size
- }
- } else {
- let range = Range(NSMakeRange(0, obj1.fileNameView.count), in: obj1.fileNameView)
- if ascending {
- return obj1.fileNameView.compare(obj1.fileNameView, options: .caseInsensitive, range: range, locale: .current) == ComparisonResult.orderedAscending
- } else {
- return obj1.fileNameView.compare(obj1.fileNameView, options: .caseInsensitive, range: range, locale: .current) == ComparisonResult.orderedDescending
- }
- }
- }
-
-
-
- for metadata in metadatasSourceSorted {
-
-
- if metadata.ext == "mov" && metadata.livePhoto {
- continue
- }
-
- if metadata.directory && directoryOnTop {
- if metadata.favorite {
- numDirectoryFavorite += 1
- numDirectory += 1
- metadatas.insert(metadata, at: numDirectoryFavorite)
- } else {
- numDirectory += 1
- metadatas.insert(metadata, at: numDirectory)
- }
- } else {
- if metadata.favorite && directoryOnTop {
- metadatasFavorite.append(metadata)
- } else {
- metadatas.append(metadata)
- }
- }
- }
- if directoryOnTop && metadatasFavorite.count > 0 {
- metadatas.insert(contentsOf: metadatasFavorite, at: numDirectory)
- }
-
-
-
- return metadatas
- }
- }
|