TUIKit SwiftUI。LoginStore 的 login 接口登录组件。sdkAppID,上文获取的 sdkAppID。userID,操作者的 userID,也就是 快速开始 中创建的 user1。userSig,操作者的 userSig,也就是 快速开始 中创建的 user1 的 userSig。// ContentView.swiftimport SwiftUIstruct ContentView: View {var body: some View {SearchPage()}}// SearchPage.swiftimport AtomicXimport AtomicXCoreimport SwiftUIpublic struct SearchPage: View {@StateObject private var themeState = ThemeState.shared@State private var isLoggedIn = false@State private var isLoggingIn = true@State private var loginError: String? = nilprivate let sdkAppID: Int32 = 1234567890 // TODO: Fill in the sdkAppID hereprivate let userID = "" // TODO: Fill in your userID hereprivate let userSig = "" // TODO: Fill in your generated userSig herepublic var body: some View {Group {if isLoggedIn {searchContentView} else if isLoggingIn {ProgressView("Logging in...")} else {VStack(spacing: 12) {Image(systemName: "exclamationmark.triangle").font(.system(size: 40)).foregroundColor(.orange)Text(loginError ?? "Login failed").foregroundColor(.secondary)}}}.environmentObject(themeState).onAppear {login()}}// MARK: - Search Contentprivate var searchContentView: some View {VStack(spacing: 0) {navigationBarViewDivider().background(.gray)// Add SearchBar to this page.SearchBar(onTapItem: { result inhandleSearchResult(result)}).padding(.vertical, 8)Spacer()}.background(themeState.colors.bgColorOperate.ignoresSafeArea(edges: .top))}// MARK: - Navigation Barprivate var navigationBarView: some View {HStack {Image(systemName: "magnifyingglass").font(.system(size: 24)).foregroundColor(.gray)Text("Search").font(.system(size: 17, weight: .semibold)).foregroundColor(themeState.colors.textColorPrimary)Spacer()}.padding(.horizontal, 16).frame(height: 44)}// MARK: - Handle Search Resultprivate func handleSearchResult(_ result: Any) {if let friendInfo = result as? FriendSearchInfo {// Handle friend search resultlet conversationID = ChatUtil.getC2CConversationID(friendInfo.userID)print(">>>>> Search result - Friend: \\(friendInfo.userID), conversationID: \\(conversationID)")} else if let groupInfo = result as? GroupSearchInfo {// Handle group search resultlet conversationID = ChatUtil.getGroupConversationID(groupInfo.groupID)print(">>>>> Search result - Group: \\(groupInfo.groupID), conversationID: \\(conversationID)")} else if let messageDict = result as? [String: Any],let messageInfo = messageDict["message"] as? MessageInfo,let conversationID = messageDict["conversationID"] as? String{// Handle message search result (from search detail view)let conversationName = messageDict["conversationName"] as? String ?? "Unknown"print(">>>>> Search result - Message in \\(conversationName), conversationID: \\(conversationID), messageID: \\(messageInfo.id)")} else if let conversationDict = result as? [String: Any],let conversationID = conversationDict["conversationID"] as? String{// Handle conversation search result (from detail view)let conversationName = conversationDict["conversationName"] as? String ?? "Unknown"print(">>>>> Search result - Conversation: \\(conversationName), conversationID: \\(conversationID)")} else {print(">>>>> Search result - Unknown type: \\(result)")}}// MARK: - Loginprivate func login() {guard !userSig.isEmpty else {isLoggingIn = falseloginError = "userSig is empty. Please fill in a valid userSig."return}// Login is required when page appears.LoginStore.shared.login(sdkAppID: sdkAppID, userID: userID, userSig: userSig) { result inswitch result {case .success:print(">>>>> SearchPage login success, userID: \\(userID)")isLoggedIn = trueisLoggingIn = falsecase .failure(let error):print(">>>>> SearchPage login failed: \\(error.code), \\(error.message)")loginError = "Login failed: \\(error.code), \\(error.message)"isLoggingIn = false}}}}

fileName 参数,作为被搜索的内容,如果 fileName 不设置则会从 filePath 提取文件名,并保存到本地和服务器。文档反馈