From 0a372fb9f28a45f4ebfb6fbe66be20cf992d15d9 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Tue, 10 Dec 2024 06:35:57 +0900 Subject: [PATCH 01/13] =?UTF-8?q?[CHORE/#308]=20=ED=99=88=20=EB=B7=B0=20?= =?UTF-8?q?=EB=9D=BC=EC=9D=B4=ED=8C=85=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/terning/feature/home/HomeRoute.kt | 25 ++++++++----------- .../terning/feature/home/HomeSideEffect.kt | 1 - .../home/navigation/HometNavigation.kt | 1 - feature/home/src/main/res/values/strings.xml | 8 +++--- 4 files changed, 15 insertions(+), 20 deletions(-) diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index 9cb4c1b5..747f789d 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -57,13 +57,11 @@ import com.terning.feature.home.component.HomeUpcomingEmptyFilter import com.terning.feature.home.component.HomeUpcomingEmptyIntern import com.terning.feature.home.component.HomeUpcomingInternScreen -const val NAME_START_LENGTH = 7 -const val NAME_END_LENGTH = 12 +const val NAME_MAX_LENGTH = 5 @Composable fun HomeRoute( paddingValues: PaddingValues, - navController: NavHostController, viewModel: HomeViewModel = hiltViewModel(), navigateToCalendar: () -> Unit, navigateToIntern: (Long) -> Unit @@ -93,7 +91,6 @@ fun HomeRoute( .collect { sideEffect -> when (sideEffect) { is HomeSideEffect.ShowToast -> context.toast(sideEffect.message) - is HomeSideEffect.NavigateToHome -> navController.navigateUp() is HomeSideEffect.NavigateToCalendar -> navigateToCalendar() is HomeSideEffect.NavigateToIntern -> navigateToIntern(sideEffect.announcementId) } @@ -283,7 +280,7 @@ fun HomeScreen( ) { item { Column { - ShowMainTitleWithName(homeUserName) + ShowUpcomingTitle() ShowUpcomingIntern( homeUpcomingInternState = homeState.homeUpcomingInternState, homeState = homeState, @@ -299,7 +296,7 @@ fun HomeScreen( modifier = Modifier .background(White) ) { - ShowRecommendTitle() + ShowRecommendTitle(homeUserName) ShowInternFilter( homeFilteringInfo = homeFilteringInfo, onChangeFilterClick = { changeFilteringSheetState = true }, @@ -408,13 +405,9 @@ private fun RecommendInternItem( } @Composable -private fun ShowMainTitleWithName(userName: String) { +private fun ShowUpcomingTitle() { Text( - text = stringResource( - id = R.string.home_upcoming_title, - if (userName.length in NAME_START_LENGTH..NAME_END_LENGTH) "\n" + userName - else userName - ), + text = stringResource(id = R.string.home_upcoming_title), modifier = Modifier .padding( top = 2.dp, @@ -461,9 +454,13 @@ private fun ShowUpcomingIntern( } @Composable -private fun ShowRecommendTitle() { +private fun ShowRecommendTitle(userName: String) { Text( - text = stringResource(id = R.string.home_recommend_main_title), + text = stringResource( + id = R.string.home_recommend_main_title, + userName, + if (userName.length > NAME_MAX_LENGTH) "\n" else " " + ), style = TerningTheme.typography.title1, color = Black, modifier = Modifier diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeSideEffect.kt b/feature/home/src/main/java/com/terning/feature/home/HomeSideEffect.kt index 994850ee..6580073f 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeSideEffect.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeSideEffect.kt @@ -4,7 +4,6 @@ import androidx.annotation.StringRes sealed class HomeSideEffect { data class ShowToast(@StringRes val message: Int) : HomeSideEffect() - data object NavigateToHome : HomeSideEffect() data object NavigateToCalendar : HomeSideEffect() data class NavigateToIntern(val announcementId: Long) : HomeSideEffect() } \ No newline at end of file diff --git a/feature/home/src/main/java/com/terning/feature/home/navigation/HometNavigation.kt b/feature/home/src/main/java/com/terning/feature/home/navigation/HometNavigation.kt index 217d4cd8..04a1f989 100644 --- a/feature/home/src/main/java/com/terning/feature/home/navigation/HometNavigation.kt +++ b/feature/home/src/main/java/com/terning/feature/home/navigation/HometNavigation.kt @@ -41,7 +41,6 @@ fun NavGraphBuilder.homeNavGraph( ) { HomeRoute( paddingValues = paddingValues, - navController = navHostController, navigateToCalendar = navigateToCalendar, navigateToIntern = navigateToIntern ) diff --git a/feature/home/src/main/res/values/strings.xml b/feature/home/src/main/res/values/strings.xml index 4de5c31f..83750d3e 100644 --- a/feature/home/src/main/res/values/strings.xml +++ b/feature/home/src/main/res/values/strings.xml @@ -4,22 +4,22 @@ 서버통신에 실패했어요 - 곧 마감되는 %s님의 관심 공고 + 곧 마감되는 관심 공고 아직 스크랩된 인턴 공고가 없어요! 일주일 내에 마감인 공고가 없어요\n캘린더에서 스크랩한 공고 일정을 확인해 보세요 공고 마감 일정 확인하기 근무기간 - 내 계획에 딱 맞는 대학생 인턴 공고 + %s님에게%s딱 맞는 대학생 인턴 공고 필터링 %s년 %s월 - 필터링 설정에 일치하는 인턴 공고가 없어요! + 아직 채용중인 인턴 공고가 없어요!\n새로운 공고가 올라오면 보여드릴게요 인턴 공고가 없어요! 지금 공고 필터링을 설정하고\n내 계획에 딱 맞는 대학생 인턴 공고를 추천받아보세요! - 개의 공고가 있어요 + 설정된 필터링 정보가 없어요 기업 이미지 From 0fead01f5de4e158bdbe378599d6ef4edc6044b8 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Tue, 10 Dec 2024 06:42:30 +0900 Subject: [PATCH 02/13] =?UTF-8?q?[MOD/#308]=20=EA=B3=A7=20=EB=A7=88?= =?UTF-8?q?=EA=B0=90=20=EA=B3=B5=EA=B3=A0=20=EB=8B=A4=EC=9D=B4=EC=96=BC?= =?UTF-8?q?=EB=A1=9C=EA=B7=B8=20=EC=82=AD=EC=A0=9C=20=EB=B0=8F=20=ED=99=94?= =?UTF-8?q?=EB=A9=B4=20=EC=9D=B4=EB=8F=99=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/terning/feature/home/HomeRoute.kt | 15 ++------- .../com/terning/feature/home/HomeState.kt | 1 - .../com/terning/feature/home/HomeViewModel.kt | 6 ---- .../component/HomeUpcomingInternScreen.kt | 31 +------------------ 4 files changed, 3 insertions(+), 50 deletions(-) diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index 747f789d..036f54c1 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -114,7 +114,6 @@ fun HomeRoute( viewModel.navigateCalendar() }, updateRecommendDialogVisibility = viewModel::updateRecommendDialogVisibility, - updateUpcomingDialogVisibility = viewModel::updateUpcomingDialogVisibility, getHomeUpcomingInternList = viewModel::getHomeUpcomingInternList, getRecommendInternsData = viewModel::getRecommendInternsData, viewModel = viewModel, @@ -128,7 +127,6 @@ fun HomeScreen( navigateToIntern: (Long) -> Unit, navigateToCalendar: () -> Unit, updateRecommendDialogVisibility: (Boolean) -> Unit, - updateUpcomingDialogVisibility: (Boolean) -> Unit, getHomeUpcomingInternList: () -> Unit, getRecommendInternsData: (Int, Int?, Int?) -> Unit, viewModel: HomeViewModel, @@ -283,11 +281,8 @@ fun HomeScreen( ShowUpcomingTitle() ShowUpcomingIntern( homeUpcomingInternState = homeState.homeUpcomingInternState, - homeState = homeState, - navigateToIntern = { navigateToIntern(it) }, + navigateToIntern = navigateToIntern, navigateToCalendar = navigateToCalendar, - updateUpcomingDialogVisibility = updateUpcomingDialogVisibility, - getHomeUpcomingInternList = getHomeUpcomingInternList, ) } } @@ -423,11 +418,8 @@ private fun ShowUpcomingTitle() { @Composable private fun ShowUpcomingIntern( homeUpcomingInternState: UiState, - homeState: HomeState, navigateToIntern: (Long) -> Unit, navigateToCalendar: () -> Unit, - updateUpcomingDialogVisibility: (Boolean) -> Unit, - getHomeUpcomingInternList: () -> Unit, ) { when (homeUpcomingInternState) { is UiState.Success -> { @@ -440,10 +432,7 @@ private fun ShowUpcomingIntern( else -> HomeUpcomingInternScreen( internList = homeUpcomingInternDetail, - homeState = homeState, - updateUpcomingDialogVisibility = updateUpcomingDialogVisibility, - getHomeUpcomingInternList = getHomeUpcomingInternList, - navigateToIntern = navigateToIntern + navigateToIntern = navigateToIntern, ) } } diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeState.kt b/feature/home/src/main/java/com/terning/feature/home/HomeState.kt index de563b9b..1f0ca01c 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeState.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeState.kt @@ -13,7 +13,6 @@ data class HomeState( val homeFilteringInfoState: UiState = UiState.Loading, val homeUpcomingInternState: UiState = UiState.Empty, val homeRecommendInternState: UiState = UiState.Loading, - val homeUpcomingDialogVisibility: Boolean = false, val homeRecommendDialogVisibility: Boolean = false, val homeInternModel: HomeRecommendIntern.HomeRecommendInternDetail? = null, ) diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt b/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt index 801bea8b..57dbe67e 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt @@ -115,12 +115,6 @@ class HomeViewModel @Inject constructor( } } - fun updateUpcomingDialogVisibility(visibility: Boolean) { - _homeState.update { - it.copy(homeUpcomingDialogVisibility = visibility) - } - } - fun updateRecommendDialogVisibility(visibility: Boolean) { _homeState.update { it.copy(homeRecommendDialogVisibility = visibility) diff --git a/feature/home/src/main/java/com/terning/feature/home/component/HomeUpcomingInternScreen.kt b/feature/home/src/main/java/com/terning/feature/home/component/HomeUpcomingInternScreen.kt index 8562ccaa..eb9896ea 100644 --- a/feature/home/src/main/java/com/terning/feature/home/component/HomeUpcomingInternScreen.kt +++ b/feature/home/src/main/java/com/terning/feature/home/component/HomeUpcomingInternScreen.kt @@ -51,15 +51,8 @@ import com.terning.feature.home.R @Composable fun HomeUpcomingInternScreen( internList: List, - homeState: HomeState, navigateToIntern: (Long) -> Unit, - updateUpcomingDialogVisibility: (Boolean) -> Unit, - getHomeUpcomingInternList: () -> Unit, ) { - var selectedInternItem: HomeUpcomingIntern.HomeUpcomingInternDetail? by remember { - mutableStateOf(null) - } - val amplitudeTracker = LocalTracker.current LazyRow( @@ -90,8 +83,7 @@ fun HomeUpcomingInternScreen( type = EventType.CLICK, name = "remind_intern_card" ) - selectedInternItem = homeUpcomingIntern - updateUpcomingDialogVisibility(true) + navigateToIntern(homeUpcomingIntern.internshipAnnouncementId) }, verticalArrangement = Arrangement.SpaceBetween, ) { @@ -165,25 +157,4 @@ fun HomeUpcomingInternScreen( ) } } - - if (homeState.homeUpcomingDialogVisibility) { - val upcomingIntern = selectedInternItem - with(upcomingIntern) { - if (this != null) { - ScrapDialog( - title = title, - scrapColor = Color(android.graphics.Color.parseColor(color)), - deadline = deadline, - startYearMonth = startYearMonth, - workingPeriod = workingPeriod, - internshipAnnouncementId = internshipAnnouncementId, - companyImage = companyImage, - isScrapped = isScrapped, - onDismissRequest = { updateUpcomingDialogVisibility(false) }, - onClickChangeColor = getHomeUpcomingInternList, - onClickNavigateButton = { navigateToIntern(internshipAnnouncementId) } - ) - } - } - } } From b63f3ac3c3fbc44752e9f34b579327af9a7e1591 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Tue, 17 Dec 2024 10:38:21 +0900 Subject: [PATCH 03/13] =?UTF-8?q?[MOD/#308]=20=EA=B3=B5=EA=B3=A0=20?= =?UTF-8?q?=EC=A7=80=EC=9B=90=20=EB=A7=88=EA=B0=90=20=EC=8B=9C=20=EA=B3=B5?= =?UTF-8?q?=EA=B3=A0=20=EC=95=84=EC=9D=B4=ED=85=9C=20=EC=83=89=EC=83=81=20?= =?UTF-8?q?=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../designsystem/component/item/InternItem.kt | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItem.kt b/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItem.kt index 96c370bc..6746715a 100644 --- a/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItem.kt +++ b/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItem.kt @@ -16,7 +16,9 @@ import androidx.compose.material3.Text import androidx.compose.runtime.Composable import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier +import androidx.compose.ui.draw.alpha import androidx.compose.ui.draw.clip +import androidx.compose.ui.graphics.Color import androidx.compose.ui.layout.ContentScale import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.platform.LocalDensity @@ -30,7 +32,8 @@ import coil3.compose.AsyncImage import coil3.request.ImageRequest import com.terning.core.designsystem.R import com.terning.core.designsystem.extension.noRippleClickable -import com.terning.core.designsystem.theme.Grey300 +import com.terning.core.designsystem.theme.Black +import com.terning.core.designsystem.theme.Grey350 import com.terning.core.designsystem.theme.Grey400 import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.TerningPointTheme @@ -60,6 +63,7 @@ fun InternItem( scrapId: Long = 0, onScrapButtonClicked: (Long) -> Unit = {}, ) { + val isApplyClosed = dateDeadline == stringResource(id = R.string.intern_apply_closed) Row( modifier = modifier .fillMaxWidth() @@ -77,6 +81,10 @@ fun InternItem( .fillMaxHeight() .aspectRatio(1f) .clip(RoundedCornerShape(5.dp)) + .then( + if (isApplyClosed) Modifier.alpha(0.5f) + else Modifier + ) ) Column( @@ -87,11 +95,12 @@ fun InternItem( Text( text = dateDeadline, style = TerningTheme.typography.detail0, - color = if (dateDeadline == stringResource(id = R.string.intern_apply_closed)) Grey300 else TerningMain, + color = if (isApplyClosed) Grey350 else TerningMain, ) TwoLineHeightText( text = title, style = TerningTheme.typography.title5, + color = if (isApplyClosed) Grey350 else Black, ) @@ -103,13 +112,13 @@ fun InternItem( Text( text = stringResource(R.string.intern_item_working_period), style = TerningTheme.typography.detail3, - color = Grey400 + color = if (isApplyClosed) Grey350 else Grey400, ) Text( text = workingPeriod, style = TerningTheme.typography.detail3, - color = TerningMain, + color = if (isApplyClosed) Grey350 else TerningMain, modifier = Modifier.padding(start = 4.dp) ) @@ -143,6 +152,7 @@ fun InternItem( fun TwoLineHeightText( text: String, style: TextStyle, + color: Color = Black, ) { val twoLineHeight = with(LocalDensity.current) { (style.lineHeight.toDp() * 3) - style.fontSize.toDp() @@ -151,6 +161,7 @@ fun TwoLineHeightText( Text( text = text, style = style, + color = color, maxLines = 2, overflow = TextOverflow.Ellipsis, modifier = Modifier From 0b96643ba0a65171012c1f6e9b763cf7089cfc13 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Tue, 17 Dec 2024 10:42:35 +0900 Subject: [PATCH 04/13] =?UTF-8?q?[MOD/#308]=20=ED=95=84=ED=84=B0=EB=A7=81?= =?UTF-8?q?=20=EB=B2=84=ED=8A=BC=20=EB=B0=8F=20=ED=99=88=20=EB=B7=B0=20ui?= =?UTF-8?q?=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/terning/feature/home/HomeRoute.kt | 37 ++--- .../home/component/HomeFilteringScreen.kt | 150 ++++-------------- 2 files changed, 46 insertions(+), 141 deletions(-) diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index 036f54c1..b790c70d 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -6,6 +6,7 @@ import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.PaddingValues import androidx.compose.foundation.layout.Row +import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.padding import androidx.compose.foundation.lazy.LazyColumn @@ -26,7 +27,6 @@ import androidx.hilt.navigation.compose.hiltViewModel import androidx.lifecycle.compose.LocalLifecycleOwner import androidx.lifecycle.compose.collectAsStateWithLifecycle import androidx.lifecycle.flowWithLifecycle -import androidx.navigation.NavHostController import com.google.accompanist.systemuicontroller.rememberSystemUiController import com.terning.core.analytics.EventType import com.terning.core.analytics.LocalTracker @@ -292,17 +292,13 @@ fun HomeScreen( .background(White) ) { ShowRecommendTitle(homeUserName) - ShowInternFilter( - homeFilteringInfo = homeFilteringInfo, - onChangeFilterClick = { changeFilteringSheetState = true }, - ) Row( horizontalArrangement = Arrangement.SpaceBetween, verticalAlignment = Alignment.CenterVertically, modifier = Modifier .fillMaxWidth() - .padding(start = 24.dp, end = 18.dp), + .padding(vertical = 15.dp, horizontal = 24.dp), ) { Row { Text( @@ -323,14 +319,16 @@ fun HomeScreen( color = Grey400, ) } - Row { - SortingButton( - sortBy = homeState.sortBy.ordinal, - onCLick = { viewModel.updateSortingSheetVisibility(true) }, - modifier = Modifier - .padding(vertical = 4.dp) - ) - } + Spacer(modifier = Modifier.weight(1f)) + SortingButton( + sortBy = homeState.sortBy.ordinal, + onCLick = { viewModel.updateSortingSheetVisibility(true) }, + ) + HomeFilteringScreen( + onChangeFilterClick = { changeFilteringSheetState = true }, + modifier = Modifier + .padding(start = 8.dp) + ) } } } @@ -460,14 +458,3 @@ private fun ShowRecommendTitle(userName: String) { ), ) } - -@Composable -private fun ShowInternFilter( - homeFilteringInfo: HomeFilteringInfo, - onChangeFilterClick: () -> Unit, -) { - HomeFilteringScreen( - homeFilteringInfo = homeFilteringInfo, - onChangeFilterClick = onChangeFilterClick, - ) -} diff --git a/feature/home/src/main/java/com/terning/feature/home/component/HomeFilteringScreen.kt b/feature/home/src/main/java/com/terning/feature/home/component/HomeFilteringScreen.kt index cbac1746..eeca08a4 100644 --- a/feature/home/src/main/java/com/terning/feature/home/component/HomeFilteringScreen.kt +++ b/feature/home/src/main/java/com/terning/feature/home/component/HomeFilteringScreen.kt @@ -1,149 +1,67 @@ package com.terning.feature.home.component -import androidx.compose.foundation.background import androidx.compose.foundation.border -import androidx.compose.foundation.layout.Arrangement -import androidx.compose.foundation.layout.Box -import androidx.compose.foundation.layout.IntrinsicSize +import androidx.compose.foundation.clickable import androidx.compose.foundation.layout.Row -import androidx.compose.foundation.layout.fillMaxWidth -import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding -import androidx.compose.foundation.layout.size -import androidx.compose.foundation.shape.CircleShape import androidx.compose.foundation.shape.RoundedCornerShape import androidx.compose.material3.Icon import androidx.compose.material3.Text import androidx.compose.runtime.Composable import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier -import androidx.compose.ui.draw.clip import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.text.style.TextAlign import androidx.compose.ui.unit.dp import com.terning.core.analytics.EventType import com.terning.core.analytics.LocalTracker -import com.terning.core.designsystem.extension.noRippleClickable -import com.terning.core.designsystem.theme.Grey350 -import com.terning.core.designsystem.theme.Grey400 import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.TerningTheme -import com.terning.core.designsystem.type.Grade -import com.terning.core.designsystem.type.WorkingPeriod -import com.terning.domain.home.entity.HomeFilteringInfo import com.terning.feature.home.R @Composable fun HomeFilteringScreen( - homeFilteringInfo: HomeFilteringInfo, onChangeFilterClick: () -> Unit, modifier: Modifier = Modifier, ) { + val amplitudeTracker = LocalTracker.current + Row( - modifier = modifier - .padding(horizontal = 24.dp, vertical = 12.dp) - .height(IntrinsicSize.Min) - .fillMaxWidth(), - horizontalArrangement = Arrangement.SpaceBetween, verticalAlignment = Alignment.CenterVertically, - ) { - val amplitudeTracker = LocalTracker.current - - Row( - modifier = Modifier - .border( - width = 1.dp, - color = TerningMain, - shape = RoundedCornerShape(5.dp) - ) - .align(Alignment.CenterVertically) - .noRippleClickable { - amplitudeTracker.track( - type = EventType.CLICK, - name = "home_filtering" - ) - onChangeFilterClick() - }, - ) { - Icon( - painter = painterResource(id = R.drawable.ic_home_filtering_28), - contentDescription = stringResource(id = R.string.home_recommend_filtering), - modifier = modifier - .padding( - start = 2.dp, - top = 2.dp, - bottom = 2.dp, - ), - tint = TerningMain, - ) - Text( - text = stringResource(id = R.string.home_recommend_filtering), - style = TerningTheme.typography.button3, + modifier = modifier + .border( + width = 1.dp, color = TerningMain, - textAlign = TextAlign.Center, - modifier = Modifier - .padding(start = 5.dp, end = 11.dp) - .align(Alignment.CenterVertically), + shape = RoundedCornerShape(5.dp) ) - } - with(homeFilteringInfo) { - if (grade != null) { - Row( - verticalAlignment = Alignment.CenterVertically, - ) { - HomeFilteringInfoText( - text = stringResource(id = Grade.fromString(grade).stringResId), - modifier = Modifier - .padding(end = 6.dp), - ) - HomeFilteringInfoDivider() - HomeFilteringInfoText( - text = stringResource(WorkingPeriod.fromString(workingPeriod).stringResId), - modifier = Modifier - .padding(horizontal = 6.dp), - ) - HomeFilteringInfoDivider() - HomeFilteringInfoText( - text = stringResource( - id = R.string.home_recommend_filtering_startYearMonth, - startYear.toString(), - startMonth.toString() - ), - modifier = Modifier - .padding(start = 6.dp), - ) - } - } else { - HomeFilteringInfoText( - text = stringResource(id = R.string.home_filtering_empty), - modifier = Modifier - .align(Alignment.CenterVertically), + .clickable { + amplitudeTracker.track( + type = EventType.CLICK, + name = "home_filtering" ) - } - } + onChangeFilterClick() + }, + ) { + Icon( + painter = painterResource(id = R.drawable.ic_home_filtering_28), + contentDescription = stringResource(id = R.string.home_recommend_filtering), + modifier = Modifier + .padding( + start = 2.dp, + top = 1.dp, + bottom = 1.dp, + ), + tint = TerningMain, + ) + Text( + text = stringResource(id = R.string.home_recommend_filtering), + style = TerningTheme.typography.button3, + color = TerningMain, + textAlign = TextAlign.Center, + modifier = Modifier + .padding(start = 5.dp, end = 11.dp) + .align(Alignment.CenterVertically), + ) } } - -@Composable -private fun HomeFilteringInfoText( - text: String, - modifier: Modifier = Modifier -) { - Text( - text = text, - style = TerningTheme.typography.body5, - color = Grey400, - modifier = modifier, - ) -} - -@Composable -private fun HomeFilteringInfoDivider() { - Box( - modifier = Modifier - .size(4.dp) - .clip(CircleShape) - .background(Grey350), - ) -} \ No newline at end of file From a413f3e649a3781bbf45445580a175dc8b82ceab Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Tue, 17 Dec 2024 11:03:18 +0900 Subject: [PATCH 05/13] =?UTF-8?q?[MOD/#308]=20=EC=A0=95=EB=A0=AC=20?= =?UTF-8?q?=EA=B8=B0=EC=A4=80=20=EB=B2=84=ED=8A=BC=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../component/button/SortingButton.kt | 48 +++++++++++-------- 1 file changed, 29 insertions(+), 19 deletions(-) diff --git a/core/designsystem/src/main/java/com/terning/core/designsystem/component/button/SortingButton.kt b/core/designsystem/src/main/java/com/terning/core/designsystem/component/button/SortingButton.kt index e76831d4..324962c8 100644 --- a/core/designsystem/src/main/java/com/terning/core/designsystem/component/button/SortingButton.kt +++ b/core/designsystem/src/main/java/com/terning/core/designsystem/component/button/SortingButton.kt @@ -1,17 +1,22 @@ package com.terning.core.designsystem.component.button -import androidx.compose.foundation.Image +import androidx.compose.foundation.border import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.padding +import androidx.compose.foundation.layout.size +import androidx.compose.foundation.shape.RoundedCornerShape +import androidx.compose.material3.Icon import androidx.compose.material3.Text import androidx.compose.runtime.Composable +import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier -import androidx.compose.ui.res.painterResource +import androidx.compose.ui.graphics.vector.ImageVector import androidx.compose.ui.res.stringResource +import androidx.compose.ui.res.vectorResource import androidx.compose.ui.unit.dp import com.terning.core.designsystem.R import com.terning.core.designsystem.extension.noRippleClickable -import com.terning.core.designsystem.theme.Black +import com.terning.core.designsystem.theme.Grey350 import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.designsystem.type.SortBy @@ -22,31 +27,36 @@ fun SortingButton( onCLick: () -> Unit, ) { Row( + verticalAlignment = Alignment.CenterVertically, modifier = modifier + .border( + width = 1.dp, + color = Grey350, + shape = RoundedCornerShape(5.dp) + ) .noRippleClickable(onCLick), ) { + Icon( + imageVector = ImageVector.vectorResource(id = R.drawable.ic_down_18), + contentDescription = stringResource(id = R.string.sort_button_description), + tint = Grey350, + modifier = Modifier + .padding( + start = 7.dp, + end = 6.dp, + top = 5.dp, + bottom = 5.dp, + ) + .size(20.dp) + ) Text( text = stringResource( id = SortBy.entries[sortBy].sortBy ), style = TerningTheme.typography.button3, - color = Black, - modifier = Modifier - .padding( - top = 6.dp, - bottom = 6.dp, - ) - ) - Image( - painter = painterResource(id = R.drawable.ic_down_18), - contentDescription = stringResource(id = R.string.sort_button_description), + color = Grey350, modifier = Modifier - .padding( - start = 2.dp, - end = 2.dp, - top = 6.dp, - bottom = 4.dp, - ) + .padding(end = 11.dp) ) } } From 2e3862f77b36c1ea54277bad90aee852a2455605 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Tue, 17 Dec 2024 11:18:42 +0900 Subject: [PATCH 06/13] =?UTF-8?q?[MOD/#308]=20=EC=A7=80=EC=9B=90=20?= =?UTF-8?q?=EB=A7=88=EA=B0=90=20=EA=B3=B5=EA=B3=A0=20=EB=B6=84=EA=B8=B0?= =?UTF-8?q?=EC=B2=98=EB=A6=AC=20=EB=A1=9C=EC=A7=81=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../core/designsystem/component/item/InternItem.kt | 9 +++++++-- .../designsystem/component/item/InternItemWithShadow.kt | 2 ++ .../src/main/java/com/terning/feature/home/HomeRoute.kt | 1 + feature/home/src/main/res/values/strings.xml | 1 + .../feature/search/searchprocess/SearchProcessRoute.kt | 1 + feature/search/src/main/res/values/strings.xml | 2 ++ 6 files changed, 14 insertions(+), 2 deletions(-) diff --git a/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItem.kt b/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItem.kt index 6746715a..73abbd37 100644 --- a/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItem.kt +++ b/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItem.kt @@ -33,6 +33,7 @@ import coil3.request.ImageRequest import com.terning.core.designsystem.R import com.terning.core.designsystem.extension.noRippleClickable import com.terning.core.designsystem.theme.Black +import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.Grey350 import com.terning.core.designsystem.theme.Grey400 import com.terning.core.designsystem.theme.TerningMain @@ -61,9 +62,9 @@ fun InternItem( isScraped: Boolean, modifier: Modifier = Modifier, scrapId: Long = 0, + isApplyClosed: Boolean = false, onScrapButtonClicked: (Long) -> Unit = {}, ) { - val isApplyClosed = dateDeadline == stringResource(id = R.string.intern_apply_closed) Row( modifier = modifier .fillMaxWidth() @@ -95,7 +96,11 @@ fun InternItem( Text( text = dateDeadline, style = TerningTheme.typography.detail0, - color = if (isApplyClosed) Grey350 else TerningMain, + color = when { + isApplyClosed -> Grey350 + dateDeadline == stringResource(id = R.string.intern_apply_closed) -> Grey300 + else -> TerningMain + }, ) TwoLineHeightText( text = title, diff --git a/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItemWithShadow.kt b/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItemWithShadow.kt index 7641408f..17e7adf6 100644 --- a/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItemWithShadow.kt +++ b/core/designsystem/src/main/java/com/terning/core/designsystem/component/item/InternItemWithShadow.kt @@ -21,6 +21,7 @@ fun InternItemWithShadow( dateDeadline: String, workingPeriod: String, isScrapped: Boolean, + isApplyClosed: Boolean = false, onScrapButtonClicked: (Long) -> Unit = {} ) { Box( @@ -41,6 +42,7 @@ fun InternItemWithShadow( dateDeadline = dateDeadline, workingPeriod = workingPeriod, isScraped = isScrapped, + isApplyClosed = isApplyClosed, onScrapButtonClicked = onScrapButtonClicked ) } diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index b790c70d..00eb9411 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -391,6 +391,7 @@ private fun RecommendInternItem( dateDeadline = intern.dDay, workingPeriod = intern.workingPeriod, isScrapped = intern.isScrapped, + isApplyClosed = (intern.dDay == stringResource(id = R.string.intern_apply_closed)), shadowRadius = 5.dp, shadowWidth = 1.dp, onScrapButtonClicked = onScrapButtonClicked, diff --git a/feature/home/src/main/res/values/strings.xml b/feature/home/src/main/res/values/strings.xml index 83750d3e..9e4291b1 100644 --- a/feature/home/src/main/res/values/strings.xml +++ b/feature/home/src/main/res/values/strings.xml @@ -25,4 +25,5 @@ 기업 이미지 - 오늘 마감인 공고가 없어요 + 지원마감 diff --git a/feature/search/src/main/java/com/terning/feature/search/searchprocess/SearchProcessRoute.kt b/feature/search/src/main/java/com/terning/feature/search/searchprocess/SearchProcessRoute.kt index c06b16da..0cc28017 100644 --- a/feature/search/src/main/java/com/terning/feature/search/searchprocess/SearchProcessRoute.kt +++ b/feature/search/src/main/java/com/terning/feature/search/searchprocess/SearchProcessRoute.kt @@ -388,6 +388,7 @@ private fun SearchResultInternItem( dateDeadline = intern.dDay, workingPeriod = intern.workingPeriod, isScrapped = intern.isScrapped, + isApplyClosed = intern.dDay == stringResource(id = R.string.intern_apply_closed), shadowRadius = 5.dp, shadowWidth = 1.dp, onScrapButtonClicked = { diff --git a/feature/search/src/main/res/values/strings.xml b/feature/search/src/main/res/values/strings.xml index 29a4790c..ba32e862 100644 --- a/feature/search/src/main/res/values/strings.xml +++ b/feature/search/src/main/res/values/strings.xml @@ -19,4 +19,6 @@ 해당하는 검색 결과가 없어요 개의 공고가 있어요 + + 지원마감 From 318970c91be90bd650e67df1032987689e16d652 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Tue, 17 Dec 2024 11:36:45 +0900 Subject: [PATCH 07/13] =?UTF-8?q?[CHORE/#308]=20=ED=99=88=20=EB=B7=B0=20?= =?UTF-8?q?=EC=9E=90=EC=B2=B4=20QA=20=EC=82=AC=ED=95=AD=20=EB=B0=98?= =?UTF-8?q?=EC=98=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/main/java/com/terning/feature/home/HomeRoute.kt | 8 +++----- .../terning/feature/home/component/HomeFilteringScreen.kt | 4 ++-- 2 files changed, 5 insertions(+), 7 deletions(-) diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index 00eb9411..0997fd21 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -268,10 +268,7 @@ fun HomeScreen( ) LazyColumn( - contentPadding = PaddingValues( - top = 2.dp, - bottom = 20.dp, - ), + contentPadding = PaddingValues(bottom = 20.dp), verticalArrangement = Arrangement.spacedBy(12.dp), modifier = Modifier .fillMaxWidth(), @@ -298,7 +295,8 @@ fun HomeScreen( verticalAlignment = Alignment.CenterVertically, modifier = Modifier .fillMaxWidth() - .padding(vertical = 15.dp, horizontal = 24.dp), + .padding(horizontal = 24.dp) + .padding(top = 15.dp, bottom = 3.dp), ) { Row { Text( diff --git a/feature/home/src/main/java/com/terning/feature/home/component/HomeFilteringScreen.kt b/feature/home/src/main/java/com/terning/feature/home/component/HomeFilteringScreen.kt index eeca08a4..f5dfa67b 100644 --- a/feature/home/src/main/java/com/terning/feature/home/component/HomeFilteringScreen.kt +++ b/feature/home/src/main/java/com/terning/feature/home/component/HomeFilteringScreen.kt @@ -1,7 +1,6 @@ package com.terning.feature.home.component import androidx.compose.foundation.border -import androidx.compose.foundation.clickable import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.padding import androidx.compose.foundation.shape.RoundedCornerShape @@ -16,6 +15,7 @@ import androidx.compose.ui.text.style.TextAlign import androidx.compose.ui.unit.dp import com.terning.core.analytics.EventType import com.terning.core.analytics.LocalTracker +import com.terning.core.designsystem.extension.noRippleClickable import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.TerningTheme import com.terning.feature.home.R @@ -35,7 +35,7 @@ fun HomeFilteringScreen( color = TerningMain, shape = RoundedCornerShape(5.dp) ) - .clickable { + .noRippleClickable { amplitudeTracker.track( type = EventType.CLICK, name = "home_filtering" From ba7bf35b6a92d774243059da8fa7d37a576247be Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Wed, 18 Dec 2024 14:14:45 +0900 Subject: [PATCH 08/13] =?UTF-8?q?[REFACTOR/#308]=20=EB=94=B1=20=EB=A7=9E?= =?UTF-8?q?=EB=8A=94=20=EC=9D=B8=ED=84=B4=20=EA=B3=B5=EA=B3=A0=20=ED=8C=8C?= =?UTF-8?q?=EB=9D=BC=EB=AF=B8=ED=84=B0=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../terning/data/home/datasource/HomeDataSource.kt | 2 -- .../data/home/datasourceimpl/HomeDataSourceImpl.kt | 4 ---- .../data/home/repositoryimpl/HomeRepositoryImpl.kt | 4 ---- .../java/com/terning/data/home/service/HomeService.kt | 2 -- .../terning/domain/home/repository/HomeRepository.kt | 2 -- .../main/java/com/terning/feature/home/HomeRoute.kt | 6 +----- .../java/com/terning/feature/home/HomeViewModel.kt | 11 +---------- 7 files changed, 2 insertions(+), 29 deletions(-) diff --git a/data/home/src/main/java/com/terning/data/home/datasource/HomeDataSource.kt b/data/home/src/main/java/com/terning/data/home/datasource/HomeDataSource.kt index 21520cc7..0c255517 100644 --- a/data/home/src/main/java/com/terning/data/home/datasource/HomeDataSource.kt +++ b/data/home/src/main/java/com/terning/data/home/datasource/HomeDataSource.kt @@ -12,8 +12,6 @@ interface HomeDataSource { suspend fun getRecommendIntern( sortBy: String, - startYear: Int, - startMonth: Int ): BaseResponse suspend fun getFilteringInfo(): BaseResponse diff --git a/data/home/src/main/java/com/terning/data/home/datasourceimpl/HomeDataSourceImpl.kt b/data/home/src/main/java/com/terning/data/home/datasourceimpl/HomeDataSourceImpl.kt index cc73df1b..973151a6 100644 --- a/data/home/src/main/java/com/terning/data/home/datasourceimpl/HomeDataSourceImpl.kt +++ b/data/home/src/main/java/com/terning/data/home/datasourceimpl/HomeDataSourceImpl.kt @@ -18,13 +18,9 @@ class HomeDataSourceImpl @Inject constructor( override suspend fun getRecommendIntern( sortBy: String, - startYear: Int, - startMonth: Int ): BaseResponse = homeService.getRecommendIntern( sortBy = sortBy, - startYear = startYear, - startMonth = startMonth ) override suspend fun getFilteringInfo(): BaseResponse = diff --git a/data/home/src/main/java/com/terning/data/home/repositoryimpl/HomeRepositoryImpl.kt b/data/home/src/main/java/com/terning/data/home/repositoryimpl/HomeRepositoryImpl.kt index 8c01ea9c..d0677159 100644 --- a/data/home/src/main/java/com/terning/data/home/repositoryimpl/HomeRepositoryImpl.kt +++ b/data/home/src/main/java/com/terning/data/home/repositoryimpl/HomeRepositoryImpl.kt @@ -22,14 +22,10 @@ class HomeRepositoryImpl @Inject constructor( override suspend fun getRecommendIntern( sortBy: String, - startYear: Int, - startMonth: Int ): Result = runCatching { homeDataSource.getRecommendIntern( sortBy = sortBy, - startYear = startYear, - startMonth = startMonth ).result.toHomeRecommendInternList() } diff --git a/data/home/src/main/java/com/terning/data/home/service/HomeService.kt b/data/home/src/main/java/com/terning/data/home/service/HomeService.kt index 1215a33e..cc54844b 100644 --- a/data/home/src/main/java/com/terning/data/home/service/HomeService.kt +++ b/data/home/src/main/java/com/terning/data/home/service/HomeService.kt @@ -18,8 +18,6 @@ interface HomeService { @GET("api/v1/home") suspend fun getRecommendIntern( @Query("sortBy") sortBy: String, - @Query("startYear") startYear: Int, - @Query("startMonth") startMonth: Int, ): BaseResponse @GET("api/v1/filters") diff --git a/domain/home/src/main/java/com/terning/domain/home/repository/HomeRepository.kt b/domain/home/src/main/java/com/terning/domain/home/repository/HomeRepository.kt index e7b7f432..609212b3 100644 --- a/domain/home/src/main/java/com/terning/domain/home/repository/HomeRepository.kt +++ b/domain/home/src/main/java/com/terning/domain/home/repository/HomeRepository.kt @@ -10,8 +10,6 @@ interface HomeRepository { suspend fun getRecommendIntern( sortBy: String, - startYear: Int, - startMonth: Int ): Result suspend fun getFilteringInfo(): Result diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index 0997fd21..555d68f9 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -128,7 +128,7 @@ fun HomeScreen( navigateToCalendar: () -> Unit, updateRecommendDialogVisibility: (Boolean) -> Unit, getHomeUpcomingInternList: () -> Unit, - getRecommendInternsData: (Int, Int?, Int?) -> Unit, + getRecommendInternsData: (Int) -> Unit, viewModel: HomeViewModel, ) { val homeState by viewModel.homeState.collectAsStateWithLifecycle() @@ -221,8 +221,6 @@ fun HomeScreen( getHomeUpcomingInternList() getRecommendInternsData( homeState.sortBy.ordinal, - homeFilteringInfo.startYear, - homeFilteringInfo.startMonth ) } } @@ -242,8 +240,6 @@ fun HomeScreen( if (isScrapped) { getRecommendInternsData( homeState.sortBy.ordinal, - homeFilteringInfo.startYear, - homeFilteringInfo.startMonth ) getHomeUpcomingInternList() } diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt b/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt index 57dbe67e..41288c4d 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt @@ -2,8 +2,6 @@ package com.terning.feature.home import androidx.lifecycle.ViewModel import androidx.lifecycle.viewModelScope -import com.terning.core.designsystem.extension.currentMonth -import com.terning.core.designsystem.extension.currentYear import com.terning.core.designsystem.state.UiState import com.terning.core.designsystem.type.SortBy import com.terning.domain.home.entity.ChangeFilteringRequestModel @@ -17,7 +15,6 @@ import kotlinx.coroutines.flow.asSharedFlow import kotlinx.coroutines.flow.asStateFlow import kotlinx.coroutines.flow.update import kotlinx.coroutines.launch -import java.util.Calendar import javax.inject.Inject @HiltViewModel @@ -31,12 +28,10 @@ class HomeViewModel @Inject constructor( private val _homeSideEffect = MutableSharedFlow() val homeSideEffect get() = _homeSideEffect.asSharedFlow() - fun getRecommendInternsData(sortBy: Int, startYear: Int?, startMonth: Int?) { + fun getRecommendInternsData(sortBy: Int) { viewModelScope.launch { homeRepository.getRecommendIntern( sortBy = SortBy.entries[sortBy].type, - startYear ?: Calendar.getInstance().currentYear, - startMonth ?: Calendar.getInstance().currentMonth, ).onSuccess { internList -> _homeState.value = _homeState.value.copy( homeRecommendInternState = UiState.Success(internList) @@ -74,8 +69,6 @@ class HomeViewModel @Inject constructor( if (filteringInfo.grade != null) { getRecommendInternsData( sortBy = _homeState.value.sortBy.ordinal, - startYear = filteringInfo.startYear, - startMonth = filteringInfo.startMonth, ) getHomeUpcomingInternList() } @@ -158,8 +151,6 @@ class HomeViewModel @Inject constructor( } getRecommendInternsData( _homeState.value.sortBy.ordinal, - startYear ?: Calendar.getInstance().currentYear, - startMonth ?: Calendar.getInstance().currentMonth, ) } From 153cfb9ddae918ab16f8aa3cd0d6d793632bc4c7 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Wed, 18 Dec 2024 14:17:03 +0900 Subject: [PATCH 09/13] =?UTF-8?q?[CHORE/#308]=20navigateToCalendar=20?= =?UTF-8?q?=EC=98=A4=EB=A5=98=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../main/src/main/java/com/terning/feature/main/MainScreen.kt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/feature/main/src/main/java/com/terning/feature/main/MainScreen.kt b/feature/main/src/main/java/com/terning/feature/main/MainScreen.kt index 2f28f4a4..e95b8678 100644 --- a/feature/main/src/main/java/com/terning/feature/main/MainScreen.kt +++ b/feature/main/src/main/java/com/terning/feature/main/MainScreen.kt @@ -44,6 +44,7 @@ import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.White import com.terning.core.designsystem.util.NoRippleInteractionSource import com.terning.feature.calendar.calendar.navigation.calendarNavGraph +import com.terning.feature.calendar.calendar.navigation.navigateCalendar import com.terning.feature.filtering.filteringone.navigation.filteringOneNavGraph import com.terning.feature.filtering.filteringthree.navigation.filteringThreeNavGraph import com.terning.feature.filtering.filteringtwo.navigation.filteringTwoNavGraph @@ -169,7 +170,7 @@ fun MainScreen( homeNavGraph( paddingValues = paddingValues, navHostController = navigator.navController, - navigateToCalendar = { navigator.navController.navigateHome() }, + navigateToCalendar = { navigator.navController.navigateCalendar() }, navigateToIntern = { announcementId -> navigator.navController.navigateIntern(announcementId) } From 73167099bfc5e0f0253f7148a2334926ec23c4e1 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Fri, 20 Dec 2024 00:17:18 +0900 Subject: [PATCH 10/13] =?UTF-8?q?[MOD/#308]=20immutableList=20=EC=A0=81?= =?UTF-8?q?=EC=9A=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../home/src/main/java/com/terning/feature/home/HomeRoute.kt | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index 555d68f9..f4a677fd 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -56,6 +56,7 @@ import com.terning.feature.home.component.HomeRecommendEmptyIntern import com.terning.feature.home.component.HomeUpcomingEmptyFilter import com.terning.feature.home.component.HomeUpcomingEmptyIntern import com.terning.feature.home.component.HomeUpcomingInternScreen +import okhttp3.internal.toImmutableList const val NAME_MAX_LENGTH = 5 @@ -144,7 +145,7 @@ fun HomeScreen( } val homeRecommendInternList = when (homeState.homeRecommendInternState) { - is UiState.Success -> (homeState.homeRecommendInternState as UiState.Success).data.homeRecommendInternDetail + is UiState.Success -> (homeState.homeRecommendInternState as UiState.Success).data.homeRecommendInternDetail.toImmutableList() else -> listOf() } @@ -424,7 +425,7 @@ private fun ShowUpcomingIntern( ) else -> HomeUpcomingInternScreen( - internList = homeUpcomingInternDetail, + internList = homeUpcomingInternDetail.toImmutableList(), navigateToIntern = navigateToIntern, ) } From 26759f1b251f06235b3956c0b12d7910e99a1af8 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Mon, 23 Dec 2024 12:08:57 +0900 Subject: [PATCH 11/13] =?UTF-8?q?[MOD/#308]=20=EC=84=9C=EB=B2=84=20?= =?UTF-8?q?=ED=86=B5=EC=8B=A0=20=EB=A1=9C=EC=A7=81=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/com/terning/feature/home/HomeRoute.kt | 14 +++----------- .../java/com/terning/feature/home/HomeViewModel.kt | 13 +++++-------- 2 files changed, 8 insertions(+), 19 deletions(-) diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index f4a677fd..5d099385 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -85,6 +85,8 @@ fun HomeRoute( LaunchedEffect(key1 = true) { viewModel.getProfile() viewModel.getFilteringInfo() + viewModel.getRecommendInternsData(0) + viewModel.getHomeUpcomingInternList() } LaunchedEffect(viewModel.homeSideEffect, lifecycleOwner) { @@ -175,11 +177,7 @@ fun HomeScreen( else -> "filtered_hits" } ) - viewModel.updateSortBy( - sortBy, - homeFilteringInfo.startYear, - homeFilteringInfo.startMonth, - ) + viewModel.updateSortBy(sortBy) } ) } @@ -204,12 +202,6 @@ fun HomeScreen( ) } - LaunchedEffect(changeFilteringSheetState) { - if (!changeFilteringSheetState) { - viewModel.getFilteringInfo() - } - } - if (homeState.homeRecommendDialogVisibility) { with(homeState.homeInternModel) { if (this != null) { diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt b/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt index 41288c4d..06636e31 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeViewModel.kt @@ -66,12 +66,6 @@ class HomeViewModel @Inject constructor( _homeState.value = _homeState.value.copy( homeFilteringInfoState = UiState.Success(filteringInfo) ) - if (filteringInfo.grade != null) { - getRecommendInternsData( - sortBy = _homeState.value.sortBy.ordinal, - ) - getHomeUpcomingInternList() - } }.onFailure { exception: Throwable -> _homeState.value = _homeState.value.copy( homeFilteringInfoState = UiState.Failure(exception.toString()) @@ -90,7 +84,10 @@ class HomeViewModel @Inject constructor( year, month ) - ) + ).onSuccess { + getFilteringInfo() + getRecommendInternsData(_homeState.value.sortBy.ordinal) + } } } @@ -143,7 +140,7 @@ class HomeViewModel @Inject constructor( } } - fun updateSortBy(sortBy: Int, startYear: Int?, startMonth: Int?) { + fun updateSortBy(sortBy: Int) { _homeState.update { it.copy( sortBy = SortBy.entries[sortBy] From b892c1ed678e1298cc4a776050d5401ddce8e613 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Mon, 23 Dec 2024 12:15:28 +0900 Subject: [PATCH 12/13] =?UTF-8?q?[MOD/#308]=20=EC=A0=95=EB=A0=AC=20?= =?UTF-8?q?=EA=B8=B0=EC=A4=80=20=ED=95=A8=EC=88=98=20=EC=9D=B4=EB=8F=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../main/java/com/terning/feature/home/HomeRoute.kt | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt index 5d099385..eba443d2 100644 --- a/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt +++ b/feature/home/src/main/java/com/terning/feature/home/HomeRoute.kt @@ -117,6 +117,8 @@ fun HomeRoute( viewModel.navigateCalendar() }, updateRecommendDialogVisibility = viewModel::updateRecommendDialogVisibility, + updateSortingSheetVisibility = viewModel::updateSortingSheetVisibility, + updateSortBy = viewModel::updateSortBy, getHomeUpcomingInternList = viewModel::getHomeUpcomingInternList, getRecommendInternsData = viewModel::getRecommendInternsData, viewModel = viewModel, @@ -130,6 +132,8 @@ fun HomeScreen( navigateToIntern: (Long) -> Unit, navigateToCalendar: () -> Unit, updateRecommendDialogVisibility: (Boolean) -> Unit, + updateSortingSheetVisibility: (Boolean) -> Unit, + updateSortBy: (Int) -> Unit, getHomeUpcomingInternList: () -> Unit, getRecommendInternsData: (Int) -> Unit, viewModel: HomeViewModel, @@ -163,7 +167,7 @@ fun HomeScreen( if (homeState.sortingSheetVisibility) { SortingBottomSheet( onDismiss = { - viewModel.updateSortingSheetVisibility(false) + updateSortingSheetVisibility(false) }, currentSortBy = homeState.sortBy.ordinal, onSortChange = { sortBy -> @@ -177,7 +181,7 @@ fun HomeScreen( else -> "filtered_hits" } ) - viewModel.updateSortBy(sortBy) + updateSortBy(sortBy) } ) } @@ -309,7 +313,7 @@ fun HomeScreen( Spacer(modifier = Modifier.weight(1f)) SortingButton( sortBy = homeState.sortBy.ordinal, - onCLick = { viewModel.updateSortingSheetVisibility(true) }, + onCLick = { updateSortingSheetVisibility(true) }, ) HomeFilteringScreen( onChangeFilterClick = { changeFilteringSheetState = true }, From 23b42dac451b80d73063b4db895131878be2cdf0 Mon Sep 17 00:00:00 2001 From: Hyobeen-Park Date: Mon, 23 Dec 2024 12:17:44 +0900 Subject: [PATCH 13/13] =?UTF-8?q?[CHORE/#308]=20=EB=84=A4=EB=B9=84?= =?UTF-8?q?=EA=B2=8C=EC=9D=B4=EC=85=98=20=EC=BD=94=EB=93=9C=20=EC=A0=95?= =?UTF-8?q?=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../home/navigation/HometNavigation.kt | 21 ++----------------- .../com/terning/feature/main/MainScreen.kt | 1 - 2 files changed, 2 insertions(+), 20 deletions(-) diff --git a/feature/home/src/main/java/com/terning/feature/home/navigation/HometNavigation.kt b/feature/home/src/main/java/com/terning/feature/home/navigation/HometNavigation.kt index 04a1f989..57996f9e 100644 --- a/feature/home/src/main/java/com/terning/feature/home/navigation/HometNavigation.kt +++ b/feature/home/src/main/java/com/terning/feature/home/navigation/HometNavigation.kt @@ -1,11 +1,8 @@ package com.terning.feature.home.navigation -import androidx.compose.animation.EnterTransition -import androidx.compose.animation.ExitTransition import androidx.compose.foundation.layout.PaddingValues import androidx.navigation.NavController import androidx.navigation.NavGraphBuilder -import androidx.navigation.NavHostController import androidx.navigation.NavOptions import androidx.navigation.compose.composable import com.terning.core.navigation.MainTabRoute @@ -21,24 +18,10 @@ fun NavController.navigateHome(navOptions: NavOptions? = null) { fun NavGraphBuilder.homeNavGraph( paddingValues: PaddingValues, - navHostController: NavHostController, navigateToCalendar: () -> Unit, - navigateToIntern:(Long)-> Unit + navigateToIntern: (Long) -> Unit ) { - composable( - exitTransition = { - ExitTransition.None - }, - popEnterTransition = { - EnterTransition.None - }, - enterTransition = { - EnterTransition.None - }, - popExitTransition = { - ExitTransition.None - } - ) { + composable { HomeRoute( paddingValues = paddingValues, navigateToCalendar = navigateToCalendar, diff --git a/feature/main/src/main/java/com/terning/feature/main/MainScreen.kt b/feature/main/src/main/java/com/terning/feature/main/MainScreen.kt index 94fd51ab..643c5ce1 100644 --- a/feature/main/src/main/java/com/terning/feature/main/MainScreen.kt +++ b/feature/main/src/main/java/com/terning/feature/main/MainScreen.kt @@ -172,7 +172,6 @@ fun MainScreen( ) homeNavGraph( paddingValues = paddingValues, - navHostController = navigator.navController, navigateToCalendar = { navigator.navController.navigateCalendar() }, navigateToIntern = { announcementId -> navigator.navController.navigateIntern(announcementId)