기부 랭킹 기간 선택 추가
프로필 기부 랭킹 조회와 프로필 갱신 요청에\n기간 값을 전달한다.
This commit is contained in:
@@ -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)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user