Optimize tabbar selection

This commit is contained in:
Thomas Ricouard 2023-03-04 09:30:27 +01:00
parent ab06c0ab17
commit cfee153050
1 changed files with 14 additions and 12 deletions

View File

@ -158,9 +158,6 @@ struct IceCubesApp: App {
TabView(selection: .init(get: {
selectedTab
}, set: { newTab in
var transaction = Transaction()
transaction.disablesAnimations = true
withTransaction(transaction) {
if newTab == selectedTab {
/// Stupid hack to trigger onChange binding in tab views.
popToRootTab = .other
@ -168,7 +165,13 @@ struct IceCubesApp: App {
popToRootTab = selectedTab
}
}
selectedTab = newTab
DispatchQueue.main.async {
HapticManager.shared.fireHaptic(of: .tabSelection)
SoundEffectManager.shared.playSound(of: .tabSelection)
if selectedTab == .notifications,
let token = appAccountsManager.currentAccount.oauthToken
{
@ -176,8 +179,7 @@ struct IceCubesApp: App {
watcher.unreadNotificationsCount = 0
}
}
HapticManager.shared.fireHaptic(of: .tabSelection)
SoundEffectManager.shared.playSound(of: .tabSelection)
})) {
ForEach(availableTabs) { tab in
tab.makeContentView(popToRootTab: $popToRootTab)