Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ final class CustomBottomSheetVC: UIViewController {

var backgroundTapAction: (() -> Void)?
var completeButtonTapAction: ((String) -> Void)?
var courseName: String?

private let titleNameMaxLength = 20
private let bottomHeight: CGFloat = 206
Expand Down Expand Up @@ -142,6 +143,12 @@ extension CustomBottomSheetVC {
backgroundView.snp.makeConstraints {
$0.edges.equalToSuperview()
}

if let courseName = self.courseName {
self.bottomSheetTextField.text = courseName
self.completeButton.isEnabled = true
self.changeTextFieldLayerColor(true)
}
Comment on lines +146 to +151
Copy link
Collaborator

@thingineeer thingineeer Mar 22, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

기존에 작성하던 문구 보이게 하는 거 너무 좋아요
제가 놓친 부분인데 잘 캐치해 줘서 고마워요 👍👍
확인했습니다.

}

private func setLayout(_ type: SheetType) {
Expand Down
11 changes: 11 additions & 0 deletions Runnect-iOS/Runnect-iOS/Network/Service/Providers.swift
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,17 @@ struct Providers {
static let stampProvider = MoyaProvider<StampRouter>(withAuth: true)
}

struct Provider {
static let departureSearchingProvider = NetworkProvider<DepartureSearchingRouter>(withAuth: false)
static let authProvider = NetworkProvider<AuthRouter>(withAuth: true)
static let userProvider = NetworkProvider<UserRouter>(withAuth: true)
static let courseProvider = NetworkProvider<CourseRouter>(withAuth: true)
static let publicCourseProvider = NetworkProvider<PublicCourseRouter>(withAuth: true)
static let recordProvider = NetworkProvider<RecordRouter>(withAuth: true)
static let scrapProvider = NetworkProvider<ScrapRouter>(withAuth: true)
static let stampProvider = NetworkProvider<StampRouter>(withAuth: true)
}

extension MoyaProvider {
convenience init(withAuth: Bool) {
if withAuth {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,9 @@ import Then
final class CourseStorageVC: UIViewController {

// MARK: - Properties
private let courseProvider = Providers.courseProvider
private let courseProvider = Provider.courseProvider

private let scrapProvider = Providers.scrapProvider
private let scrapProvider = Provider.scrapProvider

private let cancelBag = CancelBag()

Expand Down Expand Up @@ -270,105 +270,61 @@ extension CourseStorageVC: PrivateCourseListViewDelegate {
extension CourseStorageVC {
private func getPrivateCourseList() {
LoadingIndicator.showLoading()
courseProvider.request(.getAllPrivateCourse) { [weak self] response in
guard let self = self else { return }

courseProvider.request(
target: .getAllPrivateCourse,
instance: BaseResponse<PrivateCourseResponseDto>.self,
vc: self
) { response in
LoadingIndicator.hideLoading()
switch response {
case .success(let result):
let status = result.statusCode
if 200..<300 ~= status {
do {
let responseDto = try result.map(BaseResponse<PrivateCourseResponseDto>.self)
guard let data = responseDto.data else { return }
self.setPrivateCourseData(courseList: data.courses)
} catch {
print(error.localizedDescription)
}
}
if status >= 400 {
print("400 error")
self.showNetworkFailureToast()
}
case .failure(let error):
print(error.localizedDescription)
self.showNetworkFailureToast()
}

guard let data = response.data else { return }
self.setPrivateCourseData(courseList: data.courses)
}
}

private func getScrapCourseList() {
LoadingIndicator.showLoading()
scrapProvider.request(.getScrapCourse) { [weak self] response in
guard let self = self else { return }

scrapProvider.request(
target: .getScrapCourse,
instance: BaseResponse<ScrapCourseResponseDto>.self,
vc: self
) { response in
LoadingIndicator.hideLoading()
switch response {
case .success(let result):
let status = result.statusCode
if 200..<300 ~= status {
do {
let responseDto = try result.map(BaseResponse<ScrapCourseResponseDto>.self)
guard let data = responseDto.data else { return }
self.setScrapCourseData(courseList: data.scraps)
} catch {
print(error.localizedDescription)
}
}
if status >= 400 {
print("400 error")
self.showNetworkFailureToast()
}
case .failure(let error):
print(error.localizedDescription)
self.showNetworkFailureToast()
}

guard let data = response.data else { return }
self.setScrapCourseData(courseList: data.scraps)
}
}

private func scrapCourse(publicCourseId: Int, scrapTF: Bool) {
LoadingIndicator.showLoading()
scrapProvider.request(.createAndDeleteScrap(publicCourseId: publicCourseId, scrapTF: scrapTF)) { [weak self] response in

scrapProvider.request(
target: .createAndDeleteScrap(publicCourseId: publicCourseId, scrapTF: scrapTF),
instance: BaseResponse<BlankData>.self,
vc: self
) { response in
LoadingIndicator.hideLoading()
guard let self = self else { return }
switch response {
case .success(let result):
let status = result.statusCode
if 200..<300 ~= status {
self.getScrapCourseList()
}
if status >= 400 {
print("400 error")
self.showNetworkFailureToast()
}
case .failure(let error):
print(error.localizedDescription)
self.showNetworkFailureToast()
}

self.getScrapCourseList()
}
}

private func deleteCourse(courseIdList: [Int]) {
LoadingIndicator.showLoading()
courseProvider.request(.deleteCourse(courseIdList: courseIdList)) { [weak self] response in

courseProvider.request(
target: .deleteCourse(courseIdList: courseIdList),
instance: BaseResponse<BlankData>.self,
vc: self
) { response in
LoadingIndicator.hideLoading()
guard let self = self else { return }

self.privateCourseListView.isEditMode = false
switch response {
case .success(let result):
print("리절트", result)
let status = result.statusCode
if 200..<300 ~= status {
print("삭제 성공")
self.getPrivateCourseList()
self.finishEditMode(withDuration: 0.7)
}
if status >= 400 {
print("400 error")
self.showNetworkFailureToast()
}
case .failure(let error):
print(error.localizedDescription)
self.showNetworkFailureToast()
}
self.getPrivateCourseList()
self.finishEditMode(withDuration: 0.7)
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -316,6 +316,7 @@ extension RunningWaitingVC {
let status = result.statusCode
if 200..<300 ~= status {
print("삭제 성공")
self.navigationController?.popViewController(animated: true)
Copy link
Collaborator

@thingineeer thingineeer Mar 22, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

이 부분이 pop 순서를 바꿔준 거 군요! 🫠
아니면 댓글 달아주세요~!
확인했습니다.

}
if status >= 400 {
print("400 error")
Expand Down Expand Up @@ -377,7 +378,6 @@ extension RunningWaitingVC {
deleteAlertVC.rightButtonTapAction = {
deleteAlertVC.dismiss(animated: false)
self.deleteCourse()
self.navigationController?.popViewController(animated: true)
}
self.present(deleteAlertVC, animated: false)
default:
Expand All @@ -389,6 +389,7 @@ extension RunningWaitingVC {
private func ModifyCourseTitle() {
let bottomSheetVC = CustomBottomSheetVC(type: .textField)
bottomSheetVC.modalPresentationStyle = .overFullScreen
bottomSheetVC.courseName = self.courseTitle
bottomSheetVC.completeButtonTapAction = { [weak self] text in
guard let self = self else { return }
guard handleVisitor() else { return }
Expand Down