From 75e1dc3abdef4d6cf53cf536b855396bf8afc6b7 Mon Sep 17 00:00:00 2001 From: Nathan Mattes Date: Sat, 25 Feb 2023 12:35:29 +0100 Subject: [PATCH] Update server-list-sorting during onboarding (IOS-116) (#956) --- .../MastodonPickServerViewModel.swift | 49 +++++-------------- 1 file changed, 12 insertions(+), 37 deletions(-) diff --git a/Mastodon/Scene/Onboarding/PickServer/MastodonPickServerViewModel.swift b/Mastodon/Scene/Onboarding/PickServer/MastodonPickServerViewModel.swift index ced8b26b3..fdc57214e 100644 --- a/Mastodon/Scene/Onboarding/PickServer/MastodonPickServerViewModel.swift +++ b/Mastodon/Scene/Onboarding/PickServer/MastodonPickServerViewModel.swift @@ -126,45 +126,20 @@ extension MastodonPickServerViewModel { } ) .map { indexedServers, selectCategoryItem, searchText, filters -> [Mastodon.Entity.Server] in - // ignore approval required servers when sign-up var indexedServers = indexedServers - // Note: - // sort by calculate last week users count - // and make medium size (~800) server to top - - // group by language user preferred language first - var languageToServersMapping = OrderedDictionary() - for language in Locale.preferredLanguages { - let local = Locale(identifier: language) - guard let languageCode = local.languageCode else { continue } - // skip if key duplicate - guard !languageToServersMapping.keys.contains(languageCode) else { continue } - // append to dict - languageToServersMapping[languageCode] = indexedServers - .filter { $0.language.lowercased() == languageCode.lowercased() } - .sorted(by: { lh, rh in - let lhValue = abs(log2(800.0) - log2(Double(lh.lastWeekUsers))) - let rhValue = abs(log2(800.0) - log2(Double(rh.lastWeekUsers))) - return lhValue < rhValue - }) - } - // sort remains servers - let remainsServers = indexedServers - .filter { server in - return !languageToServersMapping.contains { _, servers in servers.contains(server) } - } - .sorted(by: { lh, rh in - let lhValue = abs(log2(800.0) - log2(Double(lh.lastWeekUsers))) - let rhValue = abs(log2(800.0) - log2(Double(rh.lastWeekUsers))) - return lhValue < rhValue - }) - + var _indexedServers: [Mastodon.Entity.Server] = [] - for key in languageToServersMapping.keys { - _indexedServers.append(contentsOf: languageToServersMapping[key] ?? []) - } - _indexedServers.append(contentsOf: remainsServers) - + + let sortedInstantSignupServers = indexedServers + .filter { $0.approvalRequired == false } + .sorted { $0.lastWeekUsers >= $1.lastWeekUsers } + let sortedApprovalRequiredServers = indexedServers + .filter { $0.approvalRequired } + .sorted { $0.lastWeekUsers >= $1.lastWeekUsers } + + _indexedServers.append(contentsOf: sortedInstantSignupServers) + _indexedServers.append(contentsOf: sortedApprovalRequiredServers) + if _indexedServers.count == indexedServers.count { indexedServers = _indexedServers } else {