메시지 - 리스트, 쓰기, 상세 페이지 추가

This commit is contained in:
Yu Sung
2023-08-10 15:21:08 +09:00
parent 943e1d9f7f
commit 80ff04f825
36 changed files with 2969 additions and 2 deletions

View File

@@ -0,0 +1,74 @@
//
// SelectRecipientView.swift
// SodaLive
//
// Created by klaus on 2023/08/10.
//
import SwiftUI
import Kingfisher
struct SelectRecipientView: View {
@ObservedObject var viewModel = SelectRecipientViewModel()
@Binding var isShowing: Bool
let selectUser: (GetRoomDetailUser) -> Void
var body: some View {
BaseView {
VStack(spacing: 20) {
DetailNavigationBar(title: "받는 사람 검색") {
isShowing = false
}
TextField("닉네임을 입력해주세요", text: $viewModel.searchNickname)
.autocapitalization(.none)
.disableAutocorrection(true)
.font(.custom(Font.medium.rawValue, size: 13.3))
.foregroundColor(Color(hex: "eeeeee"))
.keyboardType(.default)
.padding(.horizontal, 13.3)
.frame(width: screenSize().width - 26.7, height: 50)
.background(Color(hex: "232323"))
.cornerRadius(10)
ScrollView(.vertical, showsIndicators: false) {
VStack(spacing: 26.7) {
ForEach(viewModel.users, id: \.self) { user in
HStack(spacing: 13.3) {
KFImage(URL(string: user.profileImageUrl))
.resizable()
.scaledToFill()
.frame(width: 46.7, height: 46.7, alignment: .top)
.clipped()
.cornerRadius(23.3)
Text(user.nickname)
.font(.custom(Font.medium.rawValue, size: 13.3))
.foregroundColor(Color(hex: "eeeeee"))
Spacer()
}
.contentShape(Rectangle())
.onTapGesture {
selectUser(user)
isShowing = false
}
}
}
}
.frame(width: screenSize().width - 26.7)
}
}
.onAppear {
viewModel.searchUser()
}
}
}
struct SelectRecipientView_Previews: PreviewProvider {
static var previews: some View {
SelectRecipientView(isShowing: .constant(true)) { _ in }
}
}

View File

@@ -0,0 +1,102 @@
//
// SelectRecipientViewModel.swift
// SodaLive
//
// Created by klaus on 2023/08/10.
//
import Foundation
import Combine
final class SelectRecipientViewModel: ObservableObject {
private let liveRepository = LiveRepository()
private let userRepository = UserRepository()
private var subscription = Set<AnyCancellable>()
@Published var errorMessage = ""
@Published var isShowPopup = false
@Published var isLoading = false
@Published var searchNickname = "" {
didSet {
searchUser()
}
}
@Published var users = [GetRoomDetailUser]()
func searchUser() {
if searchNickname.count > 1 {
userRepository.searchUser(nickname: searchNickname)
.sink { result in
switch result {
case .finished:
DEBUG_LOG("finish")
case .failure(let error):
ERROR_LOG(error.localizedDescription)
}
} receiveValue: { response in
let responseData = response.data
do {
let jsonDecoder = JSONDecoder()
let decoded = try jsonDecoder.decode(ApiResponse<[GetRoomDetailUser]>.self, from: responseData)
if let data = decoded.data, decoded.success {
self.users.removeAll()
self.users.append(contentsOf: data)
} else {
if let message = decoded.message {
DEBUG_LOG("message: \(message)")
self.errorMessage = message
} else {
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
}
self.isShowPopup = true
}
} catch {
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
self.isShowPopup = true
}
}
.store(in: &subscription)
} else {
liveRepository.recentVisitRoomUsers()
.sink { result in
switch result {
case .finished:
DEBUG_LOG("finish")
case .failure(let error):
ERROR_LOG(error.localizedDescription)
}
} receiveValue: { response in
self.isLoading = false
let responseData = response.data
do {
let jsonDecoder = JSONDecoder()
let decoded = try jsonDecoder.decode(ApiResponse<[GetRoomDetailUser]>.self, from: responseData)
if let data = decoded.data, decoded.success {
self.users.removeAll()
self.users.append(contentsOf: data)
} else {
if let message = decoded.message {
self.errorMessage = message
} else {
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
}
self.isShowPopup = true
}
} catch {
self.errorMessage = "다시 시도해 주세요.\n계속 같은 문제가 발생할 경우 고객센터로 문의 주시기 바랍니다."
self.isShowPopup = true
}
}
.store(in: &subscription)
}
}
}