Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: 각종 문제점 개선 #293

Merged
merged 8 commits into from
Dec 11, 2023
2 changes: 1 addition & 1 deletion iOS/Layover/Layover/DesignSystem/LODescriptionView.swift
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
import UIKit

final class LODescriptionView: UIView {
static let descriptionWidth: CGFloat = 170
static let descriptionWidth: CGFloat = 210
static let descriptionHeight: CGFloat = 63

// MARK: - View isTouched State
Expand Down
2 changes: 1 addition & 1 deletion iOS/Layover/Layover/Network/DTOs/ReportDTO.swift
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,6 @@ import Foundation

struct ReportDTO: Codable {
let memberId: Int?
let boardID: Int
let boardId: Int
Copy link
Member

Choose a reason for hiding this comment

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

CodingKeys를 쓰면 이 id와 ID의 혼란이 조금은 나아질지도..

Copy link
Collaborator Author

@chopmozzi chopmozzi Dec 11, 2023

Choose a reason for hiding this comment

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

좋은 생각입니다. 반영할게요.

let reportType: String
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ struct DefaultPostManagerEndPointFactory: PostManagerEndPointFactory {
func reportPlaybackVideoEndpoint(boardID: Int, reportType: String) -> EndPoint<Response<ReportDTO>> {
let bodyParmeters: ReportDTO = ReportDTO(
memberId: nil,
boardID: boardID,
boardId: boardID,
reportType: reportType)

return EndPoint(
Expand Down
7 changes: 5 additions & 2 deletions iOS/Layover/Layover/Scenes/Playback/Cell/PlaybackCell.swift
Original file line number Diff line number Diff line change
Expand Up @@ -41,14 +41,17 @@ final class PlaybackCell: UICollectionViewCell {
playbackView.setDescriptionViewUI()
playbackView.profileLabel.text = post.member.username
setTagButtons(with: post.tags)
playbackView.setProfileButton(member: post.member)
playbackView.setLocationText(location: post.board.location ?? "이름 모를 곳")
memberID = nil
memberID = post.member.memberID
playbackView.profileButton.removeTarget(nil, action: nil, for: .allEvents)
playbackView.profileButton.addTarget(self, action: #selector(profileButtonDidTap), for: .touchUpInside)
}

func setProfileImageAndLocation(imageData: Data?, location: String) {
playbackView.setLocationText(location: location)
playbackView.setProfileButton(imageData: imageData)
}

func addAVPlayer(url: URL) {
playbackView.resetPlayer()
playbackView.addAVPlayer(url: url)
Expand Down
53 changes: 33 additions & 20 deletions iOS/Layover/Layover/Scenes/Playback/PlaybackInteractor.swift
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ protocol PlaybackBusinessLogic {
func moveToTagPlay(with request: PlaybackModels.MoveToRelativeView.Request)
@discardableResult
func fetchPosts() -> Task<Bool, Never>
@discardableResult
func loadProfileImageAndLocation(with request: PlaybackModels.LoadProfileImageAndLocation.Request) -> Task<Bool, Never>
}

protocol PlaybackDataStore: AnyObject {
Expand Down Expand Up @@ -84,7 +86,7 @@ final class PlaybackInteractor: PlaybackBusinessLogic, PlaybackDataStore {
posts = worker.makeInfiniteScroll(posts: posts)
self.posts = posts
}
let videos: [Models.PlaybackVideo] = await transPostToVideo(posts)
let videos: [Models.PlaybackVideo] = transPostToVideo(posts)
let response: Models.LoadPlaybackVideoList.Response = Models.LoadPlaybackVideoList.Response(videos: videos)
await MainActor.run {
presenter?.presentVideoList(with: response)
Expand Down Expand Up @@ -251,25 +253,23 @@ final class PlaybackInteractor: PlaybackBusinessLogic, PlaybackDataStore {
previousCell.playbackView.playPlayer()
}

private func transPostToVideo(_ posts: [Post]) async -> [Models.PlaybackVideo] {
return await posts.asyncCompactMap { post in
private func transPostToVideo(_ posts: [Post]) -> [Models.PlaybackVideo] {
return posts.compactMap { post in
Copy link
Collaborator

Choose a reason for hiding this comment

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

이제 여기서 이미지 로드를 기다리지 않아도 되어서 확실히 성능 향상이 있을 것 같네요
고생하셨습니다...

guard let videoURL: URL = post.board.videoURL else { return nil }
async let profileImageData = self.worker?.fetchImageData(with: post.member.profileImageURL)
async let thumbnailImageData = self.worker?.fetchImageData(with: post.board.thumbnailImageURL)
async let location = self.worker?.transLocation(latitude: post.board.latitude, longitude: post.board.longitude)
return Models.PlaybackVideo(displayPost: Models.DisplayedPost(
member: Models.Member(
memberID: post.member.identifier,
username: post.member.username,
profileImageData: await profileImageData),
board: Models.Board(
boardID: post.board.identifier,
title: post.board.title,
description: post.board.description,
thumbnailImageData: await thumbnailImageData,
videoURL: videoURL,
location: await location),
tags: post.tag))
return Models.PlaybackVideo(
displayedPost: Models.DisplayedPost(
member: Models.Member(
memberID: post.member.identifier,
username: post.member.username,
profileImageURL: post.member.profileImageURL),
board: Models.Board(
boardID: post.board.identifier,
title: post.board.title,
description: post.board.description,
videoURL: videoURL,
latitude: post.board.latitude,
longitude: post.board.longitude),
tags: post.tag))
}
}

Expand Down Expand Up @@ -314,7 +314,7 @@ final class PlaybackInteractor: PlaybackBusinessLogic, PlaybackDataStore {
}
guard let newPosts else { return false }
self.posts?.append(contentsOf: newPosts)
let videos: [Models.PlaybackVideo] = await transPostToVideo(newPosts)
let videos: [Models.PlaybackVideo] = transPostToVideo(newPosts)
let response: Models.LoadPlaybackVideoList.Response = Models.LoadPlaybackVideoList.Response(videos: videos)
await MainActor.run {
presenter?.presentLoadFetchVideos(with: response)
Expand All @@ -325,4 +325,17 @@ final class PlaybackInteractor: PlaybackBusinessLogic, PlaybackDataStore {
return false
}
}

func loadProfileImageAndLocation(with request: PlaybackModels.LoadProfileImageAndLocation.Request) -> Task<Bool, Never> {
Task {
async let profileImageData = self.worker?.fetchImageData(with: request.profileImageURL)
async let location: String? = self.worker?.transLocation(latitude: request.latitude, longitude: request.longitude)
Comment on lines +331 to +332
Copy link
Member

Choose a reason for hiding this comment

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

👍👍

let response: Models.LoadProfileImageAndLocation.Response = Models.LoadProfileImageAndLocation.Response(curCell: request.curCell, profileImageData: await profileImageData, location: await location)
await MainActor.run {
presenter?.presentLoadProfileImageAndLocation(with: response)
return true
}
return false
}
}
}
31 changes: 27 additions & 4 deletions iOS/Layover/Layover/Scenes/Playback/PlaybackModels.swift
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ enum PlaybackModels {
// MARK: - Properties Type
struct PlaybackVideo: Hashable {
var id: UUID = UUID()
let displayPost: DisplayedPost
let displayedPost: DisplayedPost
}

enum ParentView {
Expand All @@ -32,16 +32,16 @@ enum PlaybackModels {
struct Member: Hashable {
let memberID: Int
let username: String
let profileImageData: Data?
let profileImageURL: URL?
}

struct Board: Hashable {
let boardID: Int
let title: String
let description: String?
let thumbnailImageData: Data?
let videoURL: URL
let location: String?
let latitude: Double
let longitude: Double
}

// MARK: - UseCase Load Video List
Expand Down Expand Up @@ -235,4 +235,27 @@ enum PlaybackModels {

}
}

// MARK: - UseCase Load ProfileImage & Location

enum LoadProfileImageAndLocation {
struct Request {
let curCell: PlaybackCell
let profileImageURL: URL?
let latitude: Double
let longitude: Double
}

struct Response {
let curCell: PlaybackCell
let profileImageData: Data?
let location: String?
}

struct ViewModel {
let curCell: PlaybackCell
let profileImageData: Data?
let location: String
}
}
}
6 changes: 6 additions & 0 deletions iOS/Layover/Layover/Scenes/Playback/PlaybackPresenter.swift
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ protocol PlaybackPresentationLogic {
func presentDeleteVideo(with response: PlaybackModels.DeletePlaybackVideo.Response)
func presentProfile()
func presentTagPlay()
func presentLoadProfileImageAndLocation(with response: PlaybackModels.LoadProfileImageAndLocation.Response)
}

final class PlaybackPresenter: PlaybackPresentationLogic {
Expand Down Expand Up @@ -128,4 +129,9 @@ final class PlaybackPresenter: PlaybackPresentationLogic {
func presentTagPlay() {
viewController?.routeToTagPlay()
}

func presentLoadProfileImageAndLocation(with response: PlaybackModels.LoadProfileImageAndLocation.Response) {
let viewModel: Models.LoadProfileImageAndLocation.ViewModel = Models.LoadProfileImageAndLocation.ViewModel(curCell: response.curCell, profileImageData: response.profileImageData, location: response.location ?? "이름 모를 곳")
viewController?.setProfileImageAndLocation(viewModel: viewModel)
}
}
5 changes: 3 additions & 2 deletions iOS/Layover/Layover/Scenes/Playback/PlaybackView.swift
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ final class PlaybackView: UIView {
button.layer.borderColor = UIColor.layoverWhite.cgColor
button.backgroundColor = .layoverWhite
button.clipsToBounds = true
button.imageView?.contentMode = .scaleAspectFill
return button
}()

Copy link
Member

@anyukyung anyukyung Dec 11, 2023

Choose a reason for hiding this comment

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

그.. 이 이슈랑 관련된건 아니긴한데 playbackView 내부 Profile 버튼의 borderColor를
grey400으로 바까주실 수 있나여 ㅎ

Copy link
Member

Choose a reason for hiding this comment

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

흰색이 좀 튀는 너낌

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

UIButton이 아니라 Button의 이미지의 border컬러가 맞을까요?

Expand Down Expand Up @@ -201,8 +202,8 @@ final class PlaybackView: UIView {
}
}

func setProfileButton(member: PlaybackModels.Member) {
if let imageData: Data = member.profileImageData {
func setProfileButton(imageData: Data?) {
if let imageData {
profileButton.setImage(UIImage(data: imageData), for: .normal)
} else {
profileButton.setImage(UIImage.profile, for: .normal)
Expand Down
14 changes: 12 additions & 2 deletions iOS/Layover/Layover/Scenes/Playback/PlaybackViewController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ protocol PlaybackDisplayLogic: AnyObject {
func deleteVideo(viewModel: PlaybackModels.DeletePlaybackVideo.ViewModel)
func routeToProfile()
func routeToTagPlay()
func setProfileImageAndLocation(viewModel: PlaybackModels.LoadProfileImageAndLocation.ViewModel)
}

final class PlaybackViewController: BaseViewController {
Expand Down Expand Up @@ -244,14 +245,19 @@ extension PlaybackViewController: PlaybackDisplayLogic {
playbackCollectionView.register(PlaybackCell.self, forCellWithReuseIdentifier: PlaybackCell.identifier)
dataSource = UICollectionViewDiffableDataSource<Section, Models.PlaybackVideo>(collectionView: playbackCollectionView) { (collectionView, indexPath, playbackVideo) -> UICollectionViewCell? in
guard let cell = collectionView.dequeueReusableCell(withReuseIdentifier: PlaybackCell.identifier, for: indexPath) as? PlaybackCell else { return PlaybackCell() }
cell.setPlaybackContents(post: playbackVideo.displayPost)
cell.setPlaybackContents(post: playbackVideo.displayedPost)
if let teleportIndex = viewModel.teleportIndex {
if indexPath.row == 0 || indexPath.row == teleportIndex {
return cell
}
}
cell.addAVPlayer(url: playbackVideo.displayedPost.board.videoURL)
self.interactor?.loadProfileImageAndLocation(with: Models.LoadProfileImageAndLocation.Request(
curCell: cell,
profileImageURL: playbackVideo.displayedPost.member.profileImageURL,
latitude: playbackVideo.displayedPost.board.latitude,
longitude: playbackVideo.displayedPost.board.longitude))
Comment on lines +256 to +260
Copy link
Collaborator

Choose a reason for hiding this comment

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

오 확실히 이렇게 필요한 부분에서만 호출되어서 로드되면 모든 데이터를 기다리지 않게 되겠네요

cell.delegate = self
cell.addAVPlayer(url: playbackVideo.displayPost.board.videoURL)
return cell
}
}
Expand Down Expand Up @@ -298,6 +304,10 @@ extension PlaybackViewController: PlaybackDisplayLogic {
func routeToTagPlay() {
router?.routeToTagPlay()
}

func setProfileImageAndLocation(viewModel: PlaybackModels.LoadProfileImageAndLocation.ViewModel) {
viewModel.curCell.setProfileImageAndLocation(imageData: viewModel.profileImageData, location: viewModel.location)
}
}

extension PlaybackViewController: UICollectionViewDelegateFlowLayout {
Expand Down
2 changes: 1 addition & 1 deletion iOS/Layover/Layover/Scenes/Profile/ProfileInteractor.swift
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ final class ProfileInteractor: ProfileBusinessLogic, ProfileDataStore {
guard let userProfile = await userWorker?.fetchProfile(by: profileId) else {
return false
}

posts = []
Copy link
Collaborator

Choose a reason for hiding this comment

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

놓친 부분 찾아주셔서 감사합니다.
태그 재생목록에도 같은 실수를 했는데, 이건 제가 지금 테스트 코드 짜면서 수정할게요!

nickname = userProfile.username
introduce = userProfile.introduce

Expand Down
4 changes: 2 additions & 2 deletions iOS/Layover/Layover/Scenes/Report/ReportConfigurator.swift
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ final class ReportConfigurator: Configurator {
let viewController: ReportViewController = viewController
let interactor: ReportInteractor = ReportInteractor()
let presenter: ReportPresenter = ReportPresenter()
// let worker: ReportWorker = ReportWorker()
let worker: ReportWorkerProtocol = MockReportWorker()
let worker: ReportWorker = ReportWorker()
// let worker: ReportWorkerProtocol = MockReportWorker()
let router: ReportRouter = ReportRouter()

router.viewController = viewController
Expand Down
2 changes: 1 addition & 1 deletion iOS/Layover/Layover/Workers/Mocks/MockReportWorker.swift
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ final class MockReportWorker: ReportWorkerProtocol {
do {
let bodyParameters = ReportDTO(
memberId: nil,
boardID: 1,
boardId: 1,
Copy link
Collaborator

@loinsir loinsir Dec 11, 2023

Choose a reason for hiding this comment

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

엇 이건 원래대로 ID가 더 적절한 것 같습니다.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

서버에서 response주는게 저거라 ID로 해서 오류가 난 거였습니다.

Copy link
Collaborator

@loinsir loinsir Dec 11, 2023

Choose a reason for hiding this comment

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

CodingKeys...ㅋㅋㅋㅋㅋ

reportType: "청소년에게 유해한 내용입니다.")
let endPoint = EndPoint<Response<ReportDTO>>(path: "/report",
method: .POST,
Expand Down