feat(home): 홈 추천 콘텐츠 섹션 추가

This commit is contained in:
Yu Sung
2025-11-14 01:24:20 +09:00
parent 0902b1fe30
commit 0fd49a71f6
6 changed files with 106 additions and 2 deletions

View File

@@ -33,6 +33,7 @@ final class HomeTabViewModel: ObservableObject {
@Published var recommendChannelList: [RecommendChannelResponse] = []
@Published var freeContentList: [AudioContentMainItem] = []
@Published var pointAvailableContentList: [AudioContentMainItem] = []
@Published var recommendContentList: [AudioContentMainItem] = []
func fetchData() {
isLoading = true
@@ -65,6 +66,7 @@ final class HomeTabViewModel: ObservableObject {
self.recommendChannelList = data.recommendChannelList
self.freeContentList = data.freeContentList
self.pointAvailableContentList = data.pointAvailableContentList
self.recommendContentList = data.recommendContentList
} else {
if let message = decoded.message {
self.errorMessage = message
@@ -197,4 +199,42 @@ final class HomeTabViewModel: ObservableObject {
}
.store(in: &subscription)
}
func refreshRecommendContents() {
isLoading = true
repository.getRecommendContents()
.sink { result in
switch result {
case .finished:
DEBUG_LOG("finish")
case .failure(let error):
ERROR_LOG(error.localizedDescription)
}
} receiveValue: { [unowned self] response in
self.isLoading = false
let responseData = response.data
do {
let jsonDecoder = JSONDecoder()
let decoded = try jsonDecoder.decode(ApiResponse<[AudioContentMainItem]>.self, from: responseData)
if let data = decoded.data, decoded.success {
self.recommendContentList = 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)
}
}