From c9fc5057a40892b8e6fb0e5eb79d3252a30a8bfe Mon Sep 17 00:00:00 2001 From: Bosco Ho Date: Sat, 16 Dec 2023 17:22:02 -0800 Subject: [PATCH] Accounts tab navigation (#811) --- Mlem.xcodeproj/project.pbxproj | 4 + .../View - Handle Lemmy Links.swift | 2 + .../Destination Values/SettingsValues.swift | 1 + .../AccountDiscussionLanguagesView.swift | 84 +++++++++++++++++++ .../Account/AccountGeneralSettingsView.swift | 66 +-------------- .../Views/Account/AccountSettingsView.swift | 1 + .../Account/AdvancedAccountSettingsView.swift | 1 + .../Views/Account/MatrixLinkView.swift | 1 + .../Views/Account/ProfileSettingsView.swift | 1 + .../SignInAndSecuritySettingsView.swift | 1 + 10 files changed, 99 insertions(+), 63 deletions(-) create mode 100644 Mlem/Views/Tabs/Settings/Components/Views/Account/AccountDiscussionLanguagesView.swift diff --git a/Mlem.xcodeproj/project.pbxproj b/Mlem.xcodeproj/project.pbxproj index 17522d9c9..1fa181d6b 100644 --- a/Mlem.xcodeproj/project.pbxproj +++ b/Mlem.xcodeproj/project.pbxproj @@ -506,6 +506,7 @@ E40E018E2AABFBDE00410B2C /* AnyNavigationPath.swift in Sources */ = {isa = PBXBuildFile; fileRef = E40E018D2AABFBDE00410B2C /* AnyNavigationPath.swift */; }; E40E01902AABFC9300410B2C /* AnyNavigablePath.swift in Sources */ = {isa = PBXBuildFile; fileRef = E40E018F2AABFC9300410B2C /* AnyNavigablePath.swift */; }; E42D9B5A2AD6802B0087693C /* OnboardingRoutes.swift in Sources */ = {isa = PBXBuildFile; fileRef = E42D9B592AD6802B0087693C /* OnboardingRoutes.swift */; }; + E449C5912B2AA8A300E3BCF4 /* AccountDiscussionLanguagesView.swift in Sources */ = {isa = PBXBuildFile; fileRef = E449C5902B2AA8A300E3BCF4 /* AccountDiscussionLanguagesView.swift */; }; E453477E2A9DE37300D1B46F /* Array+SafeIndexing.swift in Sources */ = {isa = PBXBuildFile; fileRef = E453477D2A9DE37300D1B46F /* Array+SafeIndexing.swift */; }; E453A1D02A81C2140004BB8A /* QuickLookPreviewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = E453A1CF2A81C2140004BB8A /* QuickLookPreviewController.swift */; }; E46AF98E2B29A4AA0087FDF3 /* DismissAction.swift in Sources */ = {isa = PBXBuildFile; fileRef = E46AF98D2B29A4AA0087FDF3 /* DismissAction.swift */; }; @@ -1039,6 +1040,7 @@ E40E018D2AABFBDE00410B2C /* AnyNavigationPath.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AnyNavigationPath.swift; sourceTree = ""; }; E40E018F2AABFC9300410B2C /* AnyNavigablePath.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AnyNavigablePath.swift; sourceTree = ""; }; E42D9B592AD6802B0087693C /* OnboardingRoutes.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = OnboardingRoutes.swift; sourceTree = ""; }; + E449C5902B2AA8A300E3BCF4 /* AccountDiscussionLanguagesView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AccountDiscussionLanguagesView.swift; sourceTree = ""; }; E453477D2A9DE37300D1B46F /* Array+SafeIndexing.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "Array+SafeIndexing.swift"; sourceTree = ""; }; E453A1CF2A81C2140004BB8A /* QuickLookPreviewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = QuickLookPreviewController.swift; sourceTree = ""; }; E46AF98D2B29A4AA0087FDF3 /* DismissAction.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = DismissAction.swift; sourceTree = ""; }; @@ -1101,6 +1103,7 @@ 031A617D2B1CE90F00ABF23B /* ChangePasswordView.swift */, 03F4DC9C2B193F4C00556C67 /* MatrixLinkView.swift */, 03F4DCA22B1A8B0400556C67 /* AccountGeneralSettingsView.swift */, + E449C5902B2AA8A300E3BCF4 /* AccountDiscussionLanguagesView.swift */, ); path = Account; sourceTree = ""; @@ -3275,6 +3278,7 @@ 030AC0522A64666C00037155 /* UserSettingsView.swift in Sources */, CDA2C5262A705D6000649D5A /* PostEditor.swift in Sources */, 03A40DAD2AD5EA11005F019F /* NoPostsView.swift in Sources */, + E449C5912B2AA8A300E3BCF4 /* AccountDiscussionLanguagesView.swift in Sources */, 6372184A2A3A2AAD008C4816 /* APIPost.swift in Sources */, 6D693A3E2A5113DF009E2D76 /* CreatePostReport.swift in Sources */, E46AF9922B29AA350087FDF3 /* ScrollToView.swift in Sources */, diff --git a/Mlem/Extensions/View - Handle Lemmy Links.swift b/Mlem/Extensions/View - Handle Lemmy Links.swift index 62e461b92..891231066 100644 --- a/Mlem/Extensions/View - Handle Lemmy Links.swift +++ b/Mlem/Extensions/View - Handle Lemmy Links.swift @@ -112,6 +112,8 @@ struct HandleLemmyLinksDisplay: ViewModifier { AccountGeneralSettingsView() case .accountAdvanced: AdvancedAccountSettingsView() + case .accountDiscussionLanguages: + AccountDiscussionLanguagesView() case .linkMatrixAccount: MatrixLinkView() case .accounts: diff --git a/Mlem/Navigation/Destination Values/SettingsValues.swift b/Mlem/Navigation/Destination Values/SettingsValues.swift index 4ab73e7a9..c0218b013 100644 --- a/Mlem/Navigation/Destination Values/SettingsValues.swift +++ b/Mlem/Navigation/Destination Values/SettingsValues.swift @@ -13,6 +13,7 @@ enum SettingsPage: DestinationValue { case signInAndSecurity case accountGeneral case accountAdvanced + case accountDiscussionLanguages case linkMatrixAccount case accounts case general diff --git a/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountDiscussionLanguagesView.swift b/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountDiscussionLanguagesView.swift new file mode 100644 index 000000000..a80a4b57e --- /dev/null +++ b/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountDiscussionLanguagesView.swift @@ -0,0 +1,84 @@ +// +// AccountDiscussionLanguagesView.swift +// Mlem +// +// Created by Bosco Ho on 2023-12-13. +// + +import SwiftUI +import Dependencies + +struct AccountDiscussionLanguagesView: View { + + @Dependency(\.siteInformation) var siteInformation: SiteInformationTracker + @Dependency(\.apiClient) var apiClient: APIClient + @Dependency(\.errorHandler) var errorHandler: ErrorHandler + + @State private var discussionLanguages: Set = .init() + + init() { + if let info = siteInformation.myUserInfo { + _discussionLanguages = .init(wrappedValue: Set(info.discussionLanguages)) + } + } + + var body: some View { + Form { + Section { + Toggle(isOn: Binding( + get: { discussionLanguages.contains(0) }, + set: { selected in + if selected { + discussionLanguages.insert(0) + } else { + discussionLanguages.remove(0) + } + saveDiscussionLanguages() + } + )) { + Text("Undetermined") + } + } footer: { + Text("If you deselect Undetermined, you won't see most content.") + } + Section { + ForEach(siteInformation.allLanguages.dropFirst(), id: \.self) { language in + Toggle(isOn: Binding( + get: { discussionLanguages.contains(language.id) }, + set: { selected in + if selected { + discussionLanguages.insert(language.id) + } else { + discussionLanguages.remove(language.id) + } + saveDiscussionLanguages() + } + )) { + Text(language.name) + } + } + } + } + .fancyTabScrollCompatible() + .hoistNavigation() + } + + private func saveDiscussionLanguages() { + let newValue = Array(discussionLanguages).sorted() + if newValue != siteInformation.myUserInfo?.discussionLanguages { + let oldValues = siteInformation.myUserInfo?.discussionLanguages ?? [] + siteInformation.myUserInfo?.discussionLanguages = newValue + Task { + if let info = siteInformation.myUserInfo { + do { + try await apiClient.saveUserSettings(myUserInfo: info) + } catch { + discussionLanguages = Set(oldValues) + siteInformation.myUserInfo?.discussionLanguages = oldValues + errorHandler.handle(error) + } + } + } + } + } +} diff --git a/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountGeneralSettingsView.swift b/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountGeneralSettingsView.swift index af0f9c548..276513718 100644 --- a/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountGeneralSettingsView.swift +++ b/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountGeneralSettingsView.swift @@ -17,39 +17,15 @@ struct AccountGeneralSettingsView: View { @State var showBotAccounts: Bool = false @State var sendNotificationsToEmail: Bool = false - @State var discussionLanguages: Set = .init() - init() { if let info = siteInformation.myUserInfo { _showNsfw = State(wrappedValue: info.localUserView.localUser.showNsfw) _showBotAccounts = State(wrappedValue: info.localUserView.localUser.showBotAccounts) _sendNotificationsToEmail = State(wrappedValue: info.localUserView.localUser.sendNotificationsToEmail) - _discussionLanguages = State(wrappedValue: Set(info.discussionLanguages)) - } - - } - - func saveDiscussionLanguages() { - let newValue = Array(discussionLanguages).sorted() - if newValue != siteInformation.myUserInfo?.discussionLanguages { - let oldValues = siteInformation.myUserInfo?.discussionLanguages ?? [] - siteInformation.myUserInfo?.discussionLanguages = newValue - Task { - if let info = siteInformation.myUserInfo { - do { - try await apiClient.saveUserSettings(myUserInfo: info) - } catch { - discussionLanguages = Set(oldValues) - siteInformation.myUserInfo?.discussionLanguages = oldValues - errorHandler.handle(error) - } - } - } } } var body: some View { - Form { Section { SwitchableSettingsItem( @@ -100,46 +76,9 @@ struct AccountGeneralSettingsView: View { } } Section { - NavigationLink("Discussion Languages") { - Form { - Section { - Toggle(isOn: Binding( - get: { discussionLanguages.contains(0) }, - set: { selected in - if selected { - discussionLanguages.insert(0) - } else { - discussionLanguages.remove(0) - } - saveDiscussionLanguages() - } - )) { - Text("Undetermined") - } - } footer: { - Text("If you deselect Undetermined, you won't see most content.") - } - Section { - ForEach(siteInformation.allLanguages.dropFirst(), id: \.self) { language in - Toggle(isOn: Binding( - get: { discussionLanguages.contains(language.id) }, - set: { selected in - if selected { - discussionLanguages.insert(language.id) - } else { - discussionLanguages.remove(language.id) - } - saveDiscussionLanguages() - } - )) { - Text(language.name) - } - } - } - } - .fancyTabScrollCompatible() + NavigationLink(.settings(.accountDiscussionLanguages)) { + Text("Discussion Languages") } - } Section { SwitchableSettingsItem( @@ -173,5 +112,6 @@ struct AccountGeneralSettingsView: View { } } .navigationTitle("Content & Notifications") + .hoistNavigation() } } diff --git a/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountSettingsView.swift b/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountSettingsView.swift index 52418ee5a..ffddd2e77 100644 --- a/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountSettingsView.swift +++ b/Mlem/Views/Tabs/Settings/Components/Views/Account/AccountSettingsView.swift @@ -127,6 +127,7 @@ struct AccountSettingsView: View { } .navigationTitle("Account Settings") .fancyTabScrollCompatible() + .hoistNavigation() .sheet(item: $accountForDeletion) { account in DeleteAccountView(account: account) } diff --git a/Mlem/Views/Tabs/Settings/Components/Views/Account/AdvancedAccountSettingsView.swift b/Mlem/Views/Tabs/Settings/Components/Views/Account/AdvancedAccountSettingsView.swift index 5c0da5816..34a1e7580 100644 --- a/Mlem/Views/Tabs/Settings/Components/Views/Account/AdvancedAccountSettingsView.swift +++ b/Mlem/Views/Tabs/Settings/Components/Views/Account/AdvancedAccountSettingsView.swift @@ -48,5 +48,6 @@ struct AdvancedAccountSettingsView: View { } } .navigationTitle("Advanced") + .hoistNavigation() } } diff --git a/Mlem/Views/Tabs/Settings/Components/Views/Account/MatrixLinkView.swift b/Mlem/Views/Tabs/Settings/Components/Views/Account/MatrixLinkView.swift index 08eab4584..51c4d9ab3 100644 --- a/Mlem/Views/Tabs/Settings/Components/Views/Account/MatrixLinkView.swift +++ b/Mlem/Views/Tabs/Settings/Components/Views/Account/MatrixLinkView.swift @@ -110,5 +110,6 @@ struct MatrixLinkView: View { } } } + .hoistNavigation() } } diff --git a/Mlem/Views/Tabs/Settings/Components/Views/Account/ProfileSettingsView.swift b/Mlem/Views/Tabs/Settings/Components/Views/Account/ProfileSettingsView.swift index 9b7fd7ada..d44abaaad 100644 --- a/Mlem/Views/Tabs/Settings/Components/Views/Account/ProfileSettingsView.swift +++ b/Mlem/Views/Tabs/Settings/Components/Views/Account/ProfileSettingsView.swift @@ -106,5 +106,6 @@ struct ProfileSettingsView: View { } } .fancyTabScrollCompatible() + .hoistNavigation() } } diff --git a/Mlem/Views/Tabs/Settings/Components/Views/Account/SignInAndSecuritySettingsView.swift b/Mlem/Views/Tabs/Settings/Components/Views/Account/SignInAndSecuritySettingsView.swift index b4ed39eaf..f8e35ba01 100644 --- a/Mlem/Views/Tabs/Settings/Components/Views/Account/SignInAndSecuritySettingsView.swift +++ b/Mlem/Views/Tabs/Settings/Components/Views/Account/SignInAndSecuritySettingsView.swift @@ -127,5 +127,6 @@ struct SignInAndSecuritySettingsView: View { } } .fancyTabScrollCompatible() + .hoistNavigation() } }