Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

MOB-1866 - Track search domains history #421

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
79 commits
Select commit Hold shift + click to select a range
be213e9
Created HomeExploreView
Oleg-Pecheneg Feb 23, 2024
1ff440c
Increased tappable area of chat nav title profile selector
Oleg-Pecheneg Feb 23, 2024
eeff3bd
Created explore view model.
Oleg-Pecheneg Feb 23, 2024
7615517
Added explore view to tab bar
Oleg-Pecheneg Feb 23, 2024
3f323be
Prepare mock data
Oleg-Pecheneg Feb 23, 2024
031864e
Implemented UI for followers section
Oleg-Pecheneg Feb 23, 2024
f07f1f2
Added expandable followers/followings sections
Oleg-Pecheneg Feb 23, 2024
4eb07b8
Added separators
Oleg-Pecheneg Feb 23, 2024
a79a132
Moved search functionality to explore section
Oleg-Pecheneg Feb 23, 2024
e1de387
Set explore title visibility
Oleg-Pecheneg Feb 23, 2024
7a2ffbe
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1837-explo…
Oleg-Pecheneg Feb 27, 2024
5abd9be
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1837-explo…
Oleg-Pecheneg Feb 29, 2024
5560cd4
Created UDSegmentedControlView
Oleg-Pecheneg Feb 29, 2024
32c5b8f
Updated segmented control UI
Oleg-Pecheneg Feb 29, 2024
0c47bd0
Added section with trending profiles
Oleg-Pecheneg Feb 29, 2024
ef4d102
Fixed preview target
Oleg-Pecheneg Feb 29, 2024
81ef4de
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1837-explo…
Oleg-Pecheneg Mar 1, 2024
3ea63aa
Implemented UI for followers picker
Oleg-Pecheneg Mar 1, 2024
eb830da
Refactoring.
Oleg-Pecheneg Mar 1, 2024
a0ce2f4
View refactoring
Oleg-Pecheneg Mar 1, 2024
3615c27
Implemented recent section header view
Oleg-Pecheneg Mar 1, 2024
df1bf73
Working on user domains search result
Oleg-Pecheneg Mar 1, 2024
149a00d
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1837-explo…
Oleg-Pecheneg Mar 4, 2024
cb7c944
Updated imge bridge view
Oleg-Pecheneg Mar 4, 2024
385c5f8
Handle domain selection
Oleg-Pecheneg Mar 4, 2024
7419364
Added empty state to search result.
Oleg-Pecheneg Mar 4, 2024
54603fa
Use adjusted key to search for user's domains
Oleg-Pecheneg Mar 4, 2024
b60beae
Public domain view refactoring
Oleg-Pecheneg Mar 4, 2024
44970a3
Rename crypto to addresses
Oleg-Pecheneg Mar 4, 2024
4e759c8
Extraced token ui description from home module
Oleg-Pecheneg Mar 4, 2024
c0b5e8a
Show list of tokens on public profile
Oleg-Pecheneg Mar 4, 2024
1d34707
MOB-1857 - Removed old search domains entry
Oleg-Pecheneg Mar 4, 2024
d066136
Updated UDCollectionListRowButton usage
Oleg-Pecheneg Mar 4, 2024
e5184d7
Created entities and service for public profile
Oleg-Pecheneg Mar 4, 2024
706f490
Created core data storage for public domain profiles
Oleg-Pecheneg Mar 4, 2024
9d7d1b4
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1837-explo…
Oleg-Pecheneg Mar 4, 2024
936b405
Merge branch 'dev/feat/MOB-1837-explore-ui' into dev/feat/MOB-1856-pu…
Oleg-Pecheneg Mar 4, 2024
c798832
Merge branch 'dev/feat/MOB-1856-public-tokens' into dev/feat/MOB-1857…
Oleg-Pecheneg Mar 4, 2024
481bd49
Merge branch 'dev/feat/MOB-1857-remove-old-search' into dev/feat/MOB-…
Oleg-Pecheneg Mar 4, 2024
eff2de9
Adjust UI on explore screen
Oleg-Pecheneg Mar 4, 2024
d5f95ee
Extended public profile
Oleg-Pecheneg Mar 5, 2024
e325eac
Use public domain profile instead of serialized model.
Oleg-Pecheneg Mar 5, 2024
b75b4a4
Isolate domain profile service dependencies
Oleg-Pecheneg Mar 5, 2024
6d7b0a3
Moved follow/unfollow functions to profile service
Oleg-Pecheneg Mar 5, 2024
5e8455e
Refactoring
Oleg-Pecheneg Mar 5, 2024
98d1a3c
Load and publish socials info
Oleg-Pecheneg Mar 5, 2024
95c0c94
Updated followers fetching and display
Oleg-Pecheneg Mar 5, 2024
073bed7
Refactoring
Oleg-Pecheneg Mar 5, 2024
88ad4c5
Added DomainProfileSocialRelationshipDetails tests
Oleg-Pecheneg Mar 5, 2024
d43ded5
Adding DomainProfilesServiceTests
Oleg-Pecheneg Mar 5, 2024
a94106d
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1856-publi…
Oleg-Pecheneg Mar 5, 2024
fe2b74f
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1856-publi…
Oleg-Pecheneg Mar 5, 2024
63c21a0
Merge branch 'dev/feat/MOB-1856-public-tokens' into dev/feat/MOB-1857…
Oleg-Pecheneg Mar 5, 2024
cd65168
Merge branch 'dev/feat/MOB-1857-remove-old-search' into dev/feat/MOB-…
Oleg-Pecheneg Mar 5, 2024
91e371a
Handle profile selection
Oleg-Pecheneg Mar 5, 2024
96b040c
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1856-publi…
Oleg-Pecheneg Mar 5, 2024
1bc589d
Merge branch 'dev/feat/MOB-1856-public-tokens' into dev/feat/MOB-1857…
Oleg-Pecheneg Mar 5, 2024
cbb2b51
Merge branch 'dev/feat/MOB-1857-remove-old-search' into dev/feat/MOB-…
Oleg-Pecheneg Mar 5, 2024
49bb0c0
Load user's profile
Oleg-Pecheneg Mar 5, 2024
72b3a11
Fixed long names in follower tile
Oleg-Pecheneg Mar 5, 2024
f45dc65
Improved concurrency safety of load followers info
Oleg-Pecheneg Mar 6, 2024
7a71336
Refactoring
Oleg-Pecheneg Mar 6, 2024
b590303
Track profile state when user follow/unfollow/update profile
Oleg-Pecheneg Mar 6, 2024
c878181
Fixed loading of profile info in follower tile.
Oleg-Pecheneg Mar 6, 2024
1e58a2e
Test follow and unfollow functions
Oleg-Pecheneg Mar 6, 2024
24593df
Call load more followers on scroll
Oleg-Pecheneg Mar 6, 2024
ad79c9c
Extended tests to initial data loaded
Oleg-Pecheneg Mar 6, 2024
2c5265f
Added testLoadMoreCalledOnPublishedRequestOnce
Oleg-Pecheneg Mar 6, 2024
e5da060
Created storage for recent search profiles.
Oleg-Pecheneg Mar 6, 2024
7b868ca
Fixed preview target
Oleg-Pecheneg Mar 6, 2024
a80fa1e
Test recent profiles in view model
Oleg-Pecheneg Mar 6, 2024
755d386
Extended view model recent search tests
Oleg-Pecheneg Mar 6, 2024
6aee0c8
Test profile display info in home explore view model
Oleg-Pecheneg Mar 6, 2024
3972ac1
Added empty state when no recent search results.
Oleg-Pecheneg Mar 6, 2024
fe0c487
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1857-remov…
Oleg-Pecheneg Mar 6, 2024
4bfe47d
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1857-remov…
Oleg-Pecheneg Mar 6, 2024
1949ac7
Merge branch 'dev/feat/MOB-1857-remove-old-search' into dev/feat/MOB-…
Oleg-Pecheneg Mar 6, 2024
5baabe0
Merge branch 'dev/feat/MOB-1858-load-followers' into dev/feat/MOB-186…
Oleg-Pecheneg Mar 6, 2024
7256ac8
Merge branch 'dev/feat/MOB-1836-explore' into dev/feat/MOB-1866-track…
Oleg-Pecheneg Mar 6, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,11 @@
import Foundation

final class PreviewPublicDomainProfileDisplayInfoStorageService: PublicDomainProfileDisplayInfoStorageServiceProtocol {



func store(profile: PublicDomainProfileDisplayInfo) {
func store(profile: DomainProfileDisplayInfo) {

}

func retrieveProfileFor(domainName: DomainName) throws -> PublicDomainProfileDisplayInfo {
func retrieveProfileFor(domainName: DomainName) throws -> DomainProfileDisplayInfo {
MockEntitiesFabric.PublicDomainProfile.createPublicDomainProfileDisplayInfo(domainName: domainName)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -15,3 +15,25 @@ struct Storage {

}
}

class SpecificStorage<T: Codable> {
let fileName: String

init(fileName: String) {
self.fileName = fileName
}

func retrieve() -> T? {
nil
}

@discardableResult
func store(_ data: T) -> Bool {

return true
}

func remove() {

}
}
10 changes: 10 additions & 0 deletions unstoppable-ios-app/domains-manager-ios.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -1010,6 +1010,9 @@
C67B6D552AE79E3B00F74B0B /* ImageLoadingServiceTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = C67B6D542AE79E3B00F74B0B /* ImageLoadingServiceTests.swift */; };
C67B6D572AE79E8400F74B0B /* ImagesCacheStorageTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = C67B6D562AE79E8400F74B0B /* ImagesCacheStorageTests.swift */; };
C67B6D5E2AE7F8FB00F74B0B /* Media.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = C67B6D5C2AE7F7CC00F74B0B /* Media.xcassets */; };
C67DE1432B983FD0002374CE /* HomeExploreViewModelTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = C67DE1422B983FD0002374CE /* HomeExploreViewModelTests.swift */; };
C67DE1452B984031002374CE /* RecentGlobalSearchProfilesStorageProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = C67DE1442B984031002374CE /* RecentGlobalSearchProfilesStorageProtocol.swift */; };
C67DE1462B984031002374CE /* RecentGlobalSearchProfilesStorageProtocol.swift in Sources */ = {isa = PBXBuildFile; fileRef = C67DE1442B984031002374CE /* RecentGlobalSearchProfilesStorageProtocol.swift */; };
C68017862886730300524712 /* CurrencyImageLoader.swift in Sources */ = {isa = PBXBuildFile; fileRef = C68017852886730300524712 /* CurrencyImageLoader.swift */; };
C680178E2886E96400524712 /* XCTest.swift in Sources */ = {isa = PBXBuildFile; fileRef = C680178D2886E96400524712 /* XCTest.swift */; };
C681092128041325002D780E /* GIFAnimationsService.swift in Sources */ = {isa = PBXBuildFile; fileRef = C681092028041325002D780E /* GIFAnimationsService.swift */; };
Expand Down Expand Up @@ -3206,6 +3209,8 @@
C67B6D542AE79E3B00F74B0B /* ImageLoadingServiceTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ImageLoadingServiceTests.swift; sourceTree = "<group>"; };
C67B6D562AE79E8400F74B0B /* ImagesCacheStorageTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ImagesCacheStorageTests.swift; sourceTree = "<group>"; };
C67B6D5C2AE7F7CC00F74B0B /* Media.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Media.xcassets; sourceTree = "<group>"; };
C67DE1422B983FD0002374CE /* HomeExploreViewModelTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = HomeExploreViewModelTests.swift; sourceTree = "<group>"; };
C67DE1442B984031002374CE /* RecentGlobalSearchProfilesStorageProtocol.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RecentGlobalSearchProfilesStorageProtocol.swift; sourceTree = "<group>"; };
C68017852886730300524712 /* CurrencyImageLoader.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CurrencyImageLoader.swift; sourceTree = "<group>"; };
C680178A2886A7CC00524712 /* UDWalletsServiceTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UDWalletsServiceTests.swift; sourceTree = "<group>"; };
C680178D2886E96400524712 /* XCTest.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = XCTest.swift; sourceTree = "<group>"; };
Expand Down Expand Up @@ -3957,6 +3962,7 @@
300F291B25D3D4A1007EEAD1 /* DomainRecordsViewModelTests.swift */,
306486972527253D00388026 /* domains_manager_iosTests.swift */,
C66FFD042B01E2EE00988A6F /* CoreDataMessagingStorageServiceTests.swift */,
C67DE1422B983FD0002374CE /* HomeExploreViewModelTests.swift */,
C6AB383D2A692D45003C0944 /* PushMessagingAPIServiceTests.swift */,
C63391772A86819600623188 /* XMTPMessagingAPIServiceTests.swift */,
30C0F94927D8CB250060D283 /* PrivateKeyStorageTests.swift */,
Expand Down Expand Up @@ -5967,6 +5973,7 @@
C6D6E530281937E3008C66BB /* BaseTableViewPresenterProtocol.swift */,
C6D6E526281932FF008C66BB /* BaseViewControllerProtocol.swift */,
C66804AC280D93E5007E6390 /* ObjectWithAttributedString.swift */,
C67DE1442B984031002374CE /* RecentGlobalSearchProfilesStorageProtocol.swift */,
C6EA6D6228B36E7C00B2785F /* ViewAnalyticsLogger.swift */,
C663538A294319B400EF1DC7 /* ScrollViewOffsetListener.swift */,
);
Expand Down Expand Up @@ -8489,6 +8496,7 @@
C6157B242A72663B00081574 /* SymmetricMessagingContentDecrypterService.swift in Sources */,
C689C17E2ADE767500AA0186 /* MockUDFeatureFlagsService.swift in Sources */,
C6D2F13028729585005F4F2E /* DomainDisplayInfo.swift in Sources */,
C67DE1452B984031002374CE /* RecentGlobalSearchProfilesStorageProtocol.swift in Sources */,
C6A2D59F28504EB300327C47 /* ConnectedAppCell.swift in Sources */,
C6DDF2542B147F1A006D1F0B /* UDButtonImage.swift in Sources */,
C609820A2822D92300546392 /* ToastMessageService.swift in Sources */,
Expand Down Expand Up @@ -9467,6 +9475,7 @@
C6B2E2122B970E0900CEA1F9 /* DomainProfileSocialRelationshipDetailsTests.swift in Sources */,
C63391782A86819600623188 /* XMTPMessagingAPIServiceTests.swift in Sources */,
C67B6D572AE79E8400F74B0B /* ImagesCacheStorageTests.swift in Sources */,
C67DE1432B983FD0002374CE /* HomeExploreViewModelTests.swift in Sources */,
C6B6B8732B91A4F900565ED2 /* TaskWithDeadlineTests.swift in Sources */,
C6B2E2142B9714B100CEA1F9 /* DomainProfilesServiceTests.swift in Sources */,
C6DF9870290F83020098733A /* testUpdateRecords.swift in Sources */,
Expand Down Expand Up @@ -10100,6 +10109,7 @@
C618084A2B19B9930032E543 /* PreviewDomainRecordsService.swift in Sources */,
C6D645B92B1DBC5000D724AC /* UIAction.swift in Sources */,
C618085F2B19BBFE0032E543 /* FlowLayoutView.swift in Sources */,
C67DE1462B984031002374CE /* RecentGlobalSearchProfilesStorageProtocol.swift in Sources */,
C6C8F99F2B218E9400A9834D /* ListItemView.swift in Sources */,
C61807B32B199DE50032E543 /* UDGradientCoverView.swift in Sources */,
C618086B2B19BC0C0032E543 /* EasySkeleton.swift in Sources */,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1119,6 +1119,7 @@ extension String {
static let introCollectiblesBody = "INTRO_COLLECTIBLES_BODY"
static let introMessagesBody = "INTRO_MESSAGES_BODY"
static let totalN = "TOTAL_N"
static let globalDomainsSearchHint = "GLOBAL_DOMAINS_SEARCH_HINT"

}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ extension HomeExplore {
var analyticButton: Analytics.Button { .exploreDomainsSearchType }
}

struct ExploreDomainProfile: Hashable, Identifiable {
struct ExploreDomainProfile: Hashable, Identifiable, Codable {
var id: String { domainName }

let domainName: String
Expand Down Expand Up @@ -82,3 +82,47 @@ extension HomeExplore {
}
}
}

// MARK: - Open methods
extension HomeExplore {
struct RecentGlobalSearchProfilesStorage: RecentGlobalSearchProfilesStorageProtocol {

typealias Object = SearchDomainProfile
static let domainPFPStorageFileName = "explore.recent.global.search.data"

static var instance = RecentGlobalSearchProfilesStorage()
private let storage = SpecificStorage<[Object]>(fileName: RecentGlobalSearchProfilesStorage.domainPFPStorageFileName)
private let maxNumberOfRecentProfiles = 3

private init() {}

func getRecentProfiles() -> [Object] {
storage.retrieve() ?? []
}

func addProfileToRecent(_ profile: Object) {
let targetProfileIndex = 0
var profilesList = getRecentProfiles()
if let index = profilesList.firstIndex(where: { $0.name == profile.name }) {
if index == targetProfileIndex {
return
}
profilesList.swapAt(index, targetProfileIndex)
} else {
profilesList.insert(profile, at: targetProfileIndex)
}

profilesList = Array(profilesList.prefix(maxNumberOfRecentProfiles))

set(newProfilesList: profilesList)
}

private func set(newProfilesList: [Object]) {
storage.store(newProfilesList)
}

func clearRecentProfiles() {
storage.remove()
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ final class HomeExploreViewModel: ObservableObject, ViewAnalyticsLogger {
@Published private(set) var globalProfiles: [SearchDomainProfile] = []
@Published private(set) var userDomains: [DomainDisplayInfo] = []
@Published private(set) var trendingProfiles: [HomeExplore.ExploreDomainProfile] = []
@Published private(set) var recentProfiles: [HomeExplore.ExploreDomainProfile] = []
@Published private(set) var recentProfiles: [SearchDomainProfile] = []
@Published private(set) var isLoadingGlobalProfiles = false
@Published private(set) var userWalletNonEmptySearchResults: [HomeExplore.UserWalletNonEmptySearchResult] = []
@Published var userWalletCollapsedAddresses: Set<String> = []
Expand All @@ -26,24 +26,33 @@ final class HomeExploreViewModel: ObservableObject, ViewAnalyticsLogger {
@Published var relationshipType: DomainProfileFollowerRelationshipType = .following
@Published var searchKey: String = ""
@Published var error: Error?
@Published var isKeyboardActive: Bool = true
@Published var isKeyboardActive: Bool = false
var isSearchActive: Bool { isKeyboardActive || !searchKey.isEmpty }

private var router: HomeTabRouter
private var cancellables: Set<AnyCancellable> = []
@Published private var relationshipDetails: WalletDomainProfileDetails?
@Published private var walletDomainProfileDetails: WalletDomainProfileDetails?
private var socialRelationshipDetailsPublisher: AnyCancellable?
private let walletsDataService: WalletsDataServiceProtocol
private let domainProfilesService: DomainProfilesServiceProtocol
private let searchService = DomainsGlobalSearchService()
private let recentProfilesStorage: RecentGlobalSearchProfilesStorageProtocol

init(router: HomeTabRouter,
walletsDataService: WalletsDataServiceProtocol = appContext.walletsDataService) {
walletsDataService: WalletsDataServiceProtocol = appContext.walletsDataService,
domainProfilesService: DomainProfilesServiceProtocol = appContext.domainProfilesService,
recentProfilesStorage: RecentGlobalSearchProfilesStorageProtocol = HomeExplore.RecentGlobalSearchProfilesStorage.instance) {
self.selectedProfile = router.profile
self.router = router
self.walletsDataService = walletsDataService
self.domainProfilesService = domainProfilesService
self.recentProfilesStorage = recentProfilesStorage
userDomains = walletsDataService.wallets.combinedDomains().sorted(by: { $0.name < $1.name })
appContext.userProfileService.selectedProfilePublisher.receive(on: DispatchQueue.main).sink { [weak self] selectedProfile in
self?.setSelectedProfile(selectedProfile)
if let selectedProfile {
self?.selectedProfile = selectedProfile
self?.didUpdateSelectedProfile()
}
}.store(in: &cancellables)

$searchKey.debounce(for: .milliseconds(500), scheduler: DispatchQueue.main).sink { [weak self] searchText in
Expand All @@ -57,16 +66,19 @@ final class HomeExploreViewModel: ObservableObject, ViewAnalyticsLogger {
// MARK: - Open methods
extension HomeExploreViewModel {
var getProfilesListForSelectedRelationshipType: [DomainName] {
relationshipDetails?.socialDetails?.getFollowersListFor(relationshipType: self.relationshipType) ?? []
walletDomainProfileDetails?.socialDetails?.getFollowersListFor(relationshipType: self.relationshipType) ?? []
}

var selectedPublicDomainProfile: DomainProfileDisplayInfo? {
relationshipDetails?.displayInfo
walletDomainProfileDetails?.displayInfo
}

func didTapSearchDomainProfile(_ profile: SearchDomainProfile) {
guard let walletAddress = profile.ownerAddress else { return }

makeChangesToRecentProfilesStorage { storage in
storage.addProfileToRecent(profile)
}
openPublicDomainProfile(domainName: profile.name, walletAddress: walletAddress)
}

Expand Down Expand Up @@ -95,14 +107,16 @@ extension HomeExploreViewModel {
guard let index = followersList.firstIndex(of: domainName),
case .wallet(let wallet) = selectedProfile else { return }

if index + 6 >= followersList.count {
appContext.domainProfilesService.loadMoreSocialIfAbleFor(relationshipType: self.relationshipType,
in: wallet)
if index + Constants.numberOfFollowersBeforeLoadMore >= followersList.count {
domainProfilesService.loadMoreSocialIfAbleFor(relationshipType: self.relationshipType,
in: wallet)
}
}

func clearRecentSearchButtonPressed() {

makeChangesToRecentProfilesStorage { storage in
storage.clearRecentProfiles()
}
}
}

Expand All @@ -112,6 +126,7 @@ private extension HomeExploreViewModel {
loadTrendingProfiles()
loadRecentProfiles()
setUserWalletSearchResults()
updateWalletDomainProfileDetailsForSelectedProfile()
}

func loadTrendingProfiles() {
Expand All @@ -126,28 +141,34 @@ private extension HomeExploreViewModel {
}

func loadRecentProfiles() {
recentProfiles = MockEntitiesFabric.Explore.createTrendingProfiles()
recentProfiles = recentProfilesStorage.getRecentProfiles()
}

func setUserWalletSearchResults() {
let userWallets = walletsDataService.wallets
userWalletNonEmptySearchResults = userWallets.compactMap({ .init(wallet: $0, searchKey: getLowercasedTrimmedSearchKey()) })
}

func setSelectedProfile(_ selectedProfile: UserProfile?) {
if let selectedProfile {
self.selectedProfile = selectedProfile
}
func didUpdateSelectedProfile() {
updateWalletDomainProfileDetailsForSelectedProfile()
}

func updateWalletDomainProfileDetailsForSelectedProfile() {
if case .wallet(let wallet) = selectedProfile {
Task {
socialRelationshipDetailsPublisher = await appContext.domainProfilesService.publisherForWalletDomainProfileDetails(wallet: wallet).receive(on: DispatchQueue.main).sink { [weak self] relationshipDetails in
self?.relationshipDetails = relationshipDetails
socialRelationshipDetailsPublisher = await domainProfilesService.publisherForWalletDomainProfileDetails(wallet: wallet).receive(on: DispatchQueue.main).sink { [weak self] relationshipDetails in
self?.walletDomainProfileDetails = relationshipDetails
}
}
} else {
socialRelationshipDetailsPublisher = nil
}
}

func makeChangesToRecentProfilesStorage(_ block: (RecentGlobalSearchProfilesStorageProtocol)->()) {
block(recentProfilesStorage)
loadRecentProfiles()
}
}

// MARK: - Search methods
Expand All @@ -174,3 +195,10 @@ private extension HomeExploreViewModel {
}
}
}

// MARK: - Open methods
extension HomeExploreViewModel {
struct Constants {
static let numberOfFollowersBeforeLoadMore = 6
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,18 @@
import SwiftUI

struct HomeExploreEmptySearchResultView: View {

var mode: Mode = .noResults

var body: some View {
ZStack {
VStack(spacing: 24) {
Image.searchIcon
.resizable()
.squareFrame(48)
Text(String.Constants.noResults.localized())
Text(mode.title)
.font(.currentFont(size: 22, weight: .bold))
.frame(height: 28)
.multilineTextAlignment(.center)
}
.foregroundStyle(Color.foregroundSecondary)
}
Expand All @@ -27,6 +30,23 @@ struct HomeExploreEmptySearchResultView: View {
}
}

// MARK: - Open methods
extension HomeExploreEmptySearchResultView {
enum Mode {
case noResults
case globalSearchHint

var title: String {
switch self {
case .noResults:
String.Constants.noResults.localized()
case .globalSearchHint:
String.Constants.globalDomainsSearchHint.localized()
}
}
}
}

#Preview {
HomeExploreEmptySearchResultView()
HomeExploreEmptySearchResultView(mode: .globalSearchHint)
}
Loading