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

[둘리] 3, 4단계 영화 극장 선택 제출합니다. #31

Merged
merged 90 commits into from
May 9, 2023
Merged
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
90 commits
Select commit Hold shift + click to select a range
c75c7cc
refactor(AlarmController, AlarmReceiver): 중복 코드 제거, scope function 사용 수정
hyemdooly Apr 29, 2023
af1eb2c
refactor(MovieListFragment): Mock이 아닌 인터페이스로 타입 수정
hyemdooly Apr 29, 2023
03aed6f
feat(SettingDataManager): Setting값을 관리하는 인터페이스, 프리퍼런스를 관리하는 클래스 구현
hyemdooly Apr 29, 2023
35e4978
feat(AlarmController): 채널 관리, 알람 설정 AlarmController로 함수 이동
hyemdooly Apr 29, 2023
af6ad6c
refactor(MovieMainActivity): TAG 상수 위치 이동
hyemdooly Apr 30, 2023
29edef5
refactor(MovieMainActivityTest): 프래그먼트 자체를 확인하는 직관적인 테스트 코드로 변경
hyemdooly Apr 30, 2023
bb6cca9
feat(SettingFragmentTest): UI 중심으로 프래그먼트 테스트 재작성 (토글값 유지)
hyemdooly Apr 30, 2023
b95885c
refactor(SettingFragment): MVP 리팩터링
hyemdooly May 2, 2023
a3fb3df
feat(AlarmManageable): AlarmController의 인터페이스 생성
hyemdooly May 2, 2023
163fb80
refactor(SettingPresenter, SettingContract): MVP 리팩터링, 추상화
hyemdooly May 2, 2023
77d3cc2
refactor(ReservationListFragment): MVP 리팩터링
hyemdooly May 2, 2023
42ef79c
refactor(MovieListFragment): MVP 리팩터링
hyemdooly May 3, 2023
de04d9b
refactor(ReservationActivity): 패키지명 변경
hyemdooly May 3, 2023
fc72a83
refactor(Movie): 로직 도메인 로직으로 이동
hyemdooly May 3, 2023
f36a118
refactor(Ktlint): KtlintFormat
hyemdooly May 3, 2023
11e4cc5
refactor(ReservationActivity): MVP 리팩터링
hyemdooly May 3, 2023
ceb7db9
refactor(package): 패키지명 변경
hyemdooly May 3, 2023
65b95f1
refactor(domain, SeatSelectionAcitivty): 도메인, 좌석 지정 코드 전체 리팩터링
hyemdooly May 3, 2023
7ef5f63
refactor(domain, SeatSelectionAcitivty): 도메인, 좌석 지정 코드 전체 리팩터링
hyemdooly May 4, 2023
cddae6d
refactor(SeatSelectionActivity): MVP 리팩터링
hyemdooly May 4, 2023
a77b368
feat(Theater): 극장 정보 클래스 생성
hyemdooly May 4, 2023
72f31b4
refactor(Movie, ScreeningDateTimes): Movie 프로퍼티 변경, ScreeningDateTime…
hyemdooly May 4, 2023
877910d
refactor(MovieListFragment): MovieListFragment 리팩터링
hyemdooly May 4, 2023
08e3b4d
refactor(ReservationActivityTest, SeatSelectionActivityTest): 리팩터링에 따…
hyemdooly May 4, 2023
7d5e406
refactor(ReservationCompletedActivity): 예약 확정 액티비티 MVP 리팩터링
hyemdooly May 4, 2023
7e57cc1
refactor(SettingFragment): 세팅 화면 리팩터링
hyemdooly May 4, 2023
20cf636
refactor(domain): 영화관 상영 정보 추가에 따른 도메인 구조 변경
hyemdooly May 4, 2023
8ddcb4b
refactor(Movie, Schedule): Schedule 클래스 생성, Movie 프로퍼티 변경
hyemdooly May 5, 2023
ba9cd66
refactor(MovieUiModel, MoviePosterRepository): MovieUiModel, MoviePos…
hyemdooly May 5, 2023
ef15f75
refactor(Movie, Schedule): 도메인 모델 구조 변경
hyemdooly May 5, 2023
7fb897e
feat(TheaterBottomSheetFragment): 극장 선택 구현
hyemdooly May 5, 2023
a4225fd
feat(ReservationActivity): 도메인 모델 수정에 따른 수정
hyemdooly May 5, 2023
0f0ace2
refactor(ReservationActivity): 확장함수 정의로 인한 리팩터링
hyemdooly May 5, 2023
c2f8181
fix(ReservationPresenter): 카운터 초기값 0 -> 1 수정
hyemdooly May 5, 2023
4addfaf
refactor(SeatSelectionActivity): 극장 정보 추가에 따른 리팩터링 및 추가 구현
hyemdooly May 5, 2023
417b7f9
feat(ReservationCompleted): 예매 완료 화면 극장 정보 추가 구현
hyemdooly May 5, 2023
8a17d92
refactor(TheaterMockRepository, MovieMockRepository): 아주 긴 극장 이름 확인용 …
hyemdooly May 5, 2023
b90ce79
feat(ReservationDbRepository): 데이터베이스 구현
hyemdooly May 6, 2023
20eb29d
test(ReservationActivityTest, SeatSelectionActivityTest): 도메인 모델 수정에 …
hyemdooly May 6, 2023
3278e8f
refactor(MovieListPresenter): Repository 추상화 의존성 주입, 패키지명 변경
hyemdooly May 6, 2023
5ee3bdc
test(MovieListPresenterTest): MovieListPresenterTest 구현
hyemdooly May 6, 2023
09c3ba2
test(ReservationListPresenterTest): ReservationListPresenterTest 구현
hyemdooly May 6, 2023
3a43ad8
test(ReservationPresenterTest): ReservationPresenterTest 구현
hyemdooly May 6, 2023
009cb87
test(SettingPresenterTest): SettingPresenterTest 구
hyemdooly May 6, 2023
11b2fc7
test(ReservationCompletedPresenterTest): ReservationCompletedPresente…
hyemdooly May 6, 2023
81644ee
test(SeatSelectionPresenterTest): SeatSelectionPresenterTest 구현
hyemdooly May 6, 2023
a64f78e
refactor(SeatSelectionActivity): 필요없는 전역 변수 삭제
hyemdooly May 6, 2023
4815484
refactor(MovieListAdapter): 로그 삭제
hyemdooly May 6, 2023
2611794
refactor(ReservationActivity): 데이터 바인딩 적용
hyemdooly May 6, 2023
3872943
refactor(SeatSelectionActivity): 데이터 바인딩 적용
hyemdooly May 6, 2023
7a0d10e
refactor(ReservationCompletedActivity): 데이터 바인딩 수정
hyemdooly May 6, 2023
7acb0dd
refactor(ReservationActivity): 데이터 바인딩 수정
hyemdooly May 6, 2023
c029161
fix(ReservationDbHelper): split 후 공백 제거
hyemdooly May 6, 2023
86d71bc
refactor(SettingFragment): 데이터 바인딩 적용
hyemdooly May 6, 2023
b6898a7
refactor(MovieListFragment): 데이터 바인딩 적용
hyemdooly May 6, 2023
aff53ce
refactor(TheaterItemViewHolder): 데이터 바인딩 적용
hyemdooly May 6, 2023
a093d1f
refactor(ReservationItemViewHolder): 데이터 바인딩 적용
hyemdooly May 6, 2023
ca87506
refactor(package): test 코드 패키지 이동
hyemdooly May 6, 2023
89b67a2
refactor(PriceSystem): 변수명 통일
hyemdooly May 6, 2023
809e9ae
refactor(package): 패키지 이동, 클래스명 일관성 통일
hyemdooly May 7, 2023
c032ff1
refactor(TheaterMockRepository): requireNotNull 예외처리 적용, 변수 private 변경
hyemdooly May 7, 2023
85205af
refactor(AlarmController): createChannel 함수 private으로 변경
hyemdooly May 7, 2023
131943e
refactor(MovieUiModel): typealias 적용
hyemdooly May 7, 2023
24ece77
refactor(SeatInfoUiModel): 변수명 변경
hyemdooly May 7, 2023
eedd691
refactor(MovieListFragment): MVP 리팩터링
hyemdooly May 7, 2023
14b5219
refactor(ReservationListFragment): MVP 리팩터링
hyemdooly May 7, 2023
3e8df05
refactor(SettingFragment): 필요없는 전역변수 삭제
hyemdooly May 7, 2023
a800192
refactor(SettingFragment): 프로퍼티 최상단으로 이동
hyemdooly May 7, 2023
8add901
refactor(ReservationCompletedActivity): 프로퍼티 최상단으로 이동
hyemdooly May 7, 2023
7ac96e4
refactor(SettingFragment): 인터페이스에서 필요 없는 프로퍼티 삭제
hyemdooly May 7, 2023
6cf0f67
refactor(SettingFragment): 네이밍 변경
hyemdooly May 7, 2023
8582463
refactor(Price): DecimalFormatter 추가 및 수정
hyemdooly May 8, 2023
28b61b8
refactor(ReservationActivity): MVP 리팩터링
hyemdooly May 8, 2023
97afbfe
refactor(SettingFragment): 네이밍 수정
hyemdooly May 8, 2023
3daba24
refactor(SeatSelectinActivity): MVP 리팩터링
hyemdooly May 8, 2023
7bb5bbf
refactor(MovieListAdapter): Inflate 코드 ItemViewHolder 내부로 이동
hyemdooly May 8, 2023
cc79d53
refactor(MapExtension): getKeyFromIndex 함수 제거
hyemdooly May 8, 2023
9a66f21
refactor(Fragments): Fragment가 직접 Fragment를 던지도록 수정
hyemdooly May 8, 2023
b8d4cf1
test(all): 테스트 코드 리팩터링 및 수정으로 인한 코드 변경
hyemdooly May 8, 2023
75e71b5
refactor(MoviePosterRepository): 변경이 적은 코드로 수정
hyemdooly May 8, 2023
a91744a
refactor(SeatSelectionActivity): 프레젠터에서 색상 정보를 제공하도록 변경
hyemdooly May 8, 2023
be39dac
refactor(SeatSelectionActivity): println 삭제, deprecated된 코드 수정
hyemdooly May 8, 2023
b00fa38
fix(SeatSelectionPresenterTest): 테스트 실패 수정
hyemdooly May 8, 2023
ea76ff9
refactor(TheaterMockRepository): requireNotNull 코드 수정
hyemdooly May 8, 2023
c3762e0
refactor(PriceMapper): PriceMapper 삭제
hyemdooly May 8, 2023
ca2af29
refactor(Contract.View): 인터페이스에서 presenter 변수 삭제
hyemdooly May 8, 2023
f39ff1f
refactor(MovieListFragment): presenter 초기화 코드 위치 변경
hyemdooly May 8, 2023
7fb4fbc
refactor(ReservationActivity): 함수 네이밍 변경
hyemdooly May 9, 2023
ed2b736
refactor(TheaterBottomSheetFragment): Bundle로 값을 넘겨주는 방식으로 수정
hyemdooly May 9, 2023
631ecbf
refactor(SeatSelectActivity): SeatInfo 삭제, Theater로 프로퍼티 이동, Presente…
hyemdooly May 9, 2023
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

This file was deleted.

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@ package woowacourse.movie.data.setting

import android.content.Context
import androidx.preference.PreferenceManager
import woowacourse.movie.domain.repository.SettingRepository

class SettingPreferencesManager(context: Context) : SettingDataManager {
class SettingPreferencesRepository(context: Context) : SettingRepository {
private val sharedPreferences = PreferenceManager.getDefaultSharedPreferences(context)
override fun getIsAlarmSetting(): Boolean = sharedPreferences.getBoolean(IS_ALARM_ON, false)
override fun setIsAlarmSetting(isOn: Boolean) {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
package woowacourse.movie.data.theater

import woowacourse.movie.R
import woowacourse.movie.domain.policy.MorningPolicy
import woowacourse.movie.domain.policy.MovieDayPolicy
import woowacourse.movie.domain.policy.NightPolicy
Expand All @@ -25,24 +24,20 @@ object TheaterMockRepository : TheaterRepository {
NightPolicy(),
)

val theaters: List<Theater> = listOf(
private val theaters: List<Theater> = listOf(
Theater("정말아주아주아주아주아주아주아주긴극장이름", seatInfo, policies),
Theater("선릉 극장", seatInfo, policies),
Theater("잠실 극장", seatInfo, policies),
Theater("강남 극장", seatInfo, policies),
)

val gradeColor = mapOf(
Grade.B to R.color.seat_rank_b,
Grade.S to R.color.seat_rank_s,
Grade.A to R.color.seat_rank_a,
)

override fun findAll(): List<Theater> {
return theaters
}

override fun findTheater(name: String): Theater {
return theaters.find { it.name == name } ?: throw java.lang.IllegalArgumentException("존재하지 않는 상영관입니다.")
val theater = theaters.find { it.name == name }
requireNotNull(theater) { "존재하지 않는 상영관입니다." }
laco-dev marked this conversation as resolved.
Show resolved Hide resolved
return theater
}
}
5 changes: 5 additions & 0 deletions app/src/main/java/woowacourse/movie/util/DecimalFormatter.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
package woowacourse.movie.util

import java.text.DecimalFormat

val DECIMAL_FORMAT = DecimalFormat("#,###")
4 changes: 0 additions & 4 deletions app/src/main/java/woowacourse/movie/util/MapExtension.kt
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,3 @@ package woowacourse.movie.util
fun <T, K> Map<T, List<K>>.getOrEmptyList(key: T): List<K> {
return this[key] ?: emptyList<K>()
}

fun <T, K> Map<T, K>.getKeyFromIndex(index: Int): T {
return keys.toList()[index]
}
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ class AlarmController(private val context: Context) {
alarmManager.cancel(pendingIntent)
}

fun createChannel() {
private fun createChannel() {
val channel = NotificationChannel(AlarmReceiver.CHANNEL_ID, CHANNER_NAME, NotificationManager.IMPORTANCE_DEFAULT)
val notificationManager = context.getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
if (!notificationManager.notificationChannels.contains(channel)) notificationManager.createNotificationChannel(channel)
Expand Down
13 changes: 10 additions & 3 deletions app/src/main/java/woowacourse/movie/view/mapper/MovieMapper.kt
Original file line number Diff line number Diff line change
@@ -1,15 +1,22 @@
package woowacourse.movie.view.mapper

import androidx.annotation.DrawableRes
import woowacourse.movie.R
import woowacourse.movie.domain.movie.Movie
import woowacourse.movie.view.model.MovieUiModel

fun Movie.toUiModel(@DrawableRes posterResourceId: Int): MovieUiModel = MovieUiModel(
val posters = mapOf(
"스즈메의 문단속" to R.drawable.suzume_poster,
"해리 포터와 마법사의 돌" to R.drawable.harry_potter1_poster,
"스타워즈" to R.drawable.starwars_poster,
"어벤져스: 엔드게임" to R.drawable.avengers_endgame_poster,
)

fun Movie.toUiModel(): MovieUiModel = MovieUiModel(
title,
startDate,
endDate,
runningTime.value,
posterResourceId,
posters[title] ?: 0,
summary,
schedule.schedule,
)
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
package woowacourse.movie.view.mapper

import woowacourse.movie.domain.price.Price
import java.text.DecimalFormat

fun Price.toUiModel(): String {
return DecimalFormat("#,###").format(price)
fun Price.toUiModel(): Int {
return price
laco-dev marked this conversation as resolved.
Show resolved Hide resolved
}
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
package woowacourse.movie.view.mapper

import androidx.annotation.ColorInt
import woowacourse.movie.domain.system.Seat
import woowacourse.movie.view.model.SeatUiModel

fun Seat.toUiModel(): SeatUiModel = SeatUiModel(row, col)
fun Seat.toUiModel(@ColorInt color: Int = 0): SeatUiModel = SeatUiModel(row, col, color)
fun SeatUiModel.toDomain(): Seat = Seat(row, col)
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@ import kotlinx.parcelize.Parcelize
import java.time.LocalDate
import java.time.LocalTime

typealias TheaterName = String
typealias ScreeningTimes = List<LocalTime>

@Parcelize
data class MovieUiModel(
val title: String,
Expand All @@ -13,5 +16,5 @@ data class MovieUiModel(
val runningTime: Int,
val posterResourceId: Int,
val summary: String,
val schedule: Map<String, List<LocalTime>>,
val schedule: Map<TheaterName, ScreeningTimes>,
) : Parcelable
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
package woowacourse.movie.view.model

class SeatInfoUiModel(val row: Int, val col: Int, val colorOfRow: Map<Int, Int>)
typealias row = Int
typealias colorId = Int
data class SeatInfoUiModel(val maxRow: Int, val maxCol: Int, val colorOfRow: Map<row, colorId>)
laco-dev marked this conversation as resolved.
Show resolved Hide resolved
7 changes: 4 additions & 3 deletions app/src/main/java/woowacourse/movie/view/model/SeatUiModel.kt
Original file line number Diff line number Diff line change
@@ -1,17 +1,18 @@
package woowacourse.movie.view.model

import android.os.Parcelable
import androidx.annotation.ColorRes
import kotlinx.parcelize.Parcelize

@Parcelize
class SeatUiModel(val row: Int, val col: Int) : Parcelable {
class SeatUiModel(val row: Int, val col: Int, @ColorRes val color: Int) : Parcelable {
val seatId: String = ('A'.code + row).toChar() + (col + 1).toString()

companion object {
fun of(seatId: String): SeatUiModel {
fun of(seatId: String, @ColorRes color: Int = 0): SeatUiModel {
val row = seatId[0].code - 'A'.code
val col = seatId.substring(1).toInt() - 1
return SeatUiModel(row, col)
return SeatUiModel(row, col, color)
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -23,18 +23,18 @@ class MovieMainActivity : AppCompatActivity() {
navigation.setOnItemSelectedListener { item ->
when (item.itemId) {
R.id.action_reservation_list -> {
val fragment = supportFragmentManager.findFragmentByTag(TAG_RESERVATION_LIST) as? ReservationListFragment ?: ReservationListFragment().also { addFragment(it, TAG_RESERVATION_LIST) }
replaceFragment(fragment)
val fragment = ReservationListFragment.of(supportFragmentManager)
replaceFragment(fragment, TAG_RESERVATION_LIST)
return@setOnItemSelectedListener true
}
R.id.action_home -> {
val fragment = supportFragmentManager.findFragmentByTag(TAG_MOVIE_LIST) as? MovieListFragment ?: MovieListFragment().also { addFragment(it, TAG_MOVIE_LIST) }
replaceFragment(fragment)
val fragment = MovieListFragment.of(supportFragmentManager)
replaceFragment(fragment, TAG_MOVIE_LIST)
return@setOnItemSelectedListener true
}
R.id.action_setting -> {
val fragment = supportFragmentManager.findFragmentByTag(TAG_SETTING) as? SettingFragment ?: SettingFragment().also { addFragment(it, TAG_SETTING) }
replaceFragment(fragment)
val fragment = SettingFragment.of(supportFragmentManager)
replaceFragment(fragment, TAG_SETTING)
return@setOnItemSelectedListener true
}
else -> return@setOnItemSelectedListener false
Expand All @@ -43,10 +43,10 @@ class MovieMainActivity : AppCompatActivity() {
navigation.selectedItemId = R.id.action_home
}

private fun replaceFragment(fragment: Fragment) {
private fun replaceFragment(fragment: Fragment, tag: String) {
supportFragmentManager.commit {
setReorderingAllowed(true)
replace(R.id.fragment_container_view, fragment)
replace(R.id.fragment_container_view, fragment, tag)
}
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
package woowacourse.movie.view.moviemain.movielist

import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.annotation.DrawableRes
import androidx.recyclerview.widget.RecyclerView
import woowacourse.movie.R
Expand All @@ -10,7 +12,8 @@ import woowacourse.movie.util.DATE_FORMATTER
import woowacourse.movie.view.model.MovieUiModel

sealed class ItemViewHolder(view: View) : RecyclerView.ViewHolder(view) {
class MovieItemViewHolder(private val binding: MovieItemBinding) : ItemViewHolder(binding.root) {
class MovieItemViewHolder(private val binding: MovieItemBinding) :
ItemViewHolder(binding.root) {
fun set(movie: MovieUiModel, onClick: MovieListAdapter.OnItemClick) {
val context = binding.movieTitle.context
binding.movie = movie
Expand All @@ -29,4 +32,14 @@ sealed class ItemViewHolder(view: View) : RecyclerView.ViewHolder(view) {
binding.adImageview.setImageResource(resId)
}
}

companion object {
fun of(parent: ViewGroup, type: ListViewType): ItemViewHolder {
val view = LayoutInflater.from(parent.context).inflate(type.id, parent, false)
return when (type) {
ListViewType.NORMAL_VIEWTYPE -> MovieItemViewHolder(MovieItemBinding.bind(view))
ListViewType.AD_VIEWTYPE -> AdItemViewHolder(MovieAdItemBinding.bind(view))
}
}
}
}
Original file line number Diff line number Diff line change
@@ -1,11 +1,8 @@
package woowacourse.movie.view.moviemain.movielist

import android.view.LayoutInflater
import android.view.ViewGroup
import androidx.recyclerview.widget.RecyclerView
import woowacourse.movie.R
import woowacourse.movie.databinding.MovieAdItemBinding
import woowacourse.movie.databinding.MovieItemBinding
import woowacourse.movie.view.model.MovieUiModel

class MovieListAdapter(
Expand All @@ -19,16 +16,7 @@ class MovieListAdapter(
}

override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): RecyclerView.ViewHolder {
return when (ListViewType.values()[viewType]) {
ListViewType.NORMAL_VIEWTYPE -> {
val view = LayoutInflater.from(parent.context).inflate(ListViewType.NORMAL_VIEWTYPE.id, parent, false)
ItemViewHolder.MovieItemViewHolder(MovieItemBinding.bind(view))
}
ListViewType.AD_VIEWTYPE -> {
val view = LayoutInflater.from(parent.context).inflate(ListViewType.AD_VIEWTYPE.id, parent, false)
ItemViewHolder.AdItemViewHolder(MovieAdItemBinding.bind(view))
}
}
return ItemViewHolder.of(parent, ListViewType.values()[viewType])
}

override fun getItemCount(): Int = movies.size + movies.size / adInterval
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,11 @@ package woowacourse.movie.view.moviemain.movielist
import woowacourse.movie.view.model.MovieUiModel

interface MovieListContract {
interface View {
var presenter: Presenter
laco-dev marked this conversation as resolved.
Show resolved Hide resolved
fun showMovieList(movies: List<MovieUiModel>)
}
interface Presenter {
fun getMovieListData(): List<MovieUiModel>
fun fetchMovieList()
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,21 +3,24 @@ package woowacourse.movie.view.moviemain.movielist
import android.os.Bundle
import android.view.View
import androidx.fragment.app.Fragment
import androidx.fragment.app.FragmentManager
import androidx.recyclerview.widget.RecyclerView
import woowacourse.movie.R
import woowacourse.movie.data.movie.MovieMockRepository
import woowacourse.movie.data.movie.MoviePosterMockRepository
import woowacourse.movie.view.model.MovieUiModel

class MovieListFragment : Fragment(R.layout.fragment_movie_list) {
class MovieListFragment : Fragment(R.layout.fragment_movie_list), MovieListContract.View {
override var presenter: MovieListContract.Presenter = MovieListPresenter(this, MovieMockRepository)
laco-dev marked this conversation as resolved.
Show resolved Hide resolved

override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
val presenter = MovieListPresenter(MovieMockRepository, MoviePosterMockRepository)
val movies = presenter.getMovieListData()
presenter.fetchMovieList()
}

override fun showMovieList(movies: List<MovieUiModel>) {
val movieAdapter = MovieListAdapter(3, movies, ::onClick)
val movieListView = view.findViewById<RecyclerView>(R.id.movie_recyclerview)
movieListView.adapter = movieAdapter
val movieListView = view?.findViewById<RecyclerView>(R.id.movie_recyclerview)
movieListView?.adapter = movieAdapter
}

private fun onClick(item: MovieUiModel) {
Expand All @@ -28,5 +31,9 @@ class MovieListFragment : Fragment(R.layout.fragment_movie_list) {

companion object {
const val TAG_MOVIE_LIST = "MOVIE_LIST"
fun of(supportFragmentManager: FragmentManager): MovieListFragment {
return supportFragmentManager.findFragmentByTag(TAG_MOVIE_LIST) as? MovieListFragment
?: MovieListFragment()
}
}
}
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
package woowacourse.movie.view.moviemain.movielist

import woowacourse.movie.data.movie.MoviePosterRepository
import woowacourse.movie.domain.repository.MovieRepository
import woowacourse.movie.view.mapper.toUiModel
import woowacourse.movie.view.model.MovieUiModel

class MovieListPresenter(private val movieRepository: MovieRepository, private val moviePosterRepository: MoviePosterRepository) : MovieListContract.Presenter {
override fun getMovieListData(): List<MovieUiModel> {
return movieRepository.findAll()
.map { it.toUiModel(moviePosterRepository.findPoster(it.title)) }
class MovieListPresenter(
private val view: MovieListContract.View,
private val movieRepository: MovieRepository,
) : MovieListContract.Presenter {
override fun fetchMovieList() {
val movies = movieRepository.findAll()
.map { it.toUiModel() }
view.showMovieList(movies)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,14 @@ import android.view.ViewGroup
import androidx.recyclerview.widget.RecyclerView
import woowacourse.movie.R
import woowacourse.movie.databinding.TheaterItemBinding
import woowacourse.movie.util.getKeyFromIndex
import woowacourse.movie.util.getOrEmptyList
import java.time.LocalTime

class TheaterListAdapter(
private val schedule: Map<String, List<LocalTime>>,
schedule: Map<String, List<LocalTime>>,
private val onItemClick: OnItemClick,
) : RecyclerView.Adapter<TheaterItemViewHolder>() {
private val convertSchedule = schedule.toList()

fun interface OnItemClick {
fun onClick(name: String)
}
Expand All @@ -23,11 +23,10 @@ class TheaterListAdapter(
}

override fun getItemCount(): Int {
return schedule.size
return convertSchedule.size
}

override fun onBindViewHolder(holder: TheaterItemViewHolder, position: Int) {
val key = schedule.getKeyFromIndex(position)
holder.bind(key, schedule.getOrEmptyList(key))
holder.bind(convertSchedule[position].first, convertSchedule[position].second)
}
}
Loading