Compare commits

...

2 Commits

2 changed files with 29 additions and 13 deletions

View File

@ -143,12 +143,15 @@ struct ComposeAutocompleteMentionsView: View {
localSearchWorkItem.cancel() localSearchWorkItem.cancel()
// dispatch back to the main thread because loadAccounts uses CoreData
DispatchQueue.main.async {
// if the query has changed, don't bother loading the now-outdated results // if the query has changed, don't bother loading the now-outdated results
if case .mention(query) = uiState.autocompleteState { if case .mention(query) = uiState.autocompleteState {
self.loadAccounts(accounts.map { .pachyderm($0) }, query: query) self.loadAccounts(accounts.map { .pachyderm($0) }, query: query)
} }
} }
} }
}
private func loadAccounts(_ accounts: [EitherAccount], query: String) { private func loadAccounts(_ accounts: [EitherAccount], query: String) {
// when sorting account suggestions, ignore the domain component of the acct unless the user is typing it themself // when sorting account suggestions, ignore the domain component of the acct unless the user is typing it themself
@ -161,8 +164,20 @@ struct ComposeAutocompleteMentionsView: View {
return res return res
} }
.filter(\.1.matched) .filter(\.1.matched)
// todo: it would be nice to prioritize followee/follower accounts, but relationships aren't cached .map { (account, res) -> (EitherAccount, Int) in
.sorted { $0.1.score > $1.1.score } // give higher weight to accounts that the user follows or is followed by
var score = res.score
if let relationship = mastodonController.persistentContainer.relationship(forAccount: account.id) {
if relationship.following {
score += 3
}
if relationship.followedBy {
score += 2
}
}
return (account, score)
}
.sorted { $0.1 > $1.1 }
.map(\.0) .map(\.0)
} }

View File

@ -7,6 +7,7 @@
// //
import UIKit import UIKit
import Pachyderm
class MyProfileViewController: ProfileViewController { class MyProfileViewController: ProfileViewController {
@ -21,7 +22,7 @@ class MyProfileViewController: ProfileViewController {
DispatchQueue.main.async { DispatchQueue.main.async {
self.accountID = account.id self.accountID = account.id
self.setAvatarTabBarImage() self.setAvatarTabBarImage(account: account)
} }
} }
} }
@ -38,12 +39,7 @@ class MyProfileViewController: ProfileViewController {
NotificationCenter.default.addObserver(self, selector: #selector(preferencesChanged), name: .preferencesChanged, object: nil) NotificationCenter.default.addObserver(self, selector: #selector(preferencesChanged), name: .preferencesChanged, object: nil)
} }
private func setAvatarTabBarImage() { private func setAvatarTabBarImage<Account: AccountProtocol>(account: Account) {
guard let id = mastodonController.account?.id,
let account = mastodonController.persistentContainer.account(for: id) else {
return
}
_ = ImageCache.avatars.get(account.avatar, completion: { [weak self] (data) in _ = ImageCache.avatars.get(account.avatar, completion: { [weak self] (data) in
guard let self = self, let data = data, let image = UIImage(data: data) else { return } guard let self = self, let data = data, let image = UIImage(data: data) else { return }
DispatchQueue.main.async { DispatchQueue.main.async {
@ -61,7 +57,12 @@ class MyProfileViewController: ProfileViewController {
} }
@objc private func preferencesChanged() { @objc private func preferencesChanged() {
setAvatarTabBarImage() guard let id = mastodonController.account?.id,
let account = mastodonController.persistentContainer.account(for: id) else {
return
}
setAvatarTabBarImage(account: account)
} }
// MARK: - Interaction // MARK: - Interaction