forked from zelo72/mastodon-ios
chore: add navigation to profile, add recommend navigation
This commit is contained in:
parent
2331867758
commit
803ff3a7fd
|
@ -5,6 +5,8 @@
|
||||||
// Created by sxiaojian on 2021/3/31.
|
// Created by sxiaojian on 2021/3/31.
|
||||||
//
|
//
|
||||||
|
|
||||||
|
import CoreData
|
||||||
|
import CoreDataStack
|
||||||
import Foundation
|
import Foundation
|
||||||
import MastodonSDK
|
import MastodonSDK
|
||||||
import OSLog
|
import OSLog
|
||||||
|
@ -54,6 +56,18 @@ extension SearchViewController: UICollectionViewDelegate {
|
||||||
func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
|
func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
|
||||||
os_log(.info, log: .debug, "%{public}s[%{public}ld], %{public}s: indexPath: %s", (#file as NSString).lastPathComponent, #line, #function, indexPath.debugDescription)
|
os_log(.info, log: .debug, "%{public}s[%{public}ld], %{public}s: indexPath: %s", (#file as NSString).lastPathComponent, #line, #function, indexPath.debugDescription)
|
||||||
collectionView.selectItem(at: indexPath, animated: true, scrollPosition: .centeredHorizontally)
|
collectionView.selectItem(at: indexPath, animated: true, scrollPosition: .centeredHorizontally)
|
||||||
|
switch collectionView {
|
||||||
|
case self.accountsCollectionView:
|
||||||
|
guard let diffableDataSource = viewModel.accountDiffableDataSource else { return }
|
||||||
|
guard let account = diffableDataSource.itemIdentifier(for: indexPath) else { return }
|
||||||
|
viewModel.accountCollectionViewItemDidSelected(account: account, from: self)
|
||||||
|
case self.hashtagCollectionView:
|
||||||
|
guard let diffableDataSource = viewModel.hashtagDiffableDataSource else { return }
|
||||||
|
guard let hashtag = diffableDataSource.itemIdentifier(for: indexPath) else { return }
|
||||||
|
viewModel.hashtagCollectionViewItemDidSelected(hashtag: hashtag, from: self)
|
||||||
|
default:
|
||||||
|
break
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -235,6 +235,41 @@ final class SearchViewModel: NSObject {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func accountCollectionViewItemDidSelected(account: Mastodon.Entity.Account, from: UIViewController) {
|
||||||
|
_ = context.managedObjectContext.performChanges { [weak self] in
|
||||||
|
guard let self = self else { return }
|
||||||
|
guard let activeMastodonAuthenticationBox = self.context.authenticationService.activeMastodonAuthenticationBox.value else {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// load request mastodon user
|
||||||
|
let requestMastodonUser: MastodonUser? = {
|
||||||
|
let request = MastodonUser.sortedFetchRequest
|
||||||
|
request.predicate = MastodonUser.predicate(domain: activeMastodonAuthenticationBox.domain, id: activeMastodonAuthenticationBox.userID)
|
||||||
|
request.fetchLimit = 1
|
||||||
|
request.returnsObjectsAsFaults = false
|
||||||
|
do {
|
||||||
|
return try self.context.managedObjectContext.fetch(request).first
|
||||||
|
} catch {
|
||||||
|
assertionFailure(error.localizedDescription)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
let (mastodonUser, _) = APIService.CoreData.createOrMergeMastodonUser(into: self.context.managedObjectContext, for: requestMastodonUser, in: activeMastodonAuthenticationBox.domain, entity: account, userCache: nil, networkDate: Date(), log: OSLog.api)
|
||||||
|
let viewModel = ProfileViewModel(context: self.context, optionalMastodonUser: mastodonUser)
|
||||||
|
DispatchQueue.main.async {
|
||||||
|
self.coordinator.present(scene: .profile(viewModel: viewModel), from: from, transition: .show)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func hashtagCollectionViewItemDidSelected(hashtag: Mastodon.Entity.Tag, from: UIViewController) {
|
||||||
|
let (tagInCoreData,_) = APIService.CoreData.createOrMergeTag(into: self.context.managedObjectContext, entity: hashtag)
|
||||||
|
let viewModel = HashtagTimelineViewModel(context: self.context, hashtag: tagInCoreData.name)
|
||||||
|
DispatchQueue.main.async {
|
||||||
|
self.coordinator.present(scene: .hashtagTimeline(viewModel: viewModel), from: from, transition: .show)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func searchResultItemDidSelected(item: SearchResultItem,from: UIViewController) {
|
func searchResultItemDidSelected(item: SearchResultItem,from: UIViewController) {
|
||||||
let searchHistories = self.fetchSearchHistory()
|
let searchHistories = self.fetchSearchHistory()
|
||||||
_ = context.managedObjectContext.performChanges { [weak self] in
|
_ = context.managedObjectContext.performChanges { [weak self] in
|
||||||
|
@ -271,6 +306,10 @@ final class SearchViewModel: NSObject {
|
||||||
} else {
|
} else {
|
||||||
SearchHistory.insert(into: self.context.managedObjectContext, account: mastodonUser)
|
SearchHistory.insert(into: self.context.managedObjectContext, account: mastodonUser)
|
||||||
}
|
}
|
||||||
|
let viewModel = ProfileViewModel(context: self.context, optionalMastodonUser: mastodonUser)
|
||||||
|
DispatchQueue.main.async {
|
||||||
|
self.coordinator.present(scene: .profile(viewModel: viewModel), from: from, transition: .show)
|
||||||
|
}
|
||||||
|
|
||||||
case .hashtag(let tag):
|
case .hashtag(let tag):
|
||||||
let (tagInCoreData,_) = APIService.CoreData.createOrMergeTag(into: self.context.managedObjectContext, entity: tag)
|
let (tagInCoreData,_) = APIService.CoreData.createOrMergeTag(into: self.context.managedObjectContext, entity: tag)
|
||||||
|
@ -288,7 +327,9 @@ final class SearchViewModel: NSObject {
|
||||||
SearchHistory.insert(into: self.context.managedObjectContext, hashtag: tagInCoreData)
|
SearchHistory.insert(into: self.context.managedObjectContext, hashtag: tagInCoreData)
|
||||||
}
|
}
|
||||||
let viewModel = HashtagTimelineViewModel(context: self.context, hashtag: tagInCoreData.name)
|
let viewModel = HashtagTimelineViewModel(context: self.context, hashtag: tagInCoreData.name)
|
||||||
|
DispatchQueue.main.async {
|
||||||
self.coordinator.present(scene: .hashtagTimeline(viewModel: viewModel), from: from, transition: .show)
|
self.coordinator.present(scene: .hashtagTimeline(viewModel: viewModel), from: from, transition: .show)
|
||||||
|
}
|
||||||
case .accountObjectID(let accountObjectID):
|
case .accountObjectID(let accountObjectID):
|
||||||
if let searchHistories = searchHistories {
|
if let searchHistories = searchHistories {
|
||||||
let history = searchHistories.first { history -> Bool in
|
let history = searchHistories.first { history -> Bool in
|
||||||
|
@ -299,6 +340,11 @@ final class SearchViewModel: NSObject {
|
||||||
history.update(updatedAt: Date())
|
history.update(updatedAt: Date())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
let mastodonUser = self.context.managedObjectContext.object(with: accountObjectID) as! MastodonUser
|
||||||
|
let viewModel = ProfileViewModel(context: self.context, optionalMastodonUser: mastodonUser)
|
||||||
|
DispatchQueue.main.async {
|
||||||
|
self.coordinator.present(scene: .profile(viewModel: viewModel), from: from, transition: .show)
|
||||||
|
}
|
||||||
case .hashtagObjectID(let hashtagObjectID):
|
case .hashtagObjectID(let hashtagObjectID):
|
||||||
if let searchHistories = searchHistories {
|
if let searchHistories = searchHistories {
|
||||||
let history = searchHistories.first { history -> Bool in
|
let history = searchHistories.first { history -> Bool in
|
||||||
|
@ -311,7 +357,9 @@ final class SearchViewModel: NSObject {
|
||||||
}
|
}
|
||||||
let tagInCoreData = self.context.managedObjectContext.object(with: hashtagObjectID) as! Tag
|
let tagInCoreData = self.context.managedObjectContext.object(with: hashtagObjectID) as! Tag
|
||||||
let viewModel = HashtagTimelineViewModel(context: self.context, hashtag: tagInCoreData.name)
|
let viewModel = HashtagTimelineViewModel(context: self.context, hashtag: tagInCoreData.name)
|
||||||
|
DispatchQueue.main.async {
|
||||||
self.coordinator.present(scene: .hashtagTimeline(viewModel: viewModel), from: from, transition: .show)
|
self.coordinator.present(scene: .hashtagTimeline(viewModel: viewModel), from: from, transition: .show)
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue