// // HomePhotoRepository.swift // PaiAi // // Created by FFIB on 16/3/31. // Copyright © 2016年 FFIB. All rights reserved. // import Foundation import RxCocoa import RxSwift public protocol HomePhotoRepositorable: Repositorable where Content == [PhotoItem] {} final public class HomePhotoRepository: Resource { fileprivate var items: BehaviorRelay<[PhotoItem]> fileprivate var hasMore: Bool fileprivate var page: Int fileprivate var loadingSchedule: PublishSubject var path: Interfaces { return .home } #warning("user_id 填充") var parameter: Parameter = ["user_id": ""] init() { page = 1 hasMore = true loadingSchedule = PublishSubject() items = BehaviorRelay<[PhotoItem]>(value: []) } } extension HomePhotoRepository: Parsable { func parse(_ json: JSON) -> [PhotoItem]? { guard let data = json["data"] as? [String: AnyObject], let left = data["left"] as? Int, let photos = data["photos"] as? [[String: AnyObject]] else { return nil } hasMore = left > 0 return photos.map { return PhotoItem(json: $0) } } } extension HomePhotoRepository: Gettable { public func loadContent(isRefresh: Bool) { guard hasMore else { loadingSchedule.onNext(isRefresh) return } page = isRefresh ? 1 : page + 1 parameter["page"] = page let _ = NetworkApi.share.post(resource: self) { result in defer { self.loadingSchedule.onNext(isRefresh) } guard case let .success(items) = result else { return } if isRefresh { self.items.accept(items) } else { self.items.accept(self.items.value + items) } } } } extension HomePhotoRepository: HomePhotoRepositorable { public var content: Observable<[PhotoItem]> { return items.asObservable() .flatMap { currentItems in Observable.just(currentItems) .distinctUntilChanged() }.share() } public var loadingObserver: Observable { return loadingSchedule.asObserver() .flatMap { current in Observable.just(current) }.share() } } extension HomePhotoRepository: Layoutable { public func layoutSizeForIndex(_ index: Int) -> CGSize { let h = items.value[index].photo_thumbnail_h let w = items.value[index].photo_thumbnail_w return CGSize(width: w, height: h) } }