기부 랭킹 기간 선택 추가

프로필 기부 랭킹 조회와 프로필 갱신 요청에\n기간 값을 전달한다.
This commit is contained in:
Yu Sung
2026-02-03 18:38:36 +09:00
parent d686223362
commit 13f8d924c0
9 changed files with 257 additions and 87 deletions

View File

@@ -23,17 +23,28 @@ final class UserProfileDonationAllViewModel: ObservableObject {
@Published var accumulatedCansThisMonth = 0
@Published var isVisibleDonationRank = false
@Published var userDonationRanking: [UserDonationRankingResponse] = []
@Published var donationRankingPeriod: DonationRankingPeriod = .weekly
@Published var selectedRankingPeriod: DonationRankingPeriod? = nil
var userId = 0
var page = 1
var isLast = false
private let pageSize = 10
private var hasLoadedDonationRankingPeriod = false
func getCreatorProfileDonationRanking() {
if (!isLast && !isLoading) {
isLoading = true
repository.getCreatorProfileDonationRanking(userId: userId, page: page, size: pageSize)
let isCreator = userId == UserDefaults.int(forKey: .userId)
let period: DonationRankingPeriod? = isCreator ? selectedRankingPeriod : nil
repository.getCreatorProfileDonationRanking(
userId: userId,
page: page,
size: pageSize,
period: period
)
.sink { result in
switch result {
case .finished:
@@ -55,6 +66,15 @@ final class UserProfileDonationAllViewModel: ObservableObject {
self.accumulatedCansThisMonth = data.accumulatedCansThisMonth
self.isVisibleDonationRank = data.isVisibleDonationRank
if let period = data.donationRankingPeriod {
self.donationRankingPeriod = period
self.hasLoadedDonationRankingPeriod = true
if self.selectedRankingPeriod == nil {
self.selectedRankingPeriod = period
}
}
if !data.userDonationRanking.isEmpty {
page += 1
self.totalCount = data.totalCount
@@ -79,6 +99,20 @@ final class UserProfileDonationAllViewModel: ObservableObject {
.store(in: &subscription)
}
}
func selectDonationRankingPeriod(_ period: DonationRankingPeriod) {
guard donationRankingPeriod != period else { return }
donationRankingPeriod = period
hasLoadedDonationRankingPeriod = true
updateDonationRankingPeriod(period)
}
func selectViewRankingPeriod(_ period: DonationRankingPeriod) {
guard selectedRankingPeriod != period else { return }
selectedRankingPeriod = period
resetDonationRanking()
getCreatorProfileDonationRanking()
}
func toggleVisibleDonationRank() {
isLoading = true
@@ -122,4 +156,49 @@ final class UserProfileDonationAllViewModel: ObservableObject {
}
.store(in: &subscription)
}
private func resetDonationRanking() {
totalCount = 0
userDonationRanking = []
page = 1
isLast = false
}
private func updateDonationRankingPeriod(_ period: DonationRankingPeriod) {
memberRepository.profileUpdate(
request: ProfileUpdateRequest(
email: UserDefaults.string(forKey: .email),
donationRankingPeriod: period
)
)
.sink { result in
switch result {
case .finished:
DEBUG_LOG("finish")
case .failure(let error):
ERROR_LOG(error.localizedDescription)
}
} receiveValue: { [unowned self] response in
let responseData = response.data
do {
let jsonDecoder = JSONDecoder()
let decoded = try jsonDecoder.decode(ApiResponse<GetProfileResponse>.self, from: responseData)
if !decoded.success {
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)
}
}