From 155a855477539ec4914a0be620456e458cf1464e Mon Sep 17 00:00:00 2001 From: Fuwn Date: Thu, 11 Sep 2025 15:00:22 -0700 Subject: feat: Development commit --- Sora/Views/MainView.swift | 4 +++- Sora/Views/Post/Grid/PostGridView.swift | 21 +++++++++++++-------- 2 files changed, 16 insertions(+), 9 deletions(-) (limited to 'Sora/Views') diff --git a/Sora/Views/MainView.swift b/Sora/Views/MainView.swift index f01a1e6..aa89aa3 100644 --- a/Sora/Views/MainView.swift +++ b/Sora/Views/MainView.swift @@ -13,7 +13,9 @@ struct MainView: View { updateManager(newState) } .onChange(of: manager.historyIndex) { _, _ in - manager.selectedPost = nil + if manager.isNavigatingHistory { + manager.selectedPost = nil + } } .onAppear(perform: initializeManager) .onChange(of: settings.providerCredentials) { initializeManager() } diff --git a/Sora/Views/Post/Grid/PostGridView.swift b/Sora/Views/Post/Grid/PostGridView.swift index 518b305..025c3d2 100644 --- a/Sora/Views/Post/Grid/PostGridView.swift +++ b/Sora/Views/Post/Grid/PostGridView.swift @@ -253,14 +253,19 @@ struct PostGridView: View { // swiftlint:disable:this type_body_length await performLocalSearch() } } else { - currentLocalTask = Task(priority: .userInitiated) { - await fetchLocalPosts( - page: 1, - tags: localSearchText.components(separatedBy: .whitespaces).filter { component in - !component.isEmpty - }, - replace: true - ) + let currentTags = localSearchText.components(separatedBy: .whitespaces).filter { !$0.isEmpty } + let hasPosts = !localPosts.isEmpty + let initialTags = initialTag.components(separatedBy: .whitespaces).filter { !$0.isEmpty } + let needsFetch = !hasPosts || currentTags != initialTags + + if needsFetch { + currentLocalTask = Task(priority: .userInitiated) { + await fetchLocalPosts( + page: 1, + tags: currentTags, + replace: true + ) + } } } } -- cgit v1.2.3