2021-03-17 11:09:38 +01:00
|
|
|
//
|
|
|
|
// MastodonAttachmentService.swift
|
|
|
|
// Mastodon
|
|
|
|
//
|
|
|
|
// Created by MainasuK Cirno on 2021-3-17.
|
|
|
|
//
|
|
|
|
|
|
|
|
import UIKit
|
|
|
|
import Combine
|
2021-03-18 08:16:35 +01:00
|
|
|
import PhotosUI
|
2021-03-17 11:09:38 +01:00
|
|
|
|
|
|
|
final class MastodonAttachmentService {
|
|
|
|
|
2021-03-18 08:16:35 +01:00
|
|
|
var disposeBag = Set<AnyCancellable>()
|
|
|
|
|
2021-03-17 11:09:38 +01:00
|
|
|
let identifier = UUID()
|
|
|
|
|
2021-03-18 08:16:35 +01:00
|
|
|
// input
|
|
|
|
let pickerResult: PHPickerResult
|
|
|
|
|
|
|
|
// output
|
|
|
|
let imageData = CurrentValueSubject<Data?, Never>(nil)
|
|
|
|
let error = CurrentValueSubject<Error?, Never>(nil)
|
|
|
|
|
|
|
|
init(pickerResult: PHPickerResult) {
|
|
|
|
self.pickerResult = pickerResult
|
|
|
|
// end init
|
|
|
|
|
|
|
|
PHPickerResultLoader.loadImageData(from: pickerResult)
|
|
|
|
.sink { [weak self] completion in
|
|
|
|
guard let self = self else { return }
|
|
|
|
switch completion {
|
|
|
|
case .failure(let error):
|
|
|
|
self.error.value = error
|
|
|
|
case .finished:
|
|
|
|
break
|
|
|
|
}
|
|
|
|
} receiveValue: { [weak self] imageData in
|
|
|
|
guard let self = self else { return }
|
|
|
|
self.imageData.value = imageData
|
|
|
|
}
|
|
|
|
.store(in: &disposeBag)
|
|
|
|
}
|
|
|
|
|
2021-03-17 11:09:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
extension MastodonAttachmentService: Equatable, Hashable {
|
|
|
|
|
|
|
|
static func == (lhs: MastodonAttachmentService, rhs: MastodonAttachmentService) -> Bool {
|
|
|
|
return lhs.identifier == rhs.identifier
|
|
|
|
}
|
|
|
|
|
|
|
|
func hash(into hasher: inout Hasher) {
|
|
|
|
hasher.combine(identifier)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|