feat: 修复MainView Tab切换问题并优化MeView逻辑

- 新增MainView Tab切换问题分析文档,详细描述问题原因及解决方案。
- 优化BottomTabView的绑定逻辑,简化状态管理,确保Tab切换时状态正确更新。
- 在MeView中实现用户信息加载逻辑调整,确保动态列表仅在首次进入时加载,并添加错误处理视图。
- 创建EmptyStateView组件,提供统一的空状态展示和重试功能。
- 增强调试信息输出,便于后续问题排查和用户体验提升。
This commit is contained in:
edwinQQQ
2025-08-05 15:51:07 +08:00
parent 99a53d7274
commit 4ff92c8c4d
16 changed files with 481 additions and 322 deletions

View File

@@ -26,6 +26,19 @@ struct MainFeature {
debugInfoSync("🏗️ MainFeature 初始化")
debugInfoSync(" accountModel.uid: \(accountModel?.uid ?? "nil")")
debugInfoSync(" 转换后的uid: \(uid)")
// accountModelKeychain
if accountModel == nil {
debugInfoSync(" 🔍 尝试从Keychain获取AccountModel")
Task {
if let savedAccountModel = await UserInfoManager.getAccountModel() {
debugInfoSync(" ✅ 从Keychain获取到AccountModel: \(savedAccountModel.uid ?? "nil")")
} else {
debugInfoSync(" ⚠️ 从Keychain未获取到AccountModel")
}
}
}
var meState = MeFeature.State(displayUID: uid > 0 ? uid : nil)
if uid > 0 {
meState.uid = uid // uiddisplayUID
@@ -73,15 +86,34 @@ struct MainFeature {
await send(.accountModelLoaded(accountModel))
}
case .selectTab(let tab):
debugInfoSync("🎯 MainFeature selectTab: \(tab)")
debugInfoSync(" 当前selectedTab: \(state.selectedTab)")
debugInfoSync(" 新selectedTab: \(tab)")
// tab
guard state.selectedTab != tab else {
debugInfoSync(" ⚠️ 重复设置相同tab忽略")
return .none
}
state.selectedTab = tab
state.navigationPath = []
if tab == .other, let uidStr = state.accountModel?.uid, let uid = Int(uidStr), uid > 0 {
if state.me.displayUID != uid {
state.me.displayUID = uid
state.me.uid = uid // uid
state.me.isFirstLoad = true
debugInfoSync(" ✅ selectedTab已更新为: \(state.selectedTab)")
// MeViewuid
if tab == .other {
if let uidStr = state.accountModel?.uid, let uid = Int(uidStr), uid > 0 {
if state.me.displayUID != uid {
state.me.displayUID = uid
state.me.uid = uid // uid
state.me.isFirstLoad = true
debugInfoSync(" 🔄 更新MeFeature状态uid: \(uid)")
}
debugInfoSync(" 📱 切换到MeView触发数据加载")
return .send(.me(.onAppear))
} else {
debugInfoSync(" ⚠️ 切换到MeView但uid无效等待AccountModel加载")
}
return .send(.me(.onAppear))
}
return .none
case .feedList(.testButtonTapped):
@@ -97,14 +129,31 @@ struct MainFeature {
return .none
case let .accountModelLoaded(accountModel):
state.accountModel = accountModel
// MeView uid
if state.selectedTab == .other, let uidStr = accountModel?.uid, let uid = Int(uidStr), uid > 0 {
debugInfoSync("📦 MainFeature: AccountModel已加载")
debugInfoSync(" uid: \(accountModel?.uid ?? "nil")")
// MeFeature
if let uidStr = accountModel?.uid, let uid = Int(uidStr), uid > 0 {
if state.me.displayUID != uid {
state.me.displayUID = uid
state.me.uid = uid // uid
state.me.isFirstLoad = true
debugInfoSync(" 🔄 更新MeFeature状态uid: \(uid)")
}
return .send(.me(.onAppear))
// MeView
if state.selectedTab == .other {
debugInfoSync(" 📱 当前在MeView触发数据加载")
return .send(.me(.onAppear))
}
// FeedView
if state.selectedTab == .feed {
debugInfoSync(" 📱 当前在FeedView触发数据加载")
return .send(.feedList(.checkAuthAndLoad))
}
} else {
debugInfoSync(" ⚠️ AccountModel中uid无效")
}
return .none
case .me(.settingButtonTapped):