From 3a9f66390665e3a158ed0a84c258ed048c3cc1bc Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 03:46:07 +0900 Subject: [PATCH 01/33] =?UTF-8?q?[UI/#216]=20=ED=95=84=ED=84=B0=EB=A7=81?= =?UTF-8?q?=20=EC=8B=9C=EC=9E=91=20=ED=99=94=EB=A9=B4=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...teringScreen.kt => StartFilteringRoute.kt} | 51 ++++++++++++------- .../startfiltering/StartFilteringState.kt | 5 ++ .../startfiltering/StartFilteringViewModel.kt | 18 +++++++ .../navigation/StartFilteringNavigation.kt | 4 +- .../signup/navigation/SignUpNavigation.kt | 3 +- 5 files changed, 61 insertions(+), 20 deletions(-) rename feature/src/main/java/com/terning/feature/filtering/startfiltering/{StartFilteringScreen.kt => StartFilteringRoute.kt} (71%) create mode 100644 feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringState.kt create mode 100644 feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringViewModel.kt diff --git a/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringScreen.kt b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt similarity index 71% rename from feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringScreen.kt rename to feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt index e8e1128b2..0efc87a2d 100644 --- a/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringScreen.kt +++ b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt @@ -2,6 +2,7 @@ package com.terning.feature.filtering.startfiltering import androidx.compose.animation.AnimatedVisibility import androidx.compose.animation.fadeIn +import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Box import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Spacer @@ -13,40 +14,53 @@ import androidx.compose.material3.Text import androidx.compose.runtime.Composable import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.getValue -import androidx.compose.runtime.mutableStateOf -import androidx.compose.runtime.remember -import androidx.compose.runtime.setValue import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.platform.LocalConfiguration +import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.text.style.TextAlign import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp +import androidx.hilt.navigation.compose.hiltViewModel +import androidx.lifecycle.compose.collectAsStateWithLifecycle import com.terning.core.designsystem.component.button.RectangleButton -import com.terning.core.designsystem.component.image.TerningImage import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme import com.terning.feature.R import kotlinx.coroutines.delay @Composable -fun StartFilteringScreen( - modifier: Modifier = Modifier, - onNextClick: () -> Unit +fun StartFilteringRoute( + onNextClick: () -> Unit, + viewModel: StartFilteringViewModel = hiltViewModel() ) { - var isVisible by remember { mutableStateOf(false) } + val state by viewModel.state.collectAsStateWithLifecycle() val configuration = LocalConfiguration.current val screenHeight = 780f / configuration.screenHeightDp LaunchedEffect(key1 = true) { delay(DELAY) - isVisible = true + viewModel.updateButtonState() } + StartFilteringScreen( + onNextClick = onNextClick, + buttonState = state.isButtonVisible, + screenHeight = screenHeight + ) + +} + +@Composable +fun StartFilteringScreen( + onNextClick: () -> Unit, + buttonState: Boolean, + screenHeight: Float +) { Box( - modifier = modifier.fillMaxSize() + modifier = Modifier.fillMaxSize() ) { Column( modifier = Modifier.fillMaxSize(), @@ -59,11 +73,12 @@ fun StartFilteringScreen( modifier = Modifier.padding(bottom = 35.dp), textAlign = TextAlign.Center ) - TerningImage( - painter = R.drawable.ic_terning_onboarding, + Image( + painter = painterResource(id = R.drawable.ic_terning_onboarding), modifier = Modifier .fillMaxWidth() - .padding(horizontal = 24.dp) + .padding(horizontal = 24.dp), + contentDescription = "terning image" ) Spacer(modifier = Modifier.weight(2f)) } @@ -73,14 +88,14 @@ fun StartFilteringScreen( .padding(bottom = 12.dp) ) { AnimatedVisibility( - visible = isVisible, + visible = buttonState, enter = fadeIn(initialAlpha = 0.3f), ) { RectangleButton( style = TerningTheme.typography.button0, paddingVertical = 20.dp, text = R.string.start_filtering_button, - onButtonClick = { onNextClick() }, + onButtonClick = onNextClick, ) } } @@ -94,7 +109,9 @@ private const val DELAY: Long = 1000 fun StartFilteringScreenPreview() { TerningPointTheme { StartFilteringScreen( - onNextClick = {} + onNextClick = {}, + buttonState = true, + screenHeight = 1f ) } -} +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringState.kt b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringState.kt new file mode 100644 index 000000000..005cb40f8 --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringState.kt @@ -0,0 +1,5 @@ +package com.terning.feature.filtering.startfiltering + +data class StartFilteringState( + val isButtonVisible: Boolean = false +) \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringViewModel.kt new file mode 100644 index 000000000..3cfc06193 --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringViewModel.kt @@ -0,0 +1,18 @@ +package com.terning.feature.filtering.startfiltering + +import androidx.lifecycle.ViewModel +import kotlinx.coroutines.flow.MutableStateFlow +import kotlinx.coroutines.flow.StateFlow +import kotlinx.coroutines.flow.asStateFlow + +class StartFilteringViewModel : ViewModel() { + + private val _state: MutableStateFlow = + MutableStateFlow(StartFilteringState()) + val state: StateFlow get() = _state.asStateFlow() + + fun updateButtonState() { + _state.value = _state.value.copy(isButtonVisible = true) + } + +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/startfiltering/navigation/StartFilteringNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/startfiltering/navigation/StartFilteringNavigation.kt index e70d98afa..f217cf39e 100644 --- a/feature/src/main/java/com/terning/feature/filtering/startfiltering/navigation/StartFilteringNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/startfiltering/navigation/StartFilteringNavigation.kt @@ -8,7 +8,7 @@ import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route import com.terning.feature.filtering.filtering.navigation.navigateFilteringOne -import com.terning.feature.filtering.startfiltering.StartFilteringScreen +import com.terning.feature.filtering.startfiltering.StartFilteringRoute import kotlinx.serialization.Serializable fun NavController.navigateStartFiltering( @@ -26,7 +26,7 @@ fun NavGraphBuilder.startFilteringNavGraph( ) { composable { val args = it.toRoute() - StartFilteringScreen( + StartFilteringRoute( onNextClick = { navHostController.navigateFilteringOne(args.name) } diff --git a/feature/src/main/java/com/terning/feature/onboarding/signup/navigation/SignUpNavigation.kt b/feature/src/main/java/com/terning/feature/onboarding/signup/navigation/SignUpNavigation.kt index 479e02eda..95932966e 100644 --- a/feature/src/main/java/com/terning/feature/onboarding/signup/navigation/SignUpNavigation.kt +++ b/feature/src/main/java/com/terning/feature/onboarding/signup/navigation/SignUpNavigation.kt @@ -8,6 +8,7 @@ import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route import com.terning.feature.filtering.filtering.navigation.navigateFilteringOne +import com.terning.feature.filtering.startfiltering.navigation.navigateStartFiltering import com.terning.feature.onboarding.signup.SignUpRoute import kotlinx.serialization.Serializable @@ -28,7 +29,7 @@ fun NavGraphBuilder.signUpNavGraph( val args = it.toRoute() SignUpRoute( authId = args.authId, - navigateToStartFiltering = { name -> navHostController.navigateFilteringOne(name) } + navigateToStartFiltering = { name -> navHostController.navigateStartFiltering(name) } ) } From b65f7732d118bfda58d12f327be1fdd6a05e05a4 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 03:54:18 +0900 Subject: [PATCH 02/33] =?UTF-8?q?[UI/#216]=20=ED=99=88=20=EC=8B=9C?= =?UTF-8?q?=EC=9E=91=20=ED=99=94=EB=A9=B4=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../{StartHomeScreen.kt => StartHomeRoute.kt} | 50 +++++++++++-------- .../filtering/starthome/StartHomeState.kt | 5 ++ .../filtering/starthome/StartHomeViewModel.kt | 16 ++++++ .../navigation/StartHomeNavigation.kt | 4 +- 4 files changed, 51 insertions(+), 24 deletions(-) rename feature/src/main/java/com/terning/feature/filtering/starthome/{StartHomeScreen.kt => StartHomeRoute.kt} (79%) create mode 100644 feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeState.kt create mode 100644 feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeViewModel.kt diff --git a/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeScreen.kt b/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeRoute.kt similarity index 79% rename from feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeScreen.kt rename to feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeRoute.kt index 63b92593f..19dfda750 100644 --- a/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeScreen.kt +++ b/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeRoute.kt @@ -14,9 +14,6 @@ import androidx.compose.material3.Text import androidx.compose.runtime.Composable import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.getValue -import androidx.compose.runtime.mutableStateOf -import androidx.compose.runtime.remember -import androidx.compose.runtime.setValue import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.platform.LocalConfiguration @@ -24,9 +21,8 @@ import androidx.compose.ui.res.stringResource import androidx.compose.ui.text.style.TextAlign import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp -import androidx.navigation.NavController -import androidx.navigation.NavOptions -import androidx.navigation.compose.rememberNavController +import androidx.hilt.navigation.compose.hiltViewModel +import androidx.lifecycle.compose.collectAsStateWithLifecycle import com.airbnb.lottie.compose.LottieAnimation import com.airbnb.lottie.compose.LottieCompositionSpec import com.airbnb.lottie.compose.LottieConstants @@ -35,29 +31,39 @@ import com.terning.core.designsystem.component.button.RectangleButton import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme import com.terning.feature.R -import com.terning.feature.home.home.navigation.navigateHome -import com.terning.feature.main.MainNavigator -import com.terning.feature.main.rememberMainNavigator -import com.terning.feature.onboarding.signin.navigation.SignIn import kotlinx.coroutines.delay @Composable -fun StartHomeScreen( - modifier: Modifier = Modifier, - navigateToHome: () -> Unit +fun StartHomeRoute( + navigateToHome: () -> Unit, + viewModel: StartHomeViewModel = hiltViewModel() ) { - var isVisible by remember { mutableStateOf(false) } + val state by viewModel.state.collectAsStateWithLifecycle() val configuration = LocalConfiguration.current val screenHeight = 780f / configuration.screenHeightDp LaunchedEffect(key1 = true) { delay(DELAY) - isVisible = true + viewModel.updateButtonState() } + StartHomeScreen( + navigateToHome = navigateToHome, + buttonState = state.isButtonVisible, + screenHeight = screenHeight + ) +} + +@Composable +fun StartHomeScreen( + navigateToHome: () -> Unit, + buttonState: Boolean, + screenHeight: Float +) { + Box( - modifier = modifier.fillMaxSize() + modifier = Modifier.fillMaxSize() ) { Column( modifier = Modifier.fillMaxSize(), @@ -79,23 +85,21 @@ fun StartHomeScreen( contentAlignment = Alignment.BottomCenter ) { AnimatedVisibility( - visible = isVisible, + visible = buttonState, enter = fadeIn(initialAlpha = 0.3f), ) { RectangleButton( style = TerningTheme.typography.button0, paddingVertical = 20.dp, text = R.string.start_home_next_button, - onButtonClick = { - navigateToHome() - }, + onButtonClick = navigateToHome, ) } } } } -private const val DELAY : Long = 1000 +private const val DELAY: Long = 1000 @Composable fun StartHomeLottieAnimation( @@ -122,7 +126,9 @@ fun StartHomeLottieAnimation( fun StartHomeScreenPreview() { TerningPointTheme { StartHomeScreen( - navigateToHome = {} + navigateToHome = {}, + buttonState = true, + screenHeight = 1f ) } } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeState.kt b/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeState.kt new file mode 100644 index 000000000..d847568bc --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeState.kt @@ -0,0 +1,5 @@ +package com.terning.feature.filtering.starthome + +data class StartHomeState( + val isButtonVisible: Boolean = false +) \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeViewModel.kt new file mode 100644 index 000000000..e0e038372 --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/starthome/StartHomeViewModel.kt @@ -0,0 +1,16 @@ +package com.terning.feature.filtering.starthome + +import androidx.lifecycle.ViewModel +import kotlinx.coroutines.flow.MutableStateFlow +import kotlinx.coroutines.flow.StateFlow +import kotlinx.coroutines.flow.asStateFlow + +class StartHomeViewModel : ViewModel() { + private val _state: MutableStateFlow = + MutableStateFlow(StartHomeState()) + val state: StateFlow get() = _state.asStateFlow() + + fun updateButtonState() { + _state.value = _state.value.copy(isButtonVisible = true) + } +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/starthome/navigation/StartHomeNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/starthome/navigation/StartHomeNavigation.kt index ed29bcf97..fb3369a51 100644 --- a/feature/src/main/java/com/terning/feature/filtering/starthome/navigation/StartHomeNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/starthome/navigation/StartHomeNavigation.kt @@ -8,7 +8,7 @@ import androidx.navigation.NavHostController import androidx.navigation.NavOptions import androidx.navigation.compose.composable import com.terning.core.navigation.Route -import com.terning.feature.filtering.starthome.StartHomeScreen +import com.terning.feature.filtering.starthome.StartHomeRoute import com.terning.feature.home.home.navigation.navigateHome import com.terning.feature.onboarding.signin.navigation.SignIn import kotlinx.serialization.Serializable @@ -37,7 +37,7 @@ fun NavGraphBuilder.startHomeNavGraph( ExitTransition.None } ) { - StartHomeScreen(navigateToHome = { + StartHomeRoute(navigateToHome = { navHostController.navigateHome( navOptions = NavOptions.Builder().setPopUpTo( route = SignIn, From 34542d3d2c091504f40f4a57c38323d28a401863 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 04:15:27 +0900 Subject: [PATCH 03/33] =?UTF-8?q?[UI/#216]=20=ED=95=84=ED=84=B0=EB=A7=81?= =?UTF-8?q?=20=EB=B2=84=ED=8A=BC=20UI=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../component/button/FilteringButton.kt | 30 +++++++--------- .../terning/core/designsystem/theme/Color.kt | 1 + .../filtering/filtering/FilteringOneScreen.kt | 34 +++++++++---------- .../component/StatusOneRadioGroup.kt | 2 +- feature/src/main/res/values/strings.xml | 2 +- 5 files changed, 32 insertions(+), 37 deletions(-) diff --git a/core/src/main/java/com/terning/core/designsystem/component/button/FilteringButton.kt b/core/src/main/java/com/terning/core/designsystem/component/button/FilteringButton.kt index 69560b6dc..f0c50d820 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/button/FilteringButton.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/button/FilteringButton.kt @@ -23,13 +23,11 @@ import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.Dp import androidx.compose.ui.unit.dp import com.terning.core.R -import com.terning.core.designsystem.theme.Grey400 +import com.terning.core.designsystem.theme.Grey150 +import com.terning.core.designsystem.theme.Grey200 +import com.terning.core.designsystem.theme.Grey375 import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.TerningPointTheme -import com.terning.core.designsystem.theme.TerningSub1 -import com.terning.core.designsystem.theme.TerningSub3 -import com.terning.core.designsystem.theme.TerningSub4 -import com.terning.core.designsystem.theme.TerningSub5 import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.designsystem.theme.White import com.terning.core.util.NoRippleTheme @@ -58,19 +56,15 @@ fun FilteringButton( ) { val interactionSource = remember { MutableInteractionSource() } val isPressed by interactionSource.collectIsPressedAsState() - val backgroundColor = when { - !isSelected && !isPressed -> White - !isSelected && isPressed -> TerningSub5 - isSelected && !isPressed -> TerningSub4 - else -> TerningSub3 - } + val backgroundColor = White val textColor = when { - !isSelected -> Grey400 - else -> TerningMain + isSelected -> TerningMain + else -> Grey375 } val borderColor = when { - !isSelected -> TerningMain - else -> TerningSub1 + !isSelected && !isPressed -> Grey150 + isPressed -> Grey200 + else -> TerningMain } CompositionLocalProvider(LocalRippleTheme provides NoRippleTheme) { @@ -87,7 +81,7 @@ fun FilteringButton( color = borderColor ), shape = RoundedCornerShape(cornerRadius), - onClick = { onButtonClick() } + onClick = onButtonClick ) { Text( text = stringResource(id = text), @@ -104,14 +98,14 @@ fun FilteringButtonPreview() { TerningPointTheme { Column { FilteringButton( - isSelected = true, + isSelected = false, text = R.string.button_preview, cornerRadius = 15.dp, paddingVertical = 10.dp, onButtonClick = {} ) FilteringButton( - isSelected = false, + isSelected = true, text = R.string.button_preview, cornerRadius = 15.dp, paddingVertical = 10.dp, diff --git a/core/src/main/java/com/terning/core/designsystem/theme/Color.kt b/core/src/main/java/com/terning/core/designsystem/theme/Color.kt index bea5eb805..807bc9813 100644 --- a/core/src/main/java/com/terning/core/designsystem/theme/Color.kt +++ b/core/src/main/java/com/terning/core/designsystem/theme/Color.kt @@ -9,6 +9,7 @@ val Grey150 = Color(0xFFE9E9E9) val Grey200 = Color(0xFFDDDDDD) val Grey300 = Color(0xFFBCBCBC) val Grey350 = Color(0xFFADADAD) +val Grey375 = Color(0xFF898989) val Grey400 = Color(0xFF666666) val Grey500 = Color(0xFF373737) val Black = Color(0xFF171717) diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringOneScreen.kt b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringOneScreen.kt index 3f4a28c8c..a8065f029 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringOneScreen.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringOneScreen.kt @@ -1,5 +1,6 @@ package com.terning.feature.filtering.filtering +import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxSize @@ -12,11 +13,11 @@ import androidx.compose.runtime.mutableStateOf import androidx.compose.runtime.remember import androidx.compose.runtime.setValue import androidx.compose.ui.Modifier +import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import com.terning.core.designsystem.component.button.RectangleButton -import com.terning.core.designsystem.component.image.TerningImage import com.terning.core.designsystem.component.topappbar.BackButtonTopAppBar import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningPointTheme @@ -29,15 +30,13 @@ fun FilteringOneScreen( name: String, onNextClick: (Int) -> Unit, navigateUp: () -> Unit, - modifier: Modifier = Modifier, onButtonClick: (Int) -> Unit = {}, ) { val isButtonValid = remember { mutableStateOf(false) } - var grade by remember { mutableIntStateOf(-1) } Column( - modifier = modifier + modifier = Modifier ) { BackButtonTopAppBar( onBackButtonClick = { navigateUp() } @@ -45,12 +44,13 @@ fun FilteringOneScreen( Column( modifier = Modifier.fillMaxSize() ) { - TerningImage( - painter = R.drawable.ic_filtering_status1, - modifier = modifier.padding( - top = 20.dp, + Image( + painter = painterResource(id = R.drawable.ic_filtering_status1), + modifier = Modifier.padding( + top = 28.dp, start = 24.dp - ) + ), + contentDescription = "filtering one status" ) Text( text = stringResource( @@ -58,8 +58,8 @@ fun FilteringOneScreen( name ), style = TerningTheme.typography.title3, - modifier = modifier.padding( - top = 19.dp, + modifier = Modifier.padding( + top = 20.dp, start = 24.dp ) ) @@ -70,10 +70,10 @@ fun FilteringOneScreen( ), style = TerningTheme.typography.body5, color = Grey300, - modifier = modifier.padding( - top = 3.dp, + modifier = Modifier.padding( + top = 4.dp, start = 24.dp, - bottom = 25.dp + bottom = 24.dp ) ) StatusOneRadioGroup( @@ -86,18 +86,18 @@ fun FilteringOneScreen( Text( text = stringResource(id = R.string.filtering_status1_warning), style = TerningTheme.typography.detail3, - modifier = modifier.padding( + modifier = Modifier.padding( start = 24.dp, top = 9.dp ) ) - Spacer(modifier = modifier.weight(1f)) + Spacer(modifier = Modifier.weight(1f)) RectangleButton( style = TerningTheme.typography.button0, paddingVertical = 20.dp, text = R.string.filtering_button, onButtonClick = { onNextClick(grade) }, - modifier = modifier.padding(bottom = 12.dp), + modifier = Modifier.padding(bottom = 12.dp), isEnabled = isButtonValid.value ) } diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusOneRadioGroup.kt b/feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusOneRadioGroup.kt index 9aa695c6a..d37dc6471 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusOneRadioGroup.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusOneRadioGroup.kt @@ -55,7 +55,7 @@ fun StatusOneRadioGroup( onButtonClick(index) }, cornerRadius = 15.dp, - paddingVertical = 15.dp + paddingVertical = 14.dp ) } } diff --git a/feature/src/main/res/values/strings.xml b/feature/src/main/res/values/strings.xml index 187a825d0..f900df251 100644 --- a/feature/src/main/res/values/strings.xml +++ b/feature/src/main/res/values/strings.xml @@ -100,7 +100,7 @@ 대학생 인턴, 누구보다 빠르게 시작해 보세요! 인턴이라는 좋은 기회로 단숨에 스펙업하세요! 지금까지 준비한 역량을 인턴으로 발휘해 보세요! - 사회초년생으로 도약하기 위한 마지막 단계를 경험하세요! + 사회초년생으로 도약하는 마지막 단계를 경험하세요! 희망하는 인턴 근무 기간을 선택해 주세요 선택한 기간 동안 근무할 수 있는 인턴 공고를 찾아드릴게요 1개월 ~ 3개월 From 6211928481e2a503e24687912b45e8f90c8f11db Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 04:22:29 +0900 Subject: [PATCH 04/33] =?UTF-8?q?[UI/#216]=20=ED=95=84=ED=84=B0=EB=A7=81?= =?UTF-8?q?=20=EB=B2=84=ED=8A=BC=20UI=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../filtering/FilteringThreeRoute.kt | 39 ++++++++++--------- ...eEffect.kt => FilteringThreeSideEffect.kt} | 6 +-- .../filtering/filtering/FilteringTwoScreen.kt | 32 +++++++-------- .../filtering/filtering/FilteringViewModel.kt | 8 ++-- 4 files changed, 43 insertions(+), 42 deletions(-) rename feature/src/main/java/com/terning/feature/filtering/filtering/{FilteringSideEffect.kt => FilteringThreeSideEffect.kt} (55%) diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt index b51640a80..c6b5d9c79 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt @@ -1,5 +1,6 @@ package com.terning.feature.filtering.filtering +import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxSize @@ -13,6 +14,7 @@ import androidx.compose.runtime.remember import androidx.compose.runtime.setValue import androidx.compose.ui.Modifier import androidx.compose.ui.platform.LocalContext +import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp @@ -21,7 +23,6 @@ import androidx.lifecycle.compose.LocalLifecycleOwner import androidx.lifecycle.flowWithLifecycle import com.terning.core.designsystem.component.button.RectangleButton import com.terning.core.designsystem.component.datepicker.DatePickerUI -import com.terning.core.designsystem.component.image.TerningImage import com.terning.core.designsystem.component.topappbar.BackButtonTopAppBar import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningPointTheme @@ -61,8 +62,8 @@ fun FilteringThreeRoute( viewModel.sideEffects.flowWithLifecycle(lifecycle = lifecycleOwner.lifecycle) .collect { sideEffect -> when (sideEffect) { - is FilteringSideEffect.NavigateToStartHome -> navigateToStartHome() - is FilteringSideEffect.ShowToast -> context.toast(sideEffect.message) + is FilteringThreeSideEffect.NavigateToStartHome -> navigateToStartHome() + is FilteringThreeSideEffect.ShowToast -> context.toast(sideEffect.message) } } } @@ -79,7 +80,6 @@ fun FilteringThreeRoute( @Composable fun FilteringThreeScreen( - modifier: Modifier = Modifier, navigateUp: () -> Unit, chosenYear: Int, chosenMonth: Int, @@ -88,7 +88,7 @@ fun FilteringThreeScreen( onNextClick: () -> Unit, ) { Column( - modifier = modifier, + modifier = Modifier, ) { BackButtonTopAppBar( onBackButtonClick = { navigateUp() } @@ -96,18 +96,19 @@ fun FilteringThreeScreen( Column( modifier = Modifier.fillMaxSize() ) { - TerningImage( - painter = R.drawable.ic_filtering_status3, - modifier = modifier.padding( - top = 20.dp, + Image( + painter = painterResource(id = R.drawable.ic_filtering_status3), + modifier = Modifier.padding( + top = 28.dp, start = 24.dp - ) + ), + contentDescription = "filtering three status" ) Text( text = stringResource(id = R.string.filtering_status3_title), style = TerningTheme.typography.title3, - modifier = modifier.padding( - top = 19.dp, + modifier = Modifier.padding( + top = 20.dp, start = 24.dp ) ) @@ -115,26 +116,26 @@ fun FilteringThreeScreen( text = stringResource(id = R.string.filtering_status3_sub), style = TerningTheme.typography.body5, color = Grey300, - modifier = modifier.padding( - top = 3.dp, + modifier = Modifier.padding( + top = 4.dp, start = 24.dp, - bottom = 25.dp + bottom = 24.dp ) ) - Spacer(modifier = modifier.weight(1f)) + Spacer(modifier = Modifier.weight(1f)) DatePickerUI( chosenYear = chosenYear, chosenMonth = chosenMonth, onYearChosen = { onYearChosen(it) }, onMonthChosen = { onMonthChosen(it) }, ) - Spacer(modifier = modifier.weight(3f)) + Spacer(modifier = Modifier.weight(3f)) RectangleButton( style = TerningTheme.typography.button0, paddingVertical = 20.dp, text = R.string.filtering_button, - onButtonClick = { onNextClick() }, - modifier = modifier.padding(bottom = 12.dp), + onButtonClick = onNextClick, + modifier = Modifier.padding(bottom = 12.dp), ) } } diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringSideEffect.kt b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeSideEffect.kt similarity index 55% rename from feature/src/main/java/com/terning/feature/filtering/filtering/FilteringSideEffect.kt rename to feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeSideEffect.kt index 52c9b3a68..da8d3dfa8 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringSideEffect.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeSideEffect.kt @@ -2,7 +2,7 @@ package com.terning.feature.filtering.filtering import androidx.annotation.StringRes -sealed class FilteringSideEffect { - data object NavigateToStartHome : FilteringSideEffect() - data class ShowToast(@StringRes val message: Int) : FilteringSideEffect() +sealed class FilteringThreeSideEffect { + data object NavigateToStartHome : FilteringThreeSideEffect() + data class ShowToast(@StringRes val message: Int) : FilteringThreeSideEffect() } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringTwoScreen.kt b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringTwoScreen.kt index e66df12e8..2f1e8c643 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringTwoScreen.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringTwoScreen.kt @@ -1,5 +1,6 @@ package com.terning.feature.filtering.filtering +import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxSize @@ -12,11 +13,11 @@ import androidx.compose.runtime.mutableStateOf import androidx.compose.runtime.remember import androidx.compose.runtime.setValue import androidx.compose.ui.Modifier +import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import com.terning.core.designsystem.component.button.RectangleButton -import com.terning.core.designsystem.component.image.TerningImage import com.terning.core.designsystem.component.topappbar.BackButtonTopAppBar import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningPointTheme @@ -29,15 +30,13 @@ fun FilteringTwoScreen( grade: Int, onNextClick: (Int, Int) -> Unit, navigateUp: () -> Unit, - modifier: Modifier = Modifier, onButtonClick: (Int) -> Unit = {}, ) { val isButtonValid = remember { mutableStateOf(false) } - var workingPeriod by remember { mutableIntStateOf(-1) } Column( - modifier = modifier + modifier = Modifier ) { BackButtonTopAppBar( onBackButtonClick = { navigateUp() } @@ -45,18 +44,19 @@ fun FilteringTwoScreen( Column( modifier = Modifier.fillMaxSize() ) { - TerningImage( - painter = R.drawable.ic_filtering_status2, - modifier = modifier.padding( - top = 20.dp, + Image( + painter = painterResource(id = R.drawable.ic_filtering_status2), + modifier = Modifier.padding( + top = 28.dp, start = 24.dp - ) + ), + contentDescription = "filtering two status" ) Text( text = stringResource(id = R.string.filtering_status2_title), style = TerningTheme.typography.title3, - modifier = modifier.padding( - top = 19.dp, + modifier = Modifier.padding( + top = 20.dp, start = 24.dp ) ) @@ -64,10 +64,10 @@ fun FilteringTwoScreen( text = stringResource(id = R.string.filtering_status2_sub), style = TerningTheme.typography.body5, color = Grey300, - modifier = modifier.padding( - top = 3.dp, + modifier = Modifier.padding( + top = 4.dp, start = 24.dp, - bottom = 25.dp + bottom = 24.dp ) ) StatusTwoRadioGroup( @@ -77,13 +77,13 @@ fun FilteringTwoScreen( workingPeriod = index } ) - Spacer(modifier = modifier.weight(1f)) + Spacer(modifier = Modifier.weight(1f)) RectangleButton( style = TerningTheme.typography.button0, paddingVertical = 20.dp, text = R.string.filtering_button, onButtonClick = { onNextClick(grade, workingPeriod) }, - modifier = modifier.padding(bottom = 12.dp), + modifier = Modifier.padding(bottom = 12.dp), isEnabled = isButtonValid.value ) } diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringViewModel.kt index 692117fab..b4b85b1a5 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringViewModel.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringViewModel.kt @@ -25,8 +25,8 @@ class FilteringViewModel @Inject constructor( private val _state = MutableStateFlow(FilteringState()) val state: StateFlow get() = _state.asStateFlow() - private val _sideEffects = MutableSharedFlow() - val sideEffects: SharedFlow get() = _sideEffects.asSharedFlow() + private val _sideEffects = MutableSharedFlow() + val sideEffects: SharedFlow get() = _sideEffects.asSharedFlow() fun fetchGrade(grade: Int) { _state.value = _state.value.copy(grade = grade) @@ -57,9 +57,9 @@ class FilteringViewModel @Inject constructor( ) } ).onSuccess { - _sideEffects.emit(FilteringSideEffect.NavigateToStartHome) + _sideEffects.emit(FilteringThreeSideEffect.NavigateToStartHome) }.onFailure { - _sideEffects.emit(FilteringSideEffect.ShowToast(R.string.server_failure)) + _sideEffects.emit(FilteringThreeSideEffect.ShowToast(R.string.server_failure)) } } } From df3752641887484aa06e31606fa58dda418c9e17 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 05:59:25 +0900 Subject: [PATCH 05/33] =?UTF-8?q?[UI/#218]=20YearMonthPicker=20=EA=B5=AC?= =?UTF-8?q?=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- feature/build.gradle.kts | 3 +- .../filtering/FilteringThreeRoute.kt | 19 +- .../filtering/component/YearMonthPicker.kt | 162 ++++++++++++++++++ gradle/libs.versions.toml | 6 +- 4 files changed, 179 insertions(+), 11 deletions(-) create mode 100644 feature/src/main/java/com/terning/feature/filtering/filtering/component/YearMonthPicker.kt diff --git a/feature/build.gradle.kts b/feature/build.gradle.kts index 6b56a6904..00c9bc09d 100644 --- a/feature/build.gradle.kts +++ b/feature/build.gradle.kts @@ -70,6 +70,7 @@ dependencies { implementation(libs.hilt.compiler) implementation(libs.androidx.lifecycle.runtime.compose.android) implementation(libs.androidx.compose.saveable) + implementation(libs.androidx.compose.material) // KspDependencies ksp(libs.hilt.android.compiler) @@ -94,11 +95,11 @@ dependencies { implementation(libs.accompanist.systemuicontroller) implementation (libs.androidx.core.splashscreen) implementation (libs.androidx.browser) + implementation(libs.compose.date.time.picker) // Compose Preview implementation(libs.compose.ui.tooling) // KakaoDependencies implementation(libs.kakao.user) - } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt index c6b5d9c79..387dc519a 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt @@ -22,13 +22,13 @@ import androidx.hilt.navigation.compose.hiltViewModel import androidx.lifecycle.compose.LocalLifecycleOwner import androidx.lifecycle.flowWithLifecycle import com.terning.core.designsystem.component.button.RectangleButton -import com.terning.core.designsystem.component.datepicker.DatePickerUI import com.terning.core.designsystem.component.topappbar.BackButtonTopAppBar import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.extension.toast import com.terning.feature.R +import com.terning.feature.filtering.filtering.component.YearMonthPicker import java.util.Calendar @Composable @@ -119,17 +119,20 @@ fun FilteringThreeScreen( modifier = Modifier.padding( top = 4.dp, start = 24.dp, - bottom = 24.dp ) ) Spacer(modifier = Modifier.weight(1f)) - DatePickerUI( - chosenYear = chosenYear, - chosenMonth = chosenMonth, - onYearChosen = { onYearChosen(it) }, - onMonthChosen = { onMonthChosen(it) }, + YearMonthPicker( + years = (2010..2030).map { it.toString() }, + months = (1..12).map { it.toString() }, ) - Spacer(modifier = Modifier.weight(3f)) +// DatePickerUI( +// chosenYear = chosenYear, +// chosenMonth = chosenMonth, +// onYearChosen = { onYearChosen(it) }, +// onMonthChosen = { onMonthChosen(it) }, +// ) + Spacer(modifier = Modifier.weight(6f)) RectangleButton( style = TerningTheme.typography.button0, paddingVertical = 20.dp, diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/component/YearMonthPicker.kt b/feature/src/main/java/com/terning/feature/filtering/filtering/component/YearMonthPicker.kt new file mode 100644 index 000000000..12e46a0b6 --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/filtering/component/YearMonthPicker.kt @@ -0,0 +1,162 @@ +package com.terning.feature.filtering.filtering.component + +import androidx.compose.foundation.gestures.snapping.rememberSnapFlingBehavior +import androidx.compose.foundation.layout.Arrangement +import androidx.compose.foundation.layout.Box +import androidx.compose.foundation.layout.Row +import androidx.compose.foundation.layout.Spacer +import androidx.compose.foundation.layout.fillMaxWidth +import androidx.compose.foundation.layout.height +import androidx.compose.foundation.layout.offset +import androidx.compose.foundation.layout.padding +import androidx.compose.foundation.layout.width +import androidx.compose.foundation.lazy.LazyColumn +import androidx.compose.foundation.lazy.rememberLazyListState +import androidx.compose.material3.HorizontalDivider +import androidx.compose.material3.Text +import androidx.compose.runtime.Composable +import androidx.compose.runtime.LaunchedEffect +import androidx.compose.runtime.getValue +import androidx.compose.runtime.mutableIntStateOf +import androidx.compose.runtime.remember +import androidx.compose.runtime.setValue +import androidx.compose.runtime.snapshotFlow +import androidx.compose.ui.Alignment +import androidx.compose.ui.Modifier +import androidx.compose.ui.graphics.Color +import androidx.compose.ui.layout.onSizeChanged +import androidx.compose.ui.platform.LocalDensity +import androidx.compose.ui.text.style.TextAlign +import androidx.compose.ui.unit.IntSize +import androidx.compose.ui.unit.dp +import com.kez.picker.PickerState +import com.kez.picker.rememberPickerState +import com.terning.core.designsystem.theme.Grey300 +import com.terning.core.designsystem.theme.Grey500 +import com.terning.core.designsystem.theme.TerningMain +import com.terning.core.designsystem.theme.TerningTheme +import kotlinx.coroutines.flow.distinctUntilChanged +import kotlinx.coroutines.flow.map + +@Composable +fun YearMonthPicker( + years: List, + months: List, + modifier: Modifier = Modifier, + yearPickerState: PickerState = rememberPickerState(), + monthPickerState: PickerState = rememberPickerState(), + startYearIndex: Int = 5, + startMonthIndex: Int = 2, +) { + Row( + modifier = modifier + .fillMaxWidth() + .padding(95.dp), + horizontalArrangement = Arrangement.SpaceBetween + ) { + DatePicker( + modifier = Modifier.weight(1f), + pickerState = yearPickerState, + items = years, + startIndex = startYearIndex, + ) + Spacer(modifier = Modifier.width(25.dp)) + DatePicker( + modifier = Modifier.weight(1f), + pickerState = monthPickerState, + items = months, + startIndex = startMonthIndex, + ) + } +} + +@Composable +fun DatePicker( + items: List, + modifier: Modifier = Modifier, + pickerState: PickerState = rememberPickerState(), + startIndex: Int = 0, + visibleItemCount: Int = 3, +) { + var itemHeightPixel by remember { mutableIntStateOf(0) } + val itemHeightDp = with(LocalDensity.current) { itemHeightPixel.toDp() } + + val visibleItemsMiddle = visibleItemCount / 2 + val scrollState = rememberLazyListState(initialFirstVisibleItemIndex = startIndex) + val flingBehavior = rememberSnapFlingBehavior(lazyListState = scrollState) + + LaunchedEffect(itemHeightPixel) { + if (itemHeightPixel > 0) scrollState.scrollToItem(startIndex) + } + + LaunchedEffect(scrollState) { + snapshotFlow { scrollState.firstVisibleItemIndex } + .map { index -> items.getOrNull(index) } + .distinctUntilChanged() + .collect { item -> + if (item != null) { + pickerState.selectedItem = item + } + } + } + + Box( + modifier = modifier + ) { + LazyColumn( + modifier = Modifier + .fillMaxWidth() + .height(itemHeightDp * visibleItemCount), + flingBehavior = flingBehavior, + state = scrollState, + horizontalAlignment = Alignment.CenterHorizontally + ) { + items(visibleItemsMiddle) { + Spacer(modifier = Modifier.height(itemHeightDp)) + } + items(items.size) { index -> + DatePickerContent( + modifier = Modifier + .onSizeChanged { intSize: IntSize -> itemHeightPixel = intSize.height }, + text = items[index], + color = if (pickerState.selectedItem == items[index]) Grey500 else Grey300 + ) + } + items(visibleItemsMiddle) { + Spacer(modifier = Modifier.height(itemHeightDp)) + } + } + HorizontalDivider( + modifier = Modifier + .offset(y = itemHeightDp * visibleItemsMiddle) + .padding(horizontal = 7.dp), + color = TerningMain, + thickness = 1.dp + ) + HorizontalDivider( + modifier = Modifier + .offset(y = itemHeightDp * (visibleItemsMiddle + 1)) + .padding(horizontal = 7.dp), + color = TerningMain, + thickness = 1.dp + ) + } +} + +@Composable +fun DatePickerContent( + color: Color, + text: String, + modifier: Modifier = Modifier, +) { + Box( + modifier = modifier.padding(vertical = 11.dp) + ) { + Text( + text = text, + textAlign = TextAlign.Center, + style = TerningTheme.typography.title3, + color = color, + ) + } +} \ No newline at end of file diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 33b6c185d..27a38941f 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -23,11 +23,10 @@ ksp = "1.9.0-1.0.12" ## Compose androidxComposeBom = "2024.04.01" -androidxComposeCompiler = "1.5.14" androidxComposeMaterial3 = "1.2.1" composeNavigation = "2.8.0-beta04" composeSavable = "1.4.3" -composeFlowRow = "0.30.0" +composeDateTimePicker = "0.0.2" ## Hilt hilt = "2.48.1" @@ -92,11 +91,13 @@ browser = "1.4.0" ## dokka dokka = "1.9.0" +composeMaterial = "1.3.1" [libraries] androidx-core-ktx = { group = "androidx.core", name = "core-ktx", version.ref = "androidxCore" } androidx-appcompat = { group = "androidx.appcompat", name = "appcompat", version.ref = "androidxAppCompat" } androidx-core-splashscreen = { module = "androidx.core:core-splashscreen", version.ref = "coreSplashscreen" } +compose-date-time-picker = { module = "io.github.kez-lab:compose-date-time-picker", version.ref = "composeDateTimePicker" } junit = { group = "junit", name = "junit", version.ref = "junit" } androidx-junit = { group = "androidx.test.ext", name = "junit", version.ref = "junitVersion" } androidx-activity-compose = { group = "androidx.activity", name = "activity-compose", version.ref = "androidxActivity" } @@ -171,6 +172,7 @@ kakao-user = {group = "com.kakao.sdk", name = "v2-user", version.ref = "kakaoVer process-phoenix = {group = "com.jakewharton", name = "process-phoenix", version.ref = "processPhoenix"} accompanist-systemuicontroller = { module = "com.google.accompanist:accompanist-systemuicontroller", version.ref = "accompanistSystemuicontroller" } +androidx-compose-material = { group = "androidx.wear.compose", name = "compose-material", version.ref = "composeMaterial" } [plugins] android-application = { id = "com.android.application", version.ref = "androidGradlePlugin" } From 90f1c9e2c2bf98806bedb1ea9b09a60e78ccb419 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 06:09:45 +0900 Subject: [PATCH 06/33] =?UTF-8?q?[MOVE/#218]=20=ED=8C=8C=EC=9D=BC=20?= =?UTF-8?q?=EC=9C=84=EC=B9=98=20=EC=9D=B4=EB=8F=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- feature/build.gradle.kts | 1 - .../FilteringOneScreen.kt | 4 ++-- .../component/StatusOneRadioGroup.kt | 2 +- .../navigation/FilteringOneNavigation.kt | 5 +++-- .../FilteringState.kt | 2 +- .../FilteringThreeRoute.kt | 4 ++-- .../FilteringThreeSideEffect.kt | 2 +- .../FilteringViewModel.kt | 2 +- .../component/YearMonthPicker.kt | 14 +++++++++++--- .../navigation/FilteringThreeNavigation.kt | 4 ++-- .../FilteringTwoScreen.kt | 4 ++-- .../component/StatusTwoRadioGroup.kt | 2 +- .../navigation/FilteringTwoNavigation.kt | 5 +++-- .../navigation/StartFilteringNavigation.kt | 2 +- .../java/com/terning/feature/main/MainScreen.kt | 6 +++--- .../signup/navigation/SignUpNavigation.kt | 1 - gradle/libs.versions.toml | 2 -- 17 files changed, 34 insertions(+), 28 deletions(-) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringone}/FilteringOneScreen.kt (96%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringone}/component/StatusOneRadioGroup.kt (97%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringone}/navigation/FilteringOneNavigation.kt (82%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringthree}/FilteringState.kt (73%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringthree}/FilteringThreeRoute.kt (97%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringthree}/FilteringThreeSideEffect.kt (81%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringthree}/FilteringViewModel.kt (97%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringthree}/component/YearMonthPicker.kt (95%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringthree}/navigation/FilteringThreeNavigation.kt (89%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringtwo}/FilteringTwoScreen.kt (96%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringtwo}/component/StatusTwoRadioGroup.kt (97%) rename feature/src/main/java/com/terning/feature/filtering/{filtering => filteringtwo}/navigation/FilteringTwoNavigation.kt (83%) diff --git a/feature/build.gradle.kts b/feature/build.gradle.kts index 00c9bc09d..e157e7816 100644 --- a/feature/build.gradle.kts +++ b/feature/build.gradle.kts @@ -95,7 +95,6 @@ dependencies { implementation(libs.accompanist.systemuicontroller) implementation (libs.androidx.core.splashscreen) implementation (libs.androidx.browser) - implementation(libs.compose.date.time.picker) // Compose Preview implementation(libs.compose.ui.tooling) diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringOneScreen.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneScreen.kt similarity index 96% rename from feature/src/main/java/com/terning/feature/filtering/filtering/FilteringOneScreen.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneScreen.kt index a8065f029..8d0d3afcc 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringOneScreen.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneScreen.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering +package com.terning.feature.filtering.filteringone import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Column @@ -23,7 +23,7 @@ import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme import com.terning.feature.R -import com.terning.feature.filtering.filtering.component.StatusOneRadioGroup +import com.terning.feature.filtering.filteringone.component.StatusOneRadioGroup @Composable fun FilteringOneScreen( diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusOneRadioGroup.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/component/StatusOneRadioGroup.kt similarity index 97% rename from feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusOneRadioGroup.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringone/component/StatusOneRadioGroup.kt index d37dc6471..80608aa73 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusOneRadioGroup.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/component/StatusOneRadioGroup.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering.component +package com.terning.feature.filtering.filteringone.component import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.fillMaxWidth diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringOneNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt similarity index 82% rename from feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringOneNavigation.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt index 266137688..e5f25807e 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringOneNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering.navigation +package com.terning.feature.filtering.filteringone.navigation import androidx.navigation.NavController import androidx.navigation.NavGraphBuilder @@ -7,7 +7,8 @@ import androidx.navigation.NavOptions import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route -import com.terning.feature.filtering.filtering.FilteringOneScreen +import com.terning.feature.filtering.filteringone.FilteringOneScreen +import com.terning.feature.filtering.filteringtwo.navigation.navigateFilteringTwo import kotlinx.serialization.Serializable fun NavController.navigateFilteringOne( diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringState.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringState.kt similarity index 73% rename from feature/src/main/java/com/terning/feature/filtering/filtering/FilteringState.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringState.kt index b35e6fbd2..7f75fc847 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringState.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringState.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering +package com.terning.feature.filtering.filteringthree data class FilteringState( val grade: Int = -1, diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt similarity index 97% rename from feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt index 387dc519a..faeb3e310 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering +package com.terning.feature.filtering.filteringthree import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Column @@ -28,7 +28,7 @@ import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.extension.toast import com.terning.feature.R -import com.terning.feature.filtering.filtering.component.YearMonthPicker +import com.terning.feature.filtering.filteringthree.component.YearMonthPicker import java.util.Calendar @Composable diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeSideEffect.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeSideEffect.kt similarity index 81% rename from feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeSideEffect.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeSideEffect.kt index da8d3dfa8..42cb61d6f 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringThreeSideEffect.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeSideEffect.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering +package com.terning.feature.filtering.filteringthree import androidx.annotation.StringRes diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt similarity index 97% rename from feature/src/main/java/com/terning/feature/filtering/filtering/FilteringViewModel.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt index b4b85b1a5..7b5a64cf2 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringViewModel.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering +package com.terning.feature.filtering.filteringthree import androidx.lifecycle.ViewModel import androidx.lifecycle.viewModelScope diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/component/YearMonthPicker.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt similarity index 95% rename from feature/src/main/java/com/terning/feature/filtering/filtering/component/YearMonthPicker.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt index 12e46a0b6..87e8dd41a 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/component/YearMonthPicker.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering.component +package com.terning.feature.filtering.filteringthree.component import androidx.compose.foundation.gestures.snapping.rememberSnapFlingBehavior import androidx.compose.foundation.layout.Arrangement @@ -29,14 +29,22 @@ import androidx.compose.ui.platform.LocalDensity import androidx.compose.ui.text.style.TextAlign import androidx.compose.ui.unit.IntSize import androidx.compose.ui.unit.dp -import com.kez.picker.PickerState -import com.kez.picker.rememberPickerState import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.Grey500 import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.TerningTheme import kotlinx.coroutines.flow.distinctUntilChanged import kotlinx.coroutines.flow.map +import androidx.compose.runtime.mutableStateOf + +class PickerState { + var selectedItem by mutableStateOf("") +} + +@Composable +fun rememberPickerState() = remember { + PickerState() +} @Composable fun YearMonthPicker( diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringThreeNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/navigation/FilteringThreeNavigation.kt similarity index 89% rename from feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringThreeNavigation.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringthree/navigation/FilteringThreeNavigation.kt index 759c65c4d..57580223c 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringThreeNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/navigation/FilteringThreeNavigation.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering.navigation +package com.terning.feature.filtering.filteringthree.navigation import androidx.navigation.NavController import androidx.navigation.NavGraphBuilder @@ -7,7 +7,7 @@ import androidx.navigation.NavOptions import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route -import com.terning.feature.filtering.filtering.FilteringThreeRoute +import com.terning.feature.filtering.filteringthree.FilteringThreeRoute import com.terning.feature.filtering.starthome.navigation.navigateStartHome import kotlinx.serialization.Serializable diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringTwoScreen.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoScreen.kt similarity index 96% rename from feature/src/main/java/com/terning/feature/filtering/filtering/FilteringTwoScreen.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoScreen.kt index 2f1e8c643..7f2849ce2 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/FilteringTwoScreen.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoScreen.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering +package com.terning.feature.filtering.filteringtwo import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Column @@ -23,7 +23,7 @@ import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme import com.terning.feature.R -import com.terning.feature.filtering.filtering.component.StatusTwoRadioGroup +import com.terning.feature.filtering.filteringtwo.component.StatusTwoRadioGroup @Composable fun FilteringTwoScreen( diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusTwoRadioGroup.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/component/StatusTwoRadioGroup.kt similarity index 97% rename from feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusTwoRadioGroup.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringtwo/component/StatusTwoRadioGroup.kt index 6d42ee42a..ed06f467b 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/component/StatusTwoRadioGroup.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/component/StatusTwoRadioGroup.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering.component +package com.terning.feature.filtering.filteringtwo.component import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.fillMaxWidth diff --git a/feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringTwoNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/navigation/FilteringTwoNavigation.kt similarity index 83% rename from feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringTwoNavigation.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringtwo/navigation/FilteringTwoNavigation.kt index 0bde2ac5e..ab417cdab 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filtering/navigation/FilteringTwoNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/navigation/FilteringTwoNavigation.kt @@ -1,4 +1,4 @@ -package com.terning.feature.filtering.filtering.navigation +package com.terning.feature.filtering.filteringtwo.navigation import androidx.navigation.NavController import androidx.navigation.NavGraphBuilder @@ -7,7 +7,8 @@ import androidx.navigation.NavOptions import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route -import com.terning.feature.filtering.filtering.FilteringTwoScreen +import com.terning.feature.filtering.filteringtwo.FilteringTwoScreen +import com.terning.feature.filtering.filteringthree.navigation.navigateFilteringThree import kotlinx.serialization.Serializable fun NavController.navigateFilteringTwo( diff --git a/feature/src/main/java/com/terning/feature/filtering/startfiltering/navigation/StartFilteringNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/startfiltering/navigation/StartFilteringNavigation.kt index f217cf39e..12b8a4cdc 100644 --- a/feature/src/main/java/com/terning/feature/filtering/startfiltering/navigation/StartFilteringNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/startfiltering/navigation/StartFilteringNavigation.kt @@ -7,7 +7,7 @@ import androidx.navigation.NavOptions import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route -import com.terning.feature.filtering.filtering.navigation.navigateFilteringOne +import com.terning.feature.filtering.filteringone.navigation.navigateFilteringOne import com.terning.feature.filtering.startfiltering.StartFilteringRoute import kotlinx.serialization.Serializable diff --git a/feature/src/main/java/com/terning/feature/main/MainScreen.kt b/feature/src/main/java/com/terning/feature/main/MainScreen.kt index e5fbb5d02..f4df34f39 100644 --- a/feature/src/main/java/com/terning/feature/main/MainScreen.kt +++ b/feature/src/main/java/com/terning/feature/main/MainScreen.kt @@ -25,9 +25,9 @@ import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.White import com.terning.core.util.NoRippleInteractionSource import com.terning.feature.calendar.calendar.navigation.calendarNavGraph -import com.terning.feature.filtering.filtering.navigation.filteringOneNavGraph -import com.terning.feature.filtering.filtering.navigation.filteringThreeNavGraph -import com.terning.feature.filtering.filtering.navigation.filteringTwoNavGraph +import com.terning.feature.filtering.filteringone.navigation.filteringOneNavGraph +import com.terning.feature.filtering.filteringthree.navigation.filteringThreeNavGraph +import com.terning.feature.filtering.filteringtwo.navigation.filteringTwoNavGraph import com.terning.feature.filtering.startfiltering.navigation.startFilteringNavGraph import com.terning.feature.filtering.starthome.navigation.startHomeNavGraph import com.terning.feature.home.changefilter.navigation.changeFilterNavGraph diff --git a/feature/src/main/java/com/terning/feature/onboarding/signup/navigation/SignUpNavigation.kt b/feature/src/main/java/com/terning/feature/onboarding/signup/navigation/SignUpNavigation.kt index 95932966e..ff8c1978e 100644 --- a/feature/src/main/java/com/terning/feature/onboarding/signup/navigation/SignUpNavigation.kt +++ b/feature/src/main/java/com/terning/feature/onboarding/signup/navigation/SignUpNavigation.kt @@ -7,7 +7,6 @@ import androidx.navigation.NavOptions import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route -import com.terning.feature.filtering.filtering.navigation.navigateFilteringOne import com.terning.feature.filtering.startfiltering.navigation.navigateStartFiltering import com.terning.feature.onboarding.signup.SignUpRoute import kotlinx.serialization.Serializable diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 27a38941f..df2ce469f 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -26,7 +26,6 @@ androidxComposeBom = "2024.04.01" androidxComposeMaterial3 = "1.2.1" composeNavigation = "2.8.0-beta04" composeSavable = "1.4.3" -composeDateTimePicker = "0.0.2" ## Hilt hilt = "2.48.1" @@ -97,7 +96,6 @@ composeMaterial = "1.3.1" androidx-core-ktx = { group = "androidx.core", name = "core-ktx", version.ref = "androidxCore" } androidx-appcompat = { group = "androidx.appcompat", name = "appcompat", version.ref = "androidxAppCompat" } androidx-core-splashscreen = { module = "androidx.core:core-splashscreen", version.ref = "coreSplashscreen" } -compose-date-time-picker = { module = "io.github.kez-lab:compose-date-time-picker", version.ref = "composeDateTimePicker" } junit = { group = "junit", name = "junit", version.ref = "junit" } androidx-junit = { group = "androidx.test.ext", name = "junit", version.ref = "junitVersion" } androidx-activity-compose = { group = "androidx.activity", name = "activity-compose", version.ref = "androidxActivity" } From 8b6571514953f5797f5ddd9fdce7745b394638d9 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 06:15:48 +0900 Subject: [PATCH 07/33] =?UTF-8?q?[DEL/#218]=20=EC=95=88=20=EC=93=B0?= =?UTF-8?q?=EB=8A=94=20=EB=9D=BC=EC=9D=B4=EB=B8=8C=EB=9F=AC=EB=A6=AC=20?= =?UTF-8?q?=EC=82=AD=EC=A0=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- feature/build.gradle.kts | 1 - .../filtering/filteringthree/component/YearMonthPicker.kt | 4 +--- gradle/libs.versions.toml | 2 -- 3 files changed, 1 insertion(+), 6 deletions(-) diff --git a/feature/build.gradle.kts b/feature/build.gradle.kts index e157e7816..781cf168f 100644 --- a/feature/build.gradle.kts +++ b/feature/build.gradle.kts @@ -70,7 +70,6 @@ dependencies { implementation(libs.hilt.compiler) implementation(libs.androidx.lifecycle.runtime.compose.android) implementation(libs.androidx.compose.saveable) - implementation(libs.androidx.compose.material) // KspDependencies ksp(libs.hilt.android.compiler) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt index 87e8dd41a..fcf0bf129 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt @@ -42,9 +42,7 @@ class PickerState { } @Composable -fun rememberPickerState() = remember { - PickerState() -} +fun rememberPickerState() = remember { PickerState() } @Composable fun YearMonthPicker( diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index df2ce469f..2d60e8d41 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -90,7 +90,6 @@ browser = "1.4.0" ## dokka dokka = "1.9.0" -composeMaterial = "1.3.1" [libraries] androidx-core-ktx = { group = "androidx.core", name = "core-ktx", version.ref = "androidxCore" } @@ -170,7 +169,6 @@ kakao-user = {group = "com.kakao.sdk", name = "v2-user", version.ref = "kakaoVer process-phoenix = {group = "com.jakewharton", name = "process-phoenix", version.ref = "processPhoenix"} accompanist-systemuicontroller = { module = "com.google.accompanist:accompanist-systemuicontroller", version.ref = "accompanistSystemuicontroller" } -androidx-compose-material = { group = "androidx.wear.compose", name = "compose-material", version.ref = "composeMaterial" } [plugins] android-application = { id = "com.android.application", version.ref = "androidGradlePlugin" } From 9b9c7d2620ceae7c1b561e3c47ed4bfb1d266506 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 06:48:50 +0900 Subject: [PATCH 08/33] =?UTF-8?q?[FEAT/#218]=20=EB=8D=B0=EC=9D=B4=ED=8A=B8?= =?UTF-8?q?=ED=94=BC=EC=BB=A4=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../filteringthree/FilteringThreeRoute.kt | 16 ++--- .../component/YearMonthPicker.kt | 58 ++++++++++++++----- 2 files changed, 51 insertions(+), 23 deletions(-) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt index faeb3e310..e8e505b7f 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt @@ -43,7 +43,7 @@ fun FilteringThreeRoute( val lifecycleOwner = LocalLifecycleOwner.current val currentYear = Calendar.getInstance().get(Calendar.YEAR) - val currentMonth = Calendar.getInstance().get(Calendar.MONTH) + val currentMonth = Calendar.getInstance().get(Calendar.MONTH) + 1 var chosenYear by remember { mutableIntStateOf(currentYear) } var chosenMonth by remember { mutableIntStateOf(currentMonth) } @@ -123,16 +123,12 @@ fun FilteringThreeScreen( ) Spacer(modifier = Modifier.weight(1f)) YearMonthPicker( - years = (2010..2030).map { it.toString() }, - months = (1..12).map { it.toString() }, + chosenYear = chosenYear, + chosenMonth = chosenMonth, + onYearChosen = { onYearChosen(it) }, + onMonthChosen = { onMonthChosen(it) }, ) -// DatePickerUI( -// chosenYear = chosenYear, -// chosenMonth = chosenMonth, -// onYearChosen = { onYearChosen(it) }, -// onMonthChosen = { onMonthChosen(it) }, -// ) - Spacer(modifier = Modifier.weight(6f)) + Spacer(modifier = Modifier.weight(7f)) RectangleButton( style = TerningTheme.typography.button0, paddingVertical = 20.dp, diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt index fcf0bf129..4b790121a 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt @@ -18,6 +18,7 @@ import androidx.compose.runtime.Composable import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.getValue import androidx.compose.runtime.mutableIntStateOf +import androidx.compose.runtime.mutableStateOf import androidx.compose.runtime.remember import androidx.compose.runtime.setValue import androidx.compose.runtime.snapshotFlow @@ -35,7 +36,18 @@ import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.TerningTheme import kotlinx.coroutines.flow.distinctUntilChanged import kotlinx.coroutines.flow.map -import androidx.compose.runtime.mutableStateOf +import okhttp3.internal.toImmutableList + +private const val START_YEAR = 2010 +private const val END_YEAR = 2030 +private const val START_MONTH = 1 +private const val END_MONTH = 12 + +private val years = + (START_YEAR..END_YEAR).map { "${it}년" }.toImmutableList() + +private val months = + (START_MONTH..END_MONTH).map { "${it}월" }.toImmutableList() class PickerState { var selectedItem by mutableStateOf("") @@ -46,32 +58,50 @@ fun rememberPickerState() = remember { PickerState() } @Composable fun YearMonthPicker( - years: List, - months: List, modifier: Modifier = Modifier, - yearPickerState: PickerState = rememberPickerState(), - monthPickerState: PickerState = rememberPickerState(), - startYearIndex: Int = 5, - startMonthIndex: Int = 2, + chosenYear: Int, + chosenMonth: Int, + onYearChosen: (Int) -> Unit, + onMonthChosen: (Int) -> Unit, ) { + val yearPickerState = rememberPickerState() + val monthPickerState = rememberPickerState() + + val startYearIndex = years.indexOf("${chosenYear}년").takeIf { it >= 0 } ?: 0 + val startMonthIndex = months.indexOf("${chosenMonth}월").takeIf { it >= 0 } ?: 0 + + LaunchedEffect(chosenYear) { + yearPickerState.selectedItem = "${chosenYear}년" + } + + LaunchedEffect(chosenMonth) { + monthPickerState.selectedItem = "${chosenMonth}월" + } + Row( modifier = modifier .fillMaxWidth() - .padding(95.dp), - horizontalArrangement = Arrangement.SpaceBetween + .padding(horizontal = 95.dp), + horizontalArrangement = Arrangement.Center ) { DatePicker( modifier = Modifier.weight(1f), pickerState = yearPickerState, items = years, startIndex = startYearIndex, + onItemSelected = { year -> + onYearChosen(year.dropLast(1).toInt()) + } ) - Spacer(modifier = Modifier.width(25.dp)) + Spacer(modifier = Modifier.width(18.dp)) DatePicker( modifier = Modifier.weight(1f), pickerState = monthPickerState, items = months, startIndex = startMonthIndex, + onItemSelected = { month -> + onMonthChosen(month.dropLast(1).toInt()) + } ) } } @@ -83,6 +113,7 @@ fun DatePicker( pickerState: PickerState = rememberPickerState(), startIndex: Int = 0, visibleItemCount: Int = 3, + onItemSelected: (String) -> Unit ) { var itemHeightPixel by remember { mutableIntStateOf(0) } val itemHeightDp = with(LocalDensity.current) { itemHeightPixel.toDp() } @@ -100,8 +131,9 @@ fun DatePicker( .map { index -> items.getOrNull(index) } .distinctUntilChanged() .collect { item -> - if (item != null) { - pickerState.selectedItem = item + item?.let { + pickerState.selectedItem = it + onItemSelected(it) } } } @@ -165,4 +197,4 @@ fun DatePickerContent( color = color, ) } -} \ No newline at end of file +} From 0a643bf64f2f3f5272e2071e337e29185bc8a2c2 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 06:56:25 +0900 Subject: [PATCH 09/33] =?UTF-8?q?[FEAT/#218]=20=EC=BA=98=EB=A6=B0=EB=8D=94?= =?UTF-8?q?=20=ED=99=95=EC=9E=A5=ED=95=A8=EC=88=98=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../main/java/com/terning/core/extension/CalendarExt.kt | 7 +++++++ .../main/java/com/terning/core/util/CalendarDefaults.kt | 8 ++++++++ .../filteringthree/component/YearMonthPicker.kt | 9 ++++----- 3 files changed, 19 insertions(+), 5 deletions(-) create mode 100644 core/src/main/java/com/terning/core/extension/CalendarExt.kt create mode 100644 core/src/main/java/com/terning/core/util/CalendarDefaults.kt diff --git a/core/src/main/java/com/terning/core/extension/CalendarExt.kt b/core/src/main/java/com/terning/core/extension/CalendarExt.kt new file mode 100644 index 000000000..1bbc06b8a --- /dev/null +++ b/core/src/main/java/com/terning/core/extension/CalendarExt.kt @@ -0,0 +1,7 @@ +package com.terning.core.extension + +import java.util.Calendar + +val Calendar.currentYear: Int get() = get(Calendar.YEAR) + +val Calendar.currentMonth: Int get() = get(Calendar.MONTH) + 1 \ No newline at end of file diff --git a/core/src/main/java/com/terning/core/util/CalendarDefaults.kt b/core/src/main/java/com/terning/core/util/CalendarDefaults.kt new file mode 100644 index 000000000..2d0cb8355 --- /dev/null +++ b/core/src/main/java/com/terning/core/util/CalendarDefaults.kt @@ -0,0 +1,8 @@ +package com.terning.core.util + +object CalendarDefaults { + const val START_YEAR = 2010 + const val END_YEAR = 2030 + const val START_MONTH = 1 + const val END_MONTH = 12 +} diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt index 4b790121a..d61c06c98 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/component/YearMonthPicker.kt @@ -34,15 +34,14 @@ import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.Grey500 import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.TerningTheme +import com.terning.core.util.CalendarDefaults.END_MONTH +import com.terning.core.util.CalendarDefaults.END_YEAR +import com.terning.core.util.CalendarDefaults.START_MONTH +import com.terning.core.util.CalendarDefaults.START_YEAR import kotlinx.coroutines.flow.distinctUntilChanged import kotlinx.coroutines.flow.map import okhttp3.internal.toImmutableList -private const val START_YEAR = 2010 -private const val END_YEAR = 2030 -private const val START_MONTH = 1 -private const val END_MONTH = 12 - private val years = (START_YEAR..END_YEAR).map { "${it}년" }.toImmutableList() From a3c673a81649580058bfba8e5e8ca195443cc479 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 07:01:34 +0900 Subject: [PATCH 10/33] =?UTF-8?q?[FEAT/#218]=20=EC=BA=98=EB=A6=B0=EB=8D=94?= =?UTF-8?q?=20=ED=99=95=EC=9E=A5=ED=95=A8=EC=88=98=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../feature/filtering/filteringthree/FilteringThreeRoute.kt | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt index e8e505b7f..969475c00 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt @@ -26,6 +26,8 @@ import com.terning.core.designsystem.component.topappbar.BackButtonTopAppBar import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme +import com.terning.core.extension.currentMonth +import com.terning.core.extension.currentYear import com.terning.core.extension.toast import com.terning.feature.R import com.terning.feature.filtering.filteringthree.component.YearMonthPicker @@ -42,8 +44,8 @@ fun FilteringThreeRoute( val context = LocalContext.current val lifecycleOwner = LocalLifecycleOwner.current - val currentYear = Calendar.getInstance().get(Calendar.YEAR) - val currentMonth = Calendar.getInstance().get(Calendar.MONTH) + 1 + val currentYear = Calendar.getInstance().currentYear + val currentMonth = Calendar.getInstance().currentMonth var chosenYear by remember { mutableIntStateOf(currentYear) } var chosenMonth by remember { mutableIntStateOf(currentMonth) } From de564894a21f2ffdedbb78052088c877b7f7cc84 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 07:12:56 +0900 Subject: [PATCH 11/33] =?UTF-8?q?[FEAT/#218]=20=EB=A1=9C=EC=A7=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 --- .../filteringthree/FilteringThreeRoute.kt | 39 ++++++++++--------- .../FilteringThreeSideEffect.kt | 1 + .../filteringthree/FilteringViewModel.kt | 10 +++-- 3 files changed, 27 insertions(+), 23 deletions(-) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt index 969475c00..54eeafa9b 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt @@ -9,9 +9,6 @@ import androidx.compose.material3.Text import androidx.compose.runtime.Composable import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.getValue -import androidx.compose.runtime.mutableIntStateOf -import androidx.compose.runtime.remember -import androidx.compose.runtime.setValue import androidx.compose.ui.Modifier import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.res.painterResource @@ -20,6 +17,7 @@ import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import androidx.hilt.navigation.compose.hiltViewModel import androidx.lifecycle.compose.LocalLifecycleOwner +import androidx.lifecycle.compose.collectAsStateWithLifecycle import androidx.lifecycle.flowWithLifecycle import com.terning.core.designsystem.component.button.RectangleButton import com.terning.core.designsystem.component.topappbar.BackButtonTopAppBar @@ -41,23 +39,25 @@ fun FilteringThreeRoute( navigateToStartHome: () -> Unit, viewModel: FilteringViewModel = hiltViewModel(), ) { + val state by viewModel.state.collectAsStateWithLifecycle() + val context = LocalContext.current val lifecycleOwner = LocalLifecycleOwner.current - val currentYear = Calendar.getInstance().currentYear - val currentMonth = Calendar.getInstance().currentMonth - - var chosenYear by remember { mutableIntStateOf(currentYear) } - var chosenMonth by remember { mutableIntStateOf(currentMonth) } - LaunchedEffect(key1 = true) { - viewModel.fetchGrade(grade = grade) - viewModel.fetchWorkingPeriod(workingPeriod = workingPeriod) + with(viewModel) { + updateGrade(grade = grade) + updateWorkingPeriod(workingPeriod = workingPeriod) + updateStartYear(startYear = Calendar.getInstance().currentYear) + updateStartMonth(startMonth = Calendar.getInstance().currentMonth) + } } - LaunchedEffect(key1 = chosenYear, key2 = chosenMonth) { - viewModel.fetchStartYear(chosenYear) - viewModel.fetchStartMonth(chosenMonth) + LaunchedEffect(key1 = state.startYear, key2 = state.startMonth) { + with(viewModel) { + updateStartYear(state.startYear) + updateStartMonth(state.startMonth) + } } LaunchedEffect(viewModel.sideEffects, lifecycleOwner) { @@ -66,17 +66,18 @@ fun FilteringThreeRoute( when (sideEffect) { is FilteringThreeSideEffect.NavigateToStartHome -> navigateToStartHome() is FilteringThreeSideEffect.ShowToast -> context.toast(sideEffect.message) + is FilteringThreeSideEffect.NavigateUp -> navigateUp() } } } FilteringThreeScreen( - navigateUp = { navigateUp() }, - chosenYear = chosenYear, - chosenMonth = chosenMonth, + navigateUp = { viewModel.navigateUp() }, + chosenYear = state.startYear, + chosenMonth = state.startMonth, onNextClick = { viewModel.postFilteringWithServer() }, - onYearChosen = { chosenYear = it }, - onMonthChosen = { chosenMonth = it } + onYearChosen = { viewModel.updateStartYear(it) }, + onMonthChosen = { viewModel.updateStartMonth(it) } ) } diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeSideEffect.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeSideEffect.kt index 42cb61d6f..3b035dc7c 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeSideEffect.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeSideEffect.kt @@ -5,4 +5,5 @@ import androidx.annotation.StringRes sealed class FilteringThreeSideEffect { data object NavigateToStartHome : FilteringThreeSideEffect() data class ShowToast(@StringRes val message: Int) : FilteringThreeSideEffect() + data object NavigateUp : FilteringThreeSideEffect() } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt index 7b5a64cf2..d5d5f9b58 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt @@ -28,19 +28,19 @@ class FilteringViewModel @Inject constructor( private val _sideEffects = MutableSharedFlow() val sideEffects: SharedFlow get() = _sideEffects.asSharedFlow() - fun fetchGrade(grade: Int) { + fun updateGrade(grade: Int) { _state.value = _state.value.copy(grade = grade) } - fun fetchWorkingPeriod(workingPeriod: Int) { + fun updateWorkingPeriod(workingPeriod: Int) { _state.value = _state.value.copy(workingPeriod = workingPeriod) } - fun fetchStartYear(startYear: Int) { + fun updateStartYear(startYear: Int) { _state.value = _state.value.copy(startYear = startYear) } - fun fetchStartMonth(startMonth: Int) { + fun updateStartMonth(startMonth: Int) { _state.value = _state.value.copy(startMonth = startMonth) } @@ -64,4 +64,6 @@ class FilteringViewModel @Inject constructor( } } + fun navigateUp() = viewModelScope.launch { _sideEffects.emit(FilteringThreeSideEffect.NavigateUp) } + } \ No newline at end of file From aa2531f4186d47b2a5fde4e555fb11b4e762577e Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 07:15:34 +0900 Subject: [PATCH 12/33] =?UTF-8?q?[FEAT/#218]=20=EB=A1=9C=EC=A7=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 --- .../feature/filtering/filteringthree/FilteringThreeRoute.kt | 6 +++--- .../filteringthree/navigation/FilteringThreeNavigation.kt | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt index 54eeafa9b..2a872fe94 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt @@ -72,10 +72,10 @@ fun FilteringThreeRoute( } FilteringThreeScreen( - navigateUp = { viewModel.navigateUp() }, + navigateUp = viewModel::navigateUp, chosenYear = state.startYear, chosenMonth = state.startMonth, - onNextClick = { viewModel.postFilteringWithServer() }, + onNextClick = viewModel::postFilteringWithServer, onYearChosen = { viewModel.updateStartYear(it) }, onMonthChosen = { viewModel.updateStartMonth(it) } ) @@ -94,7 +94,7 @@ fun FilteringThreeScreen( modifier = Modifier, ) { BackButtonTopAppBar( - onBackButtonClick = { navigateUp() } + onBackButtonClick = navigateUp ) Column( modifier = Modifier.fillMaxSize() diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/navigation/FilteringThreeNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/navigation/FilteringThreeNavigation.kt index 57580223c..2a0257744 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/navigation/FilteringThreeNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/navigation/FilteringThreeNavigation.kt @@ -30,8 +30,8 @@ fun NavGraphBuilder.filteringThreeNavGraph( FilteringThreeRoute( grade = args.grade, workingPeriod = args.workingPeriod, - navigateUp = { navHostController.navigateUp() }, - navigateToStartHome = { navHostController.navigateStartHome() } + navigateUp = navHostController::navigateUp, + navigateToStartHome = navHostController::navigateStartHome ) } } From b7d263ca0d188d6d03c839dafbcf1b86e2f53969 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 07:26:33 +0900 Subject: [PATCH 13/33] =?UTF-8?q?[FEAT/#218]=20=EC=BA=98=EB=A6=B0=EB=8D=94?= =?UTF-8?q?=20=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 --- .../filtering/filteringthree/FilteringThreeRoute.kt | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt index 2a872fe94..6e19a291a 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt @@ -4,6 +4,7 @@ import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxSize +import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding import androidx.compose.material3.Text import androidx.compose.runtime.Composable @@ -48,8 +49,6 @@ fun FilteringThreeRoute( with(viewModel) { updateGrade(grade = grade) updateWorkingPeriod(workingPeriod = workingPeriod) - updateStartYear(startYear = Calendar.getInstance().currentYear) - updateStartMonth(startMonth = Calendar.getInstance().currentMonth) } } @@ -73,8 +72,8 @@ fun FilteringThreeRoute( FilteringThreeScreen( navigateUp = viewModel::navigateUp, - chosenYear = state.startYear, - chosenMonth = state.startMonth, + chosenYear = Calendar.getInstance().currentYear, + chosenMonth = Calendar.getInstance().currentMonth, onNextClick = viewModel::postFilteringWithServer, onYearChosen = { viewModel.updateStartYear(it) }, onMonthChosen = { viewModel.updateStartMonth(it) } @@ -124,14 +123,14 @@ fun FilteringThreeScreen( start = 24.dp, ) ) - Spacer(modifier = Modifier.weight(1f)) + Spacer(modifier = Modifier.height(61.dp)) YearMonthPicker( chosenYear = chosenYear, chosenMonth = chosenMonth, onYearChosen = { onYearChosen(it) }, onMonthChosen = { onMonthChosen(it) }, ) - Spacer(modifier = Modifier.weight(7f)) + Spacer(modifier = Modifier.weight(1f)) RectangleButton( style = TerningTheme.typography.button0, paddingVertical = 20.dp, From 990a776328f1c33cfae0bcb4021c63c653687db3 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 07:32:11 +0900 Subject: [PATCH 14/33] =?UTF-8?q?[FEAT/#218]=20=ED=95=84=ED=84=B0=EB=A7=81?= =?UTF-8?q?=20=EB=B2=84=ED=8A=BC=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/button/FilteringButton.kt | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/core/src/main/java/com/terning/core/designsystem/component/button/FilteringButton.kt b/core/src/main/java/com/terning/core/designsystem/component/button/FilteringButton.kt index f0c50d820..bc0ca38db 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/button/FilteringButton.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/button/FilteringButton.kt @@ -58,8 +58,9 @@ fun FilteringButton( val isPressed by interactionSource.collectIsPressedAsState() val backgroundColor = White val textColor = when { - isSelected -> TerningMain - else -> Grey375 + !isSelected -> Grey375 + isPressed -> Grey375 + else -> TerningMain } val borderColor = when { !isSelected && !isPressed -> Grey150 From 93ca5c68cad214af64f9fb41386813bb31cc3f9d Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 07:54:35 +0900 Subject: [PATCH 15/33] =?UTF-8?q?[FEAT/#218]=20=ED=95=84=ED=84=B0=EB=A7=81?= =?UTF-8?q?=20=EC=9B=90=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 --- ...eringOneScreen.kt => FilteringOneRoute.kt} | 61 ++++++++++++++----- .../filteringone/FilteringOneSideEffect.kt | 5 ++ .../filteringone/FilteringOneState.kt | 6 ++ .../filteringone/FilteringOneViewModel.kt | 31 ++++++++++ .../navigation/FilteringOneNavigation.kt | 4 +- .../filteringthree/FilteringThreeRoute.kt | 2 +- ...lteringState.kt => FilteringThreeState.kt} | 2 +- ...iewModel.kt => FilteringThreeViewModel.kt} | 6 +- 8 files changed, 96 insertions(+), 21 deletions(-) rename feature/src/main/java/com/terning/feature/filtering/filteringone/{FilteringOneScreen.kt => FilteringOneRoute.kt} (69%) create mode 100644 feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneSideEffect.kt create mode 100644 feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneState.kt create mode 100644 feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneViewModel.kt rename feature/src/main/java/com/terning/feature/filtering/filteringthree/{FilteringState.kt => FilteringThreeState.kt} (84%) rename feature/src/main/java/com/terning/feature/filtering/filteringthree/{FilteringViewModel.kt => FilteringThreeViewModel.kt} (92%) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneScreen.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneRoute.kt similarity index 69% rename from feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneScreen.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneRoute.kt index 8d0d3afcc..93166b9c8 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneScreen.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneRoute.kt @@ -7,16 +7,17 @@ import androidx.compose.foundation.layout.fillMaxSize import androidx.compose.foundation.layout.padding import androidx.compose.material3.Text import androidx.compose.runtime.Composable +import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.getValue -import androidx.compose.runtime.mutableIntStateOf -import androidx.compose.runtime.mutableStateOf -import androidx.compose.runtime.remember -import androidx.compose.runtime.setValue import androidx.compose.ui.Modifier import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp +import androidx.hilt.navigation.compose.hiltViewModel +import androidx.lifecycle.compose.LocalLifecycleOwner +import androidx.lifecycle.compose.collectAsStateWithLifecycle +import androidx.lifecycle.flowWithLifecycle import com.terning.core.designsystem.component.button.RectangleButton import com.terning.core.designsystem.component.topappbar.BackButtonTopAppBar import com.terning.core.designsystem.theme.Grey300 @@ -26,20 +27,52 @@ import com.terning.feature.R import com.terning.feature.filtering.filteringone.component.StatusOneRadioGroup @Composable -fun FilteringOneScreen( +fun FilteringOneRoute( name: String, onNextClick: (Int) -> Unit, navigateUp: () -> Unit, - onButtonClick: (Int) -> Unit = {}, + viewModel: FilteringOneViewModel = hiltViewModel() ) { - val isButtonValid = remember { mutableStateOf(false) } - var grade by remember { mutableIntStateOf(-1) } + val state by viewModel.state.collectAsStateWithLifecycle() + + val lifecycleOwner = LocalLifecycleOwner.current + + LaunchedEffect(viewModel.sideEffects, lifecycleOwner) { + viewModel.sideEffects.flowWithLifecycle(lifecycle = lifecycleOwner.lifecycle) + .collect { sideEffect -> + when (sideEffect) { + is FilteringOneSideEffect.NavigateUp -> navigateUp() + } + } + } + + FilteringOneScreen( + name = name, + onButtonClick = { index -> + viewModel.updateGrade(index) + viewModel.updateButtonValidation() + }, + onNextClick = onNextClick, + navigateUp = viewModel::navigateUp, + buttonState = state.isButtonValid, + gradeState = state.grade + ) +} +@Composable +fun FilteringOneScreen( + name: String, + onNextClick: (Int) -> Unit, + navigateUp: () -> Unit, + onButtonClick: (Int) -> Unit, + buttonState: Boolean, + gradeState: Int +) { Column( modifier = Modifier ) { BackButtonTopAppBar( - onBackButtonClick = { navigateUp() } + onBackButtonClick = navigateUp ) Column( modifier = Modifier.fillMaxSize() @@ -79,8 +112,6 @@ fun FilteringOneScreen( StatusOneRadioGroup( onButtonClick = { index -> onButtonClick(index) - isButtonValid.value = true - grade = index } ) Text( @@ -96,9 +127,9 @@ fun FilteringOneScreen( style = TerningTheme.typography.button0, paddingVertical = 20.dp, text = R.string.filtering_button, - onButtonClick = { onNextClick(grade) }, + onButtonClick = { onNextClick(gradeState) }, modifier = Modifier.padding(bottom = 12.dp), - isEnabled = isButtonValid.value + isEnabled = buttonState ) } } @@ -112,7 +143,9 @@ fun FilteringOneScreenPreview() { name = "터닝이", onButtonClick = {}, onNextClick = {}, - navigateUp = {} + navigateUp = {}, + buttonState = true, + gradeState = 1 ) } } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneSideEffect.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneSideEffect.kt new file mode 100644 index 000000000..5fdbaaaa6 --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneSideEffect.kt @@ -0,0 +1,5 @@ +package com.terning.feature.filtering.filteringone + +sealed class FilteringOneSideEffect { + data object NavigateUp : FilteringOneSideEffect() +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneState.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneState.kt new file mode 100644 index 000000000..06c28b481 --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneState.kt @@ -0,0 +1,6 @@ +package com.terning.feature.filtering.filteringone + +data class FilteringOneState( + val isButtonValid: Boolean = false, + val grade: Int = -1 +) \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneViewModel.kt new file mode 100644 index 000000000..214b0447d --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneViewModel.kt @@ -0,0 +1,31 @@ +package com.terning.feature.filtering.filteringone + +import androidx.lifecycle.ViewModel +import androidx.lifecycle.viewModelScope +import kotlinx.coroutines.flow.MutableSharedFlow +import kotlinx.coroutines.flow.MutableStateFlow +import kotlinx.coroutines.flow.SharedFlow +import kotlinx.coroutines.flow.StateFlow +import kotlinx.coroutines.flow.asSharedFlow +import kotlinx.coroutines.flow.asStateFlow +import kotlinx.coroutines.launch + +class FilteringOneViewModel : ViewModel() { + + private val _state: MutableStateFlow = MutableStateFlow(FilteringOneState()) + val state: StateFlow get() = _state.asStateFlow() + + private val _sideEffects = MutableSharedFlow() + val sideEffects: SharedFlow get() = _sideEffects.asSharedFlow() + + fun updateButtonValidation() { + _state.value = _state.value.copy(isButtonValid = true) + } + + fun updateGrade(grade: Int) { + _state.value = _state.value.copy(grade = grade) + } + + fun navigateUp() = + viewModelScope.launch { _sideEffects.emit(FilteringOneSideEffect.NavigateUp) } +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt index e5f25807e..c260aaec1 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt @@ -7,7 +7,7 @@ import androidx.navigation.NavOptions import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route -import com.terning.feature.filtering.filteringone.FilteringOneScreen +import com.terning.feature.filtering.filteringone.FilteringOneRoute import com.terning.feature.filtering.filteringtwo.navigation.navigateFilteringTwo import kotlinx.serialization.Serializable @@ -26,7 +26,7 @@ fun NavGraphBuilder.filteringOneNavGraph( ) { composable { val args = it.toRoute() - FilteringOneScreen( + FilteringOneRoute( name = args.name, onNextClick = { grade -> navHostController.navigateFilteringTwo(grade) }, navigateUp = { navHostController.navigateUp() } diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt index 6e19a291a..ff3a10a0e 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt @@ -38,7 +38,7 @@ fun FilteringThreeRoute( workingPeriod: Int, navigateUp: () -> Unit, navigateToStartHome: () -> Unit, - viewModel: FilteringViewModel = hiltViewModel(), + viewModel: FilteringThreeViewModel = hiltViewModel(), ) { val state by viewModel.state.collectAsStateWithLifecycle() diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringState.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeState.kt similarity index 84% rename from feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringState.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeState.kt index 7f75fc847..d907353f9 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringState.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeState.kt @@ -1,6 +1,6 @@ package com.terning.feature.filtering.filteringthree -data class FilteringState( +data class FilteringThreeState( val grade: Int = -1, val workingPeriod: Int = -1, val startYear: Int = -1, diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeViewModel.kt similarity index 92% rename from feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeViewModel.kt index d5d5f9b58..9c31c3c86 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringViewModel.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeViewModel.kt @@ -17,13 +17,13 @@ import kotlinx.coroutines.launch import javax.inject.Inject @HiltViewModel -class FilteringViewModel @Inject constructor( +class FilteringThreeViewModel @Inject constructor( private val filteringRepository: FilteringRepository, private val tokenRepository: TokenRepository ) : ViewModel() { - private val _state = MutableStateFlow(FilteringState()) - val state: StateFlow get() = _state.asStateFlow() + private val _state = MutableStateFlow(FilteringThreeState()) + val state: StateFlow get() = _state.asStateFlow() private val _sideEffects = MutableSharedFlow() val sideEffects: SharedFlow get() = _sideEffects.asSharedFlow() From 016fc7c7eee49728884e66fd3b46a93615618187 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Wed, 4 Sep 2024 08:04:47 +0900 Subject: [PATCH 16/33] =?UTF-8?q?[FEAT/#218]=20=ED=95=84=ED=84=B0=EB=A7=81?= =?UTF-8?q?=20=ED=88=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 --- ...eringTwoScreen.kt => FilteringTwoRoute.kt} | 58 +++++++++++++++---- .../filteringtwo/FilteringTwoSideEffect.kt | 5 ++ .../filteringtwo/FilteringTwoState.kt | 6 ++ .../filteringtwo/FilteringTwoViewModel.kt | 33 +++++++++++ .../navigation/FilteringTwoNavigation.kt | 6 +- 5 files changed, 93 insertions(+), 15 deletions(-) rename feature/src/main/java/com/terning/feature/filtering/filteringtwo/{FilteringTwoScreen.kt => FilteringTwoRoute.kt} (67%) create mode 100644 feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoSideEffect.kt create mode 100644 feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoState.kt create mode 100644 feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoViewModel.kt diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoScreen.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoRoute.kt similarity index 67% rename from feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoScreen.kt rename to feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoRoute.kt index 7f2849ce2..8c1a5b7b7 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoScreen.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoRoute.kt @@ -7,16 +7,17 @@ import androidx.compose.foundation.layout.fillMaxSize import androidx.compose.foundation.layout.padding import androidx.compose.material3.Text import androidx.compose.runtime.Composable +import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.getValue -import androidx.compose.runtime.mutableIntStateOf -import androidx.compose.runtime.mutableStateOf -import androidx.compose.runtime.remember -import androidx.compose.runtime.setValue import androidx.compose.ui.Modifier import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp +import androidx.hilt.navigation.compose.hiltViewModel +import androidx.lifecycle.compose.LocalLifecycleOwner +import androidx.lifecycle.compose.collectAsStateWithLifecycle +import androidx.lifecycle.flowWithLifecycle import com.terning.core.designsystem.component.button.RectangleButton import com.terning.core.designsystem.component.topappbar.BackButtonTopAppBar import com.terning.core.designsystem.theme.Grey300 @@ -26,15 +27,47 @@ import com.terning.feature.R import com.terning.feature.filtering.filteringtwo.component.StatusTwoRadioGroup @Composable -fun FilteringTwoScreen( +fun FilteringTwoRoute( grade: Int, onNextClick: (Int, Int) -> Unit, navigateUp: () -> Unit, - onButtonClick: (Int) -> Unit = {}, + viewModel: FilteringTwoViewModel = hiltViewModel() ) { - val isButtonValid = remember { mutableStateOf(false) } - var workingPeriod by remember { mutableIntStateOf(-1) } + val state by viewModel.state.collectAsStateWithLifecycle() + + val lifecycleOwner = LocalLifecycleOwner.current + + LaunchedEffect(viewModel.sideEffects, lifecycleOwner) { + viewModel.sideEffects.flowWithLifecycle(lifecycle = lifecycleOwner.lifecycle) + .collect { sideEffect -> + when (sideEffect) { + is FilteringTwoSideEffect.NavigateUp -> navigateUp() + } + } + } + + FilteringTwoScreen( + grade = grade, + onNextClick = onNextClick, + navigateUp = viewModel::navigateUp, + onButtonClick = { index -> + viewModel.updateWorkingPeriod(index) + viewModel.updateButtonValidation() + }, + buttonState = state.isButtonValid, + workingPeriod = state.workingPeriod + ) +} +@Composable +fun FilteringTwoScreen( + grade: Int, + onNextClick: (Int, Int) -> Unit, + navigateUp: () -> Unit, + onButtonClick: (Int) -> Unit, + buttonState: Boolean, + workingPeriod: Int +) { Column( modifier = Modifier ) { @@ -73,8 +106,6 @@ fun FilteringTwoScreen( StatusTwoRadioGroup( onButtonClick = { index -> onButtonClick(index) - isButtonValid.value = true - workingPeriod = index } ) Spacer(modifier = Modifier.weight(1f)) @@ -84,7 +115,7 @@ fun FilteringTwoScreen( text = R.string.filtering_button, onButtonClick = { onNextClick(grade, workingPeriod) }, modifier = Modifier.padding(bottom = 12.dp), - isEnabled = isButtonValid.value + isEnabled = buttonState ) } } @@ -97,7 +128,10 @@ fun FilteringTwoScreenPreview() { FilteringTwoScreen( grade = 1, onNextClick = { _, _ -> }, - navigateUp = { } + navigateUp = { }, + onButtonClick = { }, + buttonState = true, + workingPeriod = 1 ) } } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoSideEffect.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoSideEffect.kt new file mode 100644 index 000000000..a858577c1 --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoSideEffect.kt @@ -0,0 +1,5 @@ +package com.terning.feature.filtering.filteringtwo + +sealed class FilteringTwoSideEffect { + data object NavigateUp : FilteringTwoSideEffect() +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoState.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoState.kt new file mode 100644 index 000000000..383049e07 --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoState.kt @@ -0,0 +1,6 @@ +package com.terning.feature.filtering.filteringtwo + +data class FilteringTwoState( + val isButtonValid: Boolean = false, + val workingPeriod: Int = -1 +) \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoViewModel.kt new file mode 100644 index 000000000..3dc4c8afd --- /dev/null +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoViewModel.kt @@ -0,0 +1,33 @@ +package com.terning.feature.filtering.filteringtwo + +import androidx.lifecycle.ViewModel +import androidx.lifecycle.viewModelScope +import com.terning.feature.filtering.filteringone.FilteringOneSideEffect +import com.terning.feature.filtering.filteringone.FilteringOneState +import kotlinx.coroutines.flow.MutableSharedFlow +import kotlinx.coroutines.flow.MutableStateFlow +import kotlinx.coroutines.flow.SharedFlow +import kotlinx.coroutines.flow.StateFlow +import kotlinx.coroutines.flow.asSharedFlow +import kotlinx.coroutines.flow.asStateFlow +import kotlinx.coroutines.launch + +class FilteringTwoViewModel : ViewModel(){ + + private val _state: MutableStateFlow = MutableStateFlow(FilteringTwoState()) + val state: StateFlow get() = _state.asStateFlow() + + private val _sideEffects = MutableSharedFlow() + val sideEffects: SharedFlow get() = _sideEffects.asSharedFlow() + + fun updateButtonValidation() { + _state.value = _state.value.copy(isButtonValid = true) + } + + fun updateWorkingPeriod(workingPeriod: Int) { + _state.value = _state.value.copy(workingPeriod = workingPeriod) + } + + fun navigateUp() = + viewModelScope.launch { _sideEffects.emit(FilteringTwoSideEffect.NavigateUp) } +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/navigation/FilteringTwoNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/navigation/FilteringTwoNavigation.kt index ab417cdab..a05a89835 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/navigation/FilteringTwoNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/navigation/FilteringTwoNavigation.kt @@ -7,8 +7,8 @@ import androidx.navigation.NavOptions import androidx.navigation.compose.composable import androidx.navigation.toRoute import com.terning.core.navigation.Route -import com.terning.feature.filtering.filteringtwo.FilteringTwoScreen import com.terning.feature.filtering.filteringthree.navigation.navigateFilteringThree +import com.terning.feature.filtering.filteringtwo.FilteringTwoRoute import kotlinx.serialization.Serializable fun NavController.navigateFilteringTwo( @@ -26,7 +26,7 @@ fun NavGraphBuilder.filteringTwoNavGraph( ) { composable { val args = it.toRoute() - FilteringTwoScreen( + FilteringTwoRoute( grade = args.grade, onNextClick = { _, workingPeriod -> navHostController.navigateFilteringThree( @@ -34,7 +34,7 @@ fun NavGraphBuilder.filteringTwoNavGraph( workingPeriod = workingPeriod ) }, - navigateUp = { navHostController.navigateUp() } + navigateUp = navHostController::navigateUp ) } } From e410bb5f69b6d8c7da1e1341ab4e6a4303ca4aa0 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Thu, 5 Sep 2024 04:09:27 +0900 Subject: [PATCH 17/33] =?UTF-8?q?[FEAT/#218]=20=ED=8C=A8=EB=94=A9=EA=B0=92?= =?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 --- .../java/com/terning/feature/onboarding/signup/SignUpRoute.kt | 1 - 1 file changed, 1 deletion(-) diff --git a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpRoute.kt b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpRoute.kt index 9a963fe57..4be2f12c7 100644 --- a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpRoute.kt +++ b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpRoute.kt @@ -123,7 +123,6 @@ fun SignUpScreen( Column( modifier = Modifier.align(Alignment.CenterHorizontally) ) { - Spacer(modifier = Modifier.height(48.dp)) ProfileWithPlusButton( modifier = Modifier.noRippleClickable { onProfileEditClick(true) From 32686a49c1f99fb6c31e95fd25ee980be122f4b1 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 10:04:47 +0900 Subject: [PATCH 18/33] =?UTF-8?q?[FEAT/#221]=20=EB=84=A4=EB=B9=84=EA=B2=8C?= =?UTF-8?q?=EC=9D=B4=EC=85=98=20=EC=8A=A4=ED=83=9D=20=EC=A0=95=EB=A6=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/terning/feature/main/MainNavigator.kt | 9 ++++-- .../com/terning/feature/main/MainScreen.kt | 28 +++++++++++++++++++ .../feature/mypage/mypage/MyPageRoute.kt | 12 ++++++++ 3 files changed, 46 insertions(+), 3 deletions(-) diff --git a/feature/src/main/java/com/terning/feature/main/MainNavigator.kt b/feature/src/main/java/com/terning/feature/main/MainNavigator.kt index f0598bf1f..8455eb2a6 100644 --- a/feature/src/main/java/com/terning/feature/main/MainNavigator.kt +++ b/feature/src/main/java/com/terning/feature/main/MainNavigator.kt @@ -31,9 +31,12 @@ class MainNavigator( fun navigate(tab: MainTab) { val navOptions = navOptions { - popUpTo(navController.graph.findStartDestination().id) { - saveState = true - } + navController.currentDestination?.route?.let { + popUpTo(it){ + inclusive = true + saveState = true + } + } launchSingleTop = true restoreState = true } diff --git a/feature/src/main/java/com/terning/feature/main/MainScreen.kt b/feature/src/main/java/com/terning/feature/main/MainScreen.kt index d78934eba..f294cf9e1 100644 --- a/feature/src/main/java/com/terning/feature/main/MainScreen.kt +++ b/feature/src/main/java/com/terning/feature/main/MainScreen.kt @@ -1,5 +1,9 @@ package com.terning.feature.main +import android.app.Activity +import android.content.Intent +import android.widget.Toast +import androidx.activity.compose.BackHandler import androidx.compose.animation.AnimatedVisibility import androidx.compose.animation.EnterTransition import androidx.compose.animation.ExitTransition @@ -15,11 +19,18 @@ import androidx.compose.material3.NavigationBarItem import androidx.compose.material3.Scaffold import androidx.compose.material3.Text import androidx.compose.runtime.Composable +import androidx.compose.runtime.getValue +import androidx.compose.runtime.mutableStateOf +import androidx.compose.runtime.remember +import androidx.compose.runtime.rememberCoroutineScope +import androidx.compose.runtime.setValue import androidx.compose.ui.Modifier +import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.unit.IntOffset import androidx.compose.ui.unit.sp +import androidx.core.content.ContextCompat.startActivity import androidx.navigation.compose.NavHost import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningMain @@ -33,6 +44,7 @@ import com.terning.feature.filtering.startfiltering.navigation.startFilteringNav import com.terning.feature.filtering.starthome.navigation.startHomeNavGraph import com.terning.feature.home.changefilter.navigation.changeFilterNavGraph import com.terning.feature.home.home.navigation.homeNavGraph +import com.terning.feature.home.home.navigation.navigateHome import com.terning.feature.intern.navigation.internNavGraph import com.terning.feature.mypage.mypage.navigation.myPageNavGraph import com.terning.feature.mypage.profileedit.navigation.profileEditNavGraph @@ -41,11 +53,27 @@ import com.terning.feature.onboarding.signup.navigation.signUpNavGraph import com.terning.feature.onboarding.splash.navigation.splashNavGraph import com.terning.feature.search.search.navigation.searchNavGraph import com.terning.feature.search.searchprocess.navigation.searchProcessNavGraph +import kotlinx.coroutines.delay +import kotlinx.coroutines.launch @Composable fun MainScreen( navigator: MainNavigator = rememberMainNavigator(), ) { + val context = LocalContext.current + var backPressedState by remember { mutableStateOf(true) } + var backPressedTime = 0L + + BackHandler(enabled = backPressedState) { + if(System.currentTimeMillis() - backPressedTime <= 3000) { + (context as Activity).finish() + } else { + backPressedState = true + Toast.makeText(context, "한 번 더 누르시면 앱이 종료됩니다.", Toast.LENGTH_SHORT).show() + } + backPressedTime = System.currentTimeMillis() + } + Scaffold( bottomBar = { MainBottomBar( diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt index e520d3504..b31050de1 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt @@ -15,11 +15,15 @@ import androidx.compose.material3.HorizontalDivider import androidx.compose.material3.Text import androidx.compose.material3.VerticalDivider import androidx.compose.runtime.Composable +import androidx.compose.runtime.CompositionLocalProvider +import androidx.compose.runtime.DisposableEffect import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.SideEffect +import androidx.compose.runtime.compositionLocalOf import androidx.compose.runtime.getValue import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier +import androidx.compose.ui.graphics.Color import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview @@ -63,6 +67,14 @@ fun MyPageRoute( ) } + DisposableEffect(lifecycleOwner) { + onDispose { + systemUiController.setStatusBarColor( + color = White + ) + } + } + LaunchedEffect(viewModel.sideEffects, lifecycleOwner) { viewModel.sideEffects.flowWithLifecycle(lifecycle = lifecycleOwner.lifecycle) .collect { sideEffect -> From 278d274ec671d8d6075fadca3f58f0fa7e609f75 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 10:15:01 +0900 Subject: [PATCH 19/33] =?UTF-8?q?[FEAT/#218]=20=ED=95=A8=EC=88=98=20?= =?UTF-8?q?=ED=95=A9=EC=B9=98=EA=B8=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../filtering/filteringone/FilteringOneRoute.kt | 3 +-- .../filteringone/FilteringOneViewModel.kt | 11 +++++------ .../filtering/filteringtwo/FilteringTwoRoute.kt | 3 +-- .../filteringtwo/FilteringTwoViewModel.kt | 15 ++++++--------- 4 files changed, 13 insertions(+), 19 deletions(-) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneRoute.kt index 1d3dd595f..930e81fb7 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneRoute.kt @@ -53,8 +53,7 @@ fun FilteringOneRoute( FilteringOneScreen( name = name, onButtonClick = { index -> - viewModel.updateGrade(index) - viewModel.updateButtonValidation() + viewModel.updateGradeAndButton(index) }, onNextClick = onNextClick, navigateUp = viewModel::navigateUp, diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneViewModel.kt index 214b0447d..93829d006 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneViewModel.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/FilteringOneViewModel.kt @@ -18,12 +18,11 @@ class FilteringOneViewModel : ViewModel() { private val _sideEffects = MutableSharedFlow() val sideEffects: SharedFlow get() = _sideEffects.asSharedFlow() - fun updateButtonValidation() { - _state.value = _state.value.copy(isButtonValid = true) - } - - fun updateGrade(grade: Int) { - _state.value = _state.value.copy(grade = grade) + fun updateGradeAndButton(grade: Int) { + _state.value = _state.value.copy( + grade = grade, + isButtonValid = true + ) } fun navigateUp() = diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoRoute.kt index 3b00778d0..21361bdb5 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoRoute.kt @@ -55,8 +55,7 @@ fun FilteringTwoRoute( onNextClick = onNextClick, navigateUp = viewModel::navigateUp, onButtonClick = { index -> - viewModel.updateWorkingPeriod(index) - viewModel.updateButtonValidation() + viewModel.updateWorkingPeriodAndButton(index) }, buttonState = state.isButtonValid, workingPeriod = state.workingPeriod, diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoViewModel.kt b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoViewModel.kt index 3dc4c8afd..2076a5221 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoViewModel.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringtwo/FilteringTwoViewModel.kt @@ -2,8 +2,6 @@ package com.terning.feature.filtering.filteringtwo import androidx.lifecycle.ViewModel import androidx.lifecycle.viewModelScope -import com.terning.feature.filtering.filteringone.FilteringOneSideEffect -import com.terning.feature.filtering.filteringone.FilteringOneState import kotlinx.coroutines.flow.MutableSharedFlow import kotlinx.coroutines.flow.MutableStateFlow import kotlinx.coroutines.flow.SharedFlow @@ -12,7 +10,7 @@ import kotlinx.coroutines.flow.asSharedFlow import kotlinx.coroutines.flow.asStateFlow import kotlinx.coroutines.launch -class FilteringTwoViewModel : ViewModel(){ +class FilteringTwoViewModel : ViewModel() { private val _state: MutableStateFlow = MutableStateFlow(FilteringTwoState()) val state: StateFlow get() = _state.asStateFlow() @@ -20,12 +18,11 @@ class FilteringTwoViewModel : ViewModel(){ private val _sideEffects = MutableSharedFlow() val sideEffects: SharedFlow get() = _sideEffects.asSharedFlow() - fun updateButtonValidation() { - _state.value = _state.value.copy(isButtonValid = true) - } - - fun updateWorkingPeriod(workingPeriod: Int) { - _state.value = _state.value.copy(workingPeriod = workingPeriod) + fun updateWorkingPeriodAndButton(workingPeriod: Int) { + _state.value = _state.value.copy( + workingPeriod = workingPeriod, + isButtonValid = true + ) } fun navigateUp() = From fc8c1f3b72230e780c183cc293a4d817cb689d43 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 10:22:14 +0900 Subject: [PATCH 20/33] =?UTF-8?q?[FEAT/#218]=20=EC=BD=94=EB=93=9C=20?= =?UTF-8?q?=EB=A6=AC=EB=B7=B0=20=EB=B0=98=EC=98=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../filteringone/navigation/FilteringOneNavigation.kt | 4 ++-- .../feature/filtering/filteringthree/FilteringThreeRoute.kt | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt b/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt index e80b3fbeb..d771d018f 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringone/navigation/FilteringOneNavigation.kt @@ -30,8 +30,8 @@ fun NavGraphBuilder.filteringOneNavGraph( FilteringOneRoute( paddingValues = paddingValues, name = args.name, - onNextClick = { grade -> navHostController.navigateFilteringTwo(grade) }, - navigateUp = { navHostController.navigateUp() } + onNextClick = navHostController::navigateFilteringTwo, + navigateUp = navHostController::navigateUp ) } } diff --git a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt index 8bdc9d4e0..09ef94e01 100644 --- a/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/filteringthree/FilteringThreeRoute.kt @@ -80,8 +80,8 @@ fun FilteringThreeRoute( chosenYear = Calendar.getInstance().currentYear, chosenMonth = Calendar.getInstance().currentMonth, onNextClick = viewModel::postFilteringWithServer, - onYearChosen = { viewModel.updateStartYear(it) }, - onMonthChosen = { viewModel.updateStartMonth(it) } + onYearChosen = viewModel::updateStartYear, + onMonthChosen = viewModel::updateStartMonth ) } From a854109b13c7e5a4c662b729ae3a8688fd465f0e Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 11:50:42 +0900 Subject: [PATCH 21/33] =?UTF-8?q?[FEAT/#221]=20=EB=A7=88=EC=9D=B4=ED=8E=98?= =?UTF-8?q?=EC=9D=B4=EC=A7=80=20=EC=84=9C=EB=B2=84=ED=86=B5=EC=8B=A0=20?= =?UTF-8?q?=EC=88=98=EC=A0=95=EC=82=AC=ED=95=AD=20=EB=B0=98=EC=98=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../bottomsheet/ProfileBottomSheet.kt | 41 ++-- .../component/item/ProfileWithPlusButton.kt | 16 +- .../com/terning/core/type/ProfileImage.kt | 31 +++ .../res/drawable/ic_terning_profile_00.xml | 179 +++++----------- .../res/drawable/ic_terning_profile_01.xml | 200 +++++++----------- .../ic_terning_profile_01_selected.png | Bin 6221 -> 0 bytes .../res/drawable/ic_terning_profile_02.xml | 161 ++++++-------- .../res/drawable/ic_terning_profile_03.xml | 195 ++++++----------- .../res/drawable/ic_terning_profile_04.xml | 180 +++++----------- .../res/drawable/ic_terning_profile_05.xml | 172 ++++++--------- .../data/dto/request/SignUpRequestDto.kt | 2 +- .../data/dto/response/MyPageResponseDto.kt | 2 + .../data/mapper/mypage/MyPageMapper.kt | 7 +- .../entity/mypage/MyPageProfileModel.kt | 1 + .../domain/entity/onboarding/SignUpRequest.kt | 2 +- .../feature/mypage/mypage/MyPageRoute.kt | 27 +-- .../feature/mypage/mypage/MyPageState.kt | 2 +- .../feature/mypage/mypage/MyPageViewModel.kt | 1 + .../mypage/mypage/component/MyPageProfile.kt | 25 +-- .../mypage/navigation/MyPageNavigation.kt | 4 +- .../mypage/profileedit/ProfileEditRoute.kt | 15 +- .../mypage/profileedit/ProfileEditState.kt | 2 +- .../profileedit/ProfileEditViewModel.kt | 14 +- .../navigation/ProfileEditNavigation.kt | 8 +- .../feature/onboarding/signup/SignUpRoute.kt | 8 +- .../feature/onboarding/signup/SignUpState.kt | 2 +- .../onboarding/signup/SignUpViewModel.kt | 2 +- 27 files changed, 504 insertions(+), 795 deletions(-) create mode 100644 core/src/main/java/com/terning/core/type/ProfileImage.kt delete mode 100644 core/src/main/res/drawable/ic_terning_profile_01_selected.png diff --git a/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt b/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt index 9382ceb7a..640952599 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt @@ -30,6 +30,7 @@ import com.terning.core.R import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.extension.noRippleClickable +import com.terning.core.type.ProfileImage import kotlinx.coroutines.launch /** @@ -45,8 +46,8 @@ import kotlinx.coroutines.launch fun ProfileBottomSheet( modifier: Modifier = Modifier, onDismiss: () -> Unit, - onSaveClick: (Int) -> Unit, - initialSelectedOption: Int + onSaveClick: (ProfileImage) -> Unit, + initialSelectedOption: String ) { val scope = rememberCoroutineScope() val sheetState = rememberModalBottomSheetState() @@ -64,11 +65,11 @@ fun ProfileBottomSheet( ), ) RadioButtonGroup( - onOptionSelected = { index -> + onOptionSelected = { selectedProfile -> scope.launch { sheetState.hide() } .invokeOnCompletion { if (!sheetState.isVisible) { - onSaveClick(index) + onSaveClick(selectedProfile) } } }, @@ -82,6 +83,7 @@ fun ProfileBottomSheet( ) } + /** * 6개의 프로필 이미지 중, 하나의 이미지만 선택할 수 있는 라디오 버튼입니다. * @@ -91,20 +93,17 @@ fun ProfileBottomSheet( */ @Composable fun RadioButtonGroup( - onOptionSelected: (Int) -> Unit, - initialSelectedOption: Int, + onOptionSelected: (ProfileImage) -> Unit, + initialSelectedOption: String, modifier: Modifier = Modifier, ) { - val options = listOf( - R.drawable.ic_terning_profile_00, - R.drawable.ic_terning_profile_01, - R.drawable.ic_terning_profile_02, - R.drawable.ic_terning_profile_03, - R.drawable.ic_terning_profile_04, - R.drawable.ic_terning_profile_05 - ) + // 모든 ProfileImage 옵션을 가져옵니다. + val options = ProfileImage.entries - var selectedOption by rememberSaveable { mutableIntStateOf(options[initialSelectedOption]) } + // 초기 선택된 옵션을 ProfileImage로 변환하여 인덱스를 저장합니다. + var selectedOptionIndex by rememberSaveable { + mutableIntStateOf(ProfileImage.toIndex(ProfileImage.fromString(initialSelectedOption))) + } LazyVerticalGrid( columns = GridCells.Fixed(3), @@ -113,7 +112,7 @@ fun RadioButtonGroup( modifier = modifier.padding(horizontal = 34.dp) ) { itemsIndexed(options) { index, option -> - val imageModifier = if (selectedOption == options[index]) { + val imageModifier = if (selectedOptionIndex == index) { Modifier .border( color = TerningMain, @@ -126,14 +125,12 @@ fun RadioButtonGroup( } Image( - painter = painterResource( - id = option - ), + painter = painterResource(id = option.drawableResId), contentDescription = "profile image", modifier = imageModifier .noRippleClickable { - onOptionSelected(index) - selectedOption = option + onOptionSelected(option) + selectedOptionIndex = index } .clip(shape = CircleShape) .size(76.dp) @@ -141,4 +138,4 @@ fun RadioButtonGroup( ) } } -} \ No newline at end of file +} diff --git a/core/src/main/java/com/terning/core/designsystem/component/item/ProfileWithPlusButton.kt b/core/src/main/java/com/terning/core/designsystem/component/item/ProfileWithPlusButton.kt index 659f27b03..a8bccb6da 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/item/ProfileWithPlusButton.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/item/ProfileWithPlusButton.kt @@ -14,26 +14,20 @@ import androidx.compose.ui.res.painterResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import com.terning.core.R +import com.terning.core.type.ProfileImage @Composable fun ProfileWithPlusButton( - index: Int, + profileImage: String, modifier: Modifier = Modifier, ) { - val grade = when (index) { - 0 -> R.drawable.ic_terning_profile_00 - 1 -> R.drawable.ic_terning_profile_01 - 2 -> R.drawable.ic_terning_profile_02 - 3 -> R.drawable.ic_terning_profile_03 - 4 -> R.drawable.ic_terning_profile_04 - else -> R.drawable.ic_terning_profile_05 - } + val userProfile = ProfileImage.fromString(profileImage) Box( modifier = modifier.wrapContentWidth() ) { Image( - painterResource(id = grade), + painterResource(id = userProfile.drawableResId), contentDescription = "profile image", modifier = modifier .clip(shape = CircleShape) @@ -51,5 +45,5 @@ fun ProfileWithPlusButton( @Preview(showBackground = true) @Composable fun ProfileWithPlusButtonPreview() { - ProfileWithPlusButton(index = 1) + ProfileWithPlusButton(profileImage = "basic") } \ No newline at end of file diff --git a/core/src/main/java/com/terning/core/type/ProfileImage.kt b/core/src/main/java/com/terning/core/type/ProfileImage.kt new file mode 100644 index 000000000..79fd6a1a4 --- /dev/null +++ b/core/src/main/java/com/terning/core/type/ProfileImage.kt @@ -0,0 +1,31 @@ +package com.terning.core.type + +import com.terning.core.R + +enum class ProfileImage( + val drawableResId: Int, + val stringValue: String +) { + + BASIC(drawableResId = R.drawable.ic_terning_profile_00, stringValue = "basic"), + LUCKY(drawableResId = R.drawable.ic_terning_profile_01, stringValue = "lucky"), + SMART(drawableResId = R.drawable.ic_terning_profile_02, stringValue = "smart"), + GLASS(drawableResId = R.drawable.ic_terning_profile_03, stringValue = "glass"), + CALENDAR(drawableResId = R.drawable.ic_terning_profile_04, stringValue = "calendar"), + PASSION(drawableResId = R.drawable.ic_terning_profile_05, stringValue = "passion"); + + companion object { + fun fromString(value: String): ProfileImage = when (value) { + "basic" -> BASIC + "lucky" -> LUCKY + "smart" -> SMART + "glass" -> GLASS + "calendar" -> CALENDAR + else -> PASSION + } + + fun toIndex(profileImage: ProfileImage): Int { + return entries.indexOf(profileImage) + } + } +} diff --git a/core/src/main/res/drawable/ic_terning_profile_00.xml b/core/src/main/res/drawable/ic_terning_profile_00.xml index f34f8769c..99edfdf96 100644 --- a/core/src/main/res/drawable/ic_terning_profile_00.xml +++ b/core/src/main/res/drawable/ic_terning_profile_00.xml @@ -1,137 +1,60 @@ - - - - - - - + android:width="76dp" + android:height="76dp" + android:viewportWidth="76" + android:viewportHeight="76"> + android:pathData="M38,0L38,0A38,38 0,0 1,76 38L76,38A38,38 0,0 1,38 76L38,76A38,38 0,0 1,0 38L0,38A38,38 0,0 1,38 0z"/> - - - - - - - - - - - - - - - - + android:pathData="M76,0H0V76H76V0Z" + android:fillColor="#FBF8CB"/> - - - - + android:pathData="M57.95,77.966L67.64,49.542C68.314,47.472 67.574,45.192 65.807,43.909L41.971,26.59C40.204,25.308 37.819,25.308 36.053,26.59L12.217,43.909C10.45,45.192 9.718,47.462 10.384,49.542L19.494,77.567C20.169,79.638 22.097,81.045 24.282,81.045H53.751" + android:fillColor="#ffffff"/> - - - - - - + android:pathData="M57.95,77.966L67.64,49.542C68.314,47.472 67.574,45.192 65.807,43.909L41.971,26.59C40.204,25.308 37.819,25.308 36.053,26.59L12.217,43.909C10.45,45.192 9.718,47.462 10.384,49.542L19.494,77.567C20.169,79.638 22.097,81.045 24.282,81.045H53.751" + android:strokeWidth="1.425" + android:fillColor="#00000000" + android:strokeColor="#171717" + android:strokeLineCap="round"/> + + + + + + + + + android:pathData="M35.444,53.884C35.444,53.884 36.243,55.613 38.114,55.613C39.986,55.613 40.565,53.884 40.565,53.884" + android:strokeWidth="1.425" + android:fillColor="#00000000" + android:strokeColor="#171717" + android:strokeLineCap="round"/> - diff --git a/core/src/main/res/drawable/ic_terning_profile_01.xml b/core/src/main/res/drawable/ic_terning_profile_01.xml index 557c169b6..0bfcc7b29 100644 --- a/core/src/main/res/drawable/ic_terning_profile_01.xml +++ b/core/src/main/res/drawable/ic_terning_profile_01.xml @@ -1,132 +1,80 @@ - - - - - - + android:width="76dp" + android:height="76dp" + android:viewportWidth="76" + android:viewportHeight="76"> + android:pathData="M38,0L38,0A38,38 0,0 1,76 38L76,38A38,38 0,0 1,38 76L38,76A38,38 0,0 1,0 38L0,38A38,38 0,0 1,38 0z"/> + android:pathData="M76,0H0V76H76V0Z" + android:fillColor="#ECF9CA"/> + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - diff --git a/core/src/main/res/drawable/ic_terning_profile_01_selected.png b/core/src/main/res/drawable/ic_terning_profile_01_selected.png deleted file mode 100644 index f85119d4b6130d20396c478ade2f721f58868ddf..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6221 zcmV-T7_#SyP)J8_)EiIdpbaN(bTg9=xmcUiZ(wxUHi4WZ?9QtV3Ts%s@2Rl45kD&bJ+ zs$RJxxvJOWu8keUfm-0=oMA%ui@9Xp8~|788U|MT7ZelxS4UGJ`U zXV(VQN7>AHc6NTAdB5j--}n0&flnA}I$LWhE8*27yb!1nf|h9@CHzv*Md^>^wqM5f}S3 zx89YG%;QqlxG~-2f@l(O-9`k|&~KZ}uf0gRXc^F<`FR%pNVjEv*ZKn$9QLu()AoR2h zdTFtXtgW3$sKMgGPoEz8?72~t`;mIB5RX^{>q2%6?&#WsBB3b6rdlai5^j&|uoKGG z>4uw0_u*pzS6*?%_t~vDArbVT&7FE9F}b}M)>|;K$`2LdAPg(@Yr1Un+kD86o6t1q zp--FLf>Y$7DB4>Pu~eMsV$>5?HN9}l7RySxGAc*-QL>bFd@|7mn?$hnN?m(GO3A); z!P4NESUah@6nh4D?(eX^dtc79Xb_!CprM6=yovapTSQftwW0C3Z<6;Qxr7x&t|MX_ zo^NG6ZRHAz$lE=zV}BQK{}fnhT2Mv0H;D2*maC?uL5faZCkx&?u(NA7@e;7!gH2D<3PoHL+G&JeDI83@rA+zWjcwm299>;=~&(2)@(~< zxw@3ixuhf)yb5;yOFTjqb9?PyD5-iljNrg9kvg7{Oy15PL1c*q2%Dj7w{&Y*xyg&N zx|Pt%OHl|?$+dY4fk;$tT_}iHkl4oO+K$s+O>|@3{X6z==WPX5R76zh(iQp)L&oBX z&65)oICbI#2KxKacmBNkI~tBqB1*y~G?bQ?qq3?Bb!+O-xN#$Hy!mF-uV0@;c$9*E zCb)u{Agb4|MS0^o2v0$B;fJk4+xUDN84`T-=^1#SvpL%jvl5%oRgS2P%F53!RT)C8 zIbP%m8H-`&Y(Jt@%a|W;c<|Q0Ib}TO$V60rZ5`Wg*j4yoYi;7GOlarGuDJen4 zvT9Ube+}GK6(|7y5X!c)D@J--L!QEM6`?Jlw;72wC7_SjrI4hnM*i{x8G6EzpGp6B22r7WSucg~x=_-XRT46~TU3HNjH8kdXOc>;NUI}K$r7hO_$Wc@+eeS$N00rW zD5NqbNH(6{zaIyF{tL{`8t164u2$Znhi#EqtoUDGkyROLg!QYK8KtR<@r! z%nmrvRrX0kgTrdQ_wBdw>{Cw_c!Sx&6<_C*|Do1d7D`J?5hHDn&xR1bGy&uWW*`x|G?e6tMi;2L}wLl+w{)L3zT3}K`7l%<8+&Nio60uz4Np1xoYqct@6Ef(7!z6Y1@)cF= zFAfgkjn`ktQi3bAV{g4RZ+nCS5)>vyzFe#}iC8Kmt;U+@v9`G!rT`^X7?!{KzpuQS zx2`tSuffA#Z$bU)Rd9+|e*GK7TwM{4J^~oH_VImoH=F%6t+d zBL#aTJ~R4ctL;)tP3+=cKGqHiV&hR_oO6%V#FF9(ID+M~o<4aJ;ZSJ7{Y$7d@`vC3 z4jz861wZZh9#*X|uJO7}8}a9NG{FhDlzedN)V%HS*r^Ly!>dLg=HQjVQoZt_-F30;1yq$hdRY zi~ZU}C8oh>(KR~xDJWvSMu#;nd%cznP^HxZhhS~xgbSl?&6)*MevDCa#o}>2?RV=| zuZB~MjgF?>t}557g~>r2E+fok&bV_Q$${k^C}MRDhKLD~=!vHlAOn&TE^G~4ag~yT zzII)G#(irj1Emr1QA&8fed=`DeYV`NIpO5ryX|hQuFXB65{X1Ie>YZGC1!SwG9aX~ zS`7x5idd-|eyWtZ(uzKci77yER%0;CCKb!oxuq%dp=v3fzx(!E)%ua6@1)&l8Knf- z^TS(MA=!e8F^Wekms;!IyZ{{6AP$EFSI(jNPx3xim~}0%3t8rx%2qm!@Ed2Tx$P`n8fMn%#~DGeI3fZ>){ks zvUlGkDpXFT@%c7oNt07@g;@Wq)+U#xS|NLh*sc5p5xdv!PUL+us=OwSpF*6XoK=&< zxNcdw+CDUX6^}oA5Jyj+!^@pN!O1fp;jQ;hVr1ONA$+y@b10+CKa=w(4I6Otwbvx9 zFztEF_Amxpf0)jvsf<=hVxQr#L|-s7vF<8r#@TWm3P2Y%-KahX)QsgPi`__R#Z7LH zK#i_05);;*!Y;}VAjoGEE;qR$aa>c)QIjDFYin2F@o#?+L1(Hqxy%x#QG+qnhkB*_XIr^3fy;NK~lye-}vtCAl>hs%5f|di_Q!dLFcWyp+0`i^`MkoY~ zqNk(Aoft=@!xp0G-a>nLx+sd`ur@@eu1@{Za?Gb95J7|VZ{K%6hNIJIkM*6u+KIr$ zF^E9e*ii0?AoRS-6`Cej$ZRg^Q zH)T1XxSpN&6)RTE`})k4@dDfRlJV;Q9mR_j+D?{MBkn1)UB<$CtUGTOw*^*)aY{9M z$V|Lg$pZtjXzkRcb*mJ?+~p_r2FGSXxKLnD)Tjt0B2?t-8ye8|t-nUo?YFCQu{Yq( zv2(Jd$j;H}ZANIhscv$+H1b0H=5|||6veSvf>!E*hbl3?!J3-+#r|mj5W-Hag-Hzu z)q|U&Ji*r<`UY0l)g=Ofa5#+e^75Px<+LM*W|smp7aN!%i&agyX7-!MI`J2xh{Q6= zH`FT&s;xC-!HyuM?p{69PZpQwjd74MK}oq1qsRv%#_w5AEuWS9%ch<$6Szge2?XMb zD^6yan|gU}1S8Q+$pc|5CElvbkbD8Hy-UElp)h z%@%E?LMwITYRwJfPjuLjJ?ePsKeJgu)8;y7(2w3l5#g>ZN9mfCYJGKv#=#kCsePmG z61v|#hgZphKe$9q=hIZVO;A&HfIhP`hQ%_W<;hLul>SUx8gjnA3{CIZK#%%}wN6rZ zo4L*4lK)ekX^oVZ*QT@GC^E{-F#(m-hLw$kS<=SKlQS5bq#_>)8@UB0lv0qWri!Ve zDk)0SNgDL36>tiT!f%g*?3N30#S!;@hf&%C)`*&fvXgi#_Vt)y(v%hN5k+*n)XAur zR&3g!)>#rtvlKrU5!X;vW{}Ai%7iW_@;u2hA}J4WF6=^B7`GCO#gH#b*E(um_ups^ z(Wlh2&$yU53!bYorP1j?ia9xmL+nG5QL=JHB4}8amNjA zv*At%X2-8S6dCL@PM-LXvPvNpa&isc*w~0`ue~-A*UO6^QH_+P8xU1s1G8~l)C_lv z6WLr@GU`UiIOTT*csxj=yfx8q9Okn0if8KoyH0XP+b@B#Ok0C9tC&}hKuh<%W zr%SnqYPb&GMv`zC1x`J}gDYmv_Nk>E-1C|(jeT2=&e#`SzkWTcs;UzE$k{2(j0|IV zbPOXDVNpz;7=_3|KrU&)Y~b^jtXe_7cD>5RWdpgPM{W`oK3?bX8bTAD-1T)}XQ$7; z-@LLWh)}A)e5TdzHO-r?)(3}(j9$fThT%XQ*R!Rv^>R2mPOY*0si>$>g!4@^fkAVK zks8iM$Kmk>h4`&@@bSVUB4+yr zGvyAtENwNWmoi2dS>rYANI%X?8Y5=xT3e3tj(q*v;Dt*F_Fu|r-)wDCnV=WBoytOZ zXhg}DO!kTWFzXu?5J;n^kc`Q+)0(6u)^4@b*s9E(^9MR)8*)T&;BsC=f4KOcKYu=F zKa|}o-k)V+F%TV}z|_gJs^grAJt>}mR}F{FFpX5koSJYEi9FOsh<2+p?Ma0vN;i#~Td$~Dc$`?JL^<|s#Q2b(`q8Rr(F_|oZL+UyDl?*1IYU(h*YcRVJ@&jSJvjm1T~HOqo>Yy@H$I?Rbla@7};hL z&1xPOc69AECBa)=t#$G?Go{#!G~}}2&z$k+JwS~ukBPEeu3W&9kx0M_bdCUhw%>KvU4H)CoWZF@jfi*2?F;>WL1Nk5HQhLnCPhc%f43=pxlUB| zQUua$k;{|igoj4q1Xh>&T&>U2R=0a``kP2&>gwiu?zuy> zx?6f#PPY)77O^vIc9o91>|-a>P8bAXuTHKF1;9SnDy8zeqfvdgHC@u1Z@%fJ z3-5q6O>-6u4-c#K;ktF}lG25lz~L_^XX@(e9A~)LN-2ZZVG*icd{K>qiRrNO)YMcI zBvMLqL9Q6TiiG@Jo~qBBQ$|U{-FM&3;om0Mnu*iFX;|veVvm?wny^w1*_Ty|(v5#tXZ3ifuhHQ^QOS(S=x2EC*3PZ*ot|w zane{HY3yzF_4PURx8jGu4eaoqwY33~m|pUMdnwb^Yw4yP z{IFv>cFiLcvctbfuculxVlD8bwwYd}6OE&%*smh7ph`{*Ep*=dQ(qvon1m+IgC&AF zi)AaF@qTkQ4+F*v&Uz8YA)UMnr>})lZ$pZzxn0TP=^PN=#Fwn0aBz2#d5~4{aeVIkBlwmdsP9Na3T4@n(3N+`=$kxYkQ$y@$J{`v2Ho?Y9uvqIrQBYRr-8 r-gNu%kRKP1_;IPw*}v2lxe)#zJgI!#R9VSd00000NkvXXu0mjfQ0_LN diff --git a/core/src/main/res/drawable/ic_terning_profile_02.xml b/core/src/main/res/drawable/ic_terning_profile_02.xml index 1ad3e5dd8..8ba5ffc15 100644 --- a/core/src/main/res/drawable/ic_terning_profile_02.xml +++ b/core/src/main/res/drawable/ic_terning_profile_02.xml @@ -1,98 +1,75 @@ - - - - - - + android:width="76dp" + android:height="76dp" + android:viewportWidth="76" + android:viewportHeight="76"> + android:pathData="M38,0L38,0A38,38 0,0 1,76 38L76,38A38,38 0,0 1,38 76L38,76A38,38 0,0 1,0 38L0,38A38,38 0,0 1,38 0z"/> + android:pathData="M76,0H0V76H76V0Z" + android:fillColor="#D4F9DE"/> + + + + + + + + + + + + + - - - - - - - - - - - - - - diff --git a/core/src/main/res/drawable/ic_terning_profile_03.xml b/core/src/main/res/drawable/ic_terning_profile_03.xml index fc45cad6a..25e878efb 100644 --- a/core/src/main/res/drawable/ic_terning_profile_03.xml +++ b/core/src/main/res/drawable/ic_terning_profile_03.xml @@ -1,131 +1,76 @@ - - - - - + android:width="76dp" + android:height="76dp" + android:viewportWidth="76" + android:viewportHeight="76"> + android:pathData="M38,0L38,0A38,38 0,0 1,76 38L76,38A38,38 0,0 1,38 76L38,76A38,38 0,0 1,0 38L0,38A38,38 0,0 1,38 0z"/> + android:pathData="M76.209,0H0.209V76H76.209V0Z" + android:fillColor="#C5DEF2"/> + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - diff --git a/core/src/main/res/drawable/ic_terning_profile_04.xml b/core/src/main/res/drawable/ic_terning_profile_04.xml index 228909ea8..8b27c5c6c 100644 --- a/core/src/main/res/drawable/ic_terning_profile_04.xml +++ b/core/src/main/res/drawable/ic_terning_profile_04.xml @@ -1,150 +1,74 @@ + android:width="76dp" + android:height="76dp" + android:viewportWidth="76" + android:viewportHeight="76"> + android:pathData="M76,0H0V76H76V0Z" + android:fillColor="#E9F1E4"/> - - - - - - - - - - - - - - - - - - - - - - + android:pathData="M64.676,32.956H11.324V85.035H64.676V32.956Z" + android:strokeLineJoin="round" + android:strokeWidth="1.425" + android:fillColor="#ffffff" + android:strokeColor="#171717" + android:strokeLineCap="round"/> + android:pathData="M31.663,53.447C31.663,53.779 31.616,54.131 31.502,54.416C31.388,54.701 31.036,54.872 30.808,55.1C30.58,55.328 30.409,55.623 30.105,55.746C29.801,55.869 29.488,55.841 29.155,55.841C28.823,55.841 28.509,55.822 28.224,55.699C27.939,55.575 27.654,55.395 27.426,55.167C27.198,54.938 26.999,54.682 26.875,54.378C26.752,54.074 26.638,53.761 26.638,53.438C26.638,53.114 26.837,52.811 26.961,52.526C27.084,52.241 27.274,52.003 27.502,51.775C27.73,51.547 27.939,51.319 28.234,51.195C28.528,51.072 28.832,51.072 29.165,51.072C29.497,51.072 29.801,51.082 30.086,51.205C30.371,51.328 30.647,51.509 30.875,51.728C31.103,51.946 31.293,52.212 31.416,52.507C31.54,52.801 31.682,53.105 31.682,53.438L31.663,53.447Z" + android:fillColor="#F9DBDE"/> + android:pathData="M31.663,53.447C31.663,53.779 31.616,54.131 31.502,54.416C31.388,54.701 31.036,54.872 30.808,55.1C30.58,55.328 30.409,55.623 30.105,55.746C29.801,55.869 29.488,55.841 29.155,55.841C28.823,55.841 28.509,55.822 28.224,55.699C27.939,55.575 27.654,55.395 27.426,55.167C27.198,54.938 26.999,54.682 26.875,54.378C26.752,54.074 26.638,53.761 26.638,53.438C26.638,53.114 26.837,52.811 26.961,52.526C27.084,52.241 27.274,52.003 27.502,51.775C27.73,51.547 27.939,51.319 28.234,51.195C28.528,51.072 28.832,51.072 29.165,51.072C29.497,51.072 29.801,51.082 30.086,51.205C30.371,51.328 30.647,51.509 30.875,51.728C31.103,51.946 31.293,52.212 31.416,52.507C31.54,52.801 31.682,53.105 31.682,53.438L31.663,53.447Z" + android:strokeWidth="0.7315" + android:fillColor="#00000000" + android:strokeColor="#F9DBDE"/> + android:pathData="M49.343,53.267C49.343,53.599 49.267,53.932 49.143,54.226C49.02,54.521 48.839,54.825 48.611,55.043C48.383,55.262 48.079,55.433 47.785,55.556C47.49,55.68 47.167,55.651 46.835,55.651C46.502,55.651 46.217,55.585 45.923,55.461C45.628,55.338 45.267,55.281 45.049,55.053C44.83,54.825 44.669,54.511 44.545,54.217C44.422,53.922 44.422,53.599 44.422,53.267C44.422,52.934 44.45,52.611 44.564,52.326C44.678,52.041 44.897,51.775 45.125,51.557C45.353,51.338 45.638,51.215 45.932,51.091C46.227,50.968 46.502,50.92 46.835,50.92C47.167,50.92 47.49,50.863 47.785,50.987C48.079,51.11 48.355,51.3 48.583,51.528C48.811,51.756 49.01,52.022 49.134,52.326C49.257,52.63 49.343,52.944 49.343,53.276V53.267Z" + android:fillColor="#F9DBDE"/> + android:strokeColor="#F9DBDE"/> + android:pathData="M37.506,63.441H38.598C38.988,63.441 39.32,63.707 39.396,64.077L41.762,75.8C41.828,76.199 41.705,76.608 41.42,76.902L39.016,79.372C38.503,79.895 37.648,79.914 37.126,79.401L34.618,76.978C34.314,76.684 34.171,76.256 34.247,75.838L36.717,64.077C36.793,63.707 37.126,63.441 37.515,63.441H37.506Z" + android:strokeWidth="1.425" + android:fillColor="#A6B7FF" + android:strokeColor="#171717"/> + android:pathData="M39.168,63.907H36.955C36.518,63.907 36.147,63.603 36.053,63.185L35.54,60.952C35.407,60.373 35.853,59.812 36.442,59.812H39.701C40.299,59.812 40.745,60.373 40.603,60.952L40.071,63.185C39.976,63.603 39.596,63.897 39.168,63.897V63.907Z" + android:strokeWidth="1.425" + android:fillColor="#A6B7FF" + android:strokeColor="#171717"/> + android:pathData="M34.818,52.497C35.384,52.497 35.843,51.791 35.843,50.92C35.843,50.049 35.384,49.343 34.818,49.343C34.251,49.343 33.792,50.049 33.792,50.92C33.792,51.791 34.251,52.497 34.818,52.497Z" + android:fillColor="#171717"/> + android:pathData="M41.182,52.497C41.749,52.497 42.208,51.791 42.208,50.92C42.208,50.049 41.749,49.343 41.182,49.343C40.616,49.343 40.157,50.049 40.157,50.92C40.157,51.791 40.616,52.497 41.182,52.497Z" + android:fillColor="#171717"/> + diff --git a/core/src/main/res/drawable/ic_terning_profile_05.xml b/core/src/main/res/drawable/ic_terning_profile_05.xml index 2d21f7990..9a32c789e 100644 --- a/core/src/main/res/drawable/ic_terning_profile_05.xml +++ b/core/src/main/res/drawable/ic_terning_profile_05.xml @@ -1,111 +1,73 @@ - - - - + android:width="76dp" + android:height="76dp" + android:viewportWidth="76" + android:viewportHeight="76"> + android:pathData="M38,0L38,0A38,38 0,0 1,76 38L76,38A38,38 0,0 1,38 76L38,76A38,38 0,0 1,0 38L0,38A38,38 0,0 1,38 0z"/> + android:pathData="M76,0H0V76H76V0Z" + android:fillColor="#E6FFF6"/> + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - diff --git a/data/src/main/java/com/terning/data/dto/request/SignUpRequestDto.kt b/data/src/main/java/com/terning/data/dto/request/SignUpRequestDto.kt index fbfc3d0bf..9cea3722d 100644 --- a/data/src/main/java/com/terning/data/dto/request/SignUpRequestDto.kt +++ b/data/src/main/java/com/terning/data/dto/request/SignUpRequestDto.kt @@ -8,7 +8,7 @@ data class SignUpRequestDto( @SerialName("name") val name: String, @SerialName("profileImage") - val profileImage: Int, + val profileImage: String, @SerialName("authType") val authType: String ) \ No newline at end of file diff --git a/data/src/main/java/com/terning/data/dto/response/MyPageResponseDto.kt b/data/src/main/java/com/terning/data/dto/response/MyPageResponseDto.kt index 035919f84..3afedf5b3 100644 --- a/data/src/main/java/com/terning/data/dto/response/MyPageResponseDto.kt +++ b/data/src/main/java/com/terning/data/dto/response/MyPageResponseDto.kt @@ -7,6 +7,8 @@ import kotlinx.serialization.Serializable data class MyPageResponseDto( @SerialName("name") val name: String, + @SerialName("profileImage") + val profileImage: String, @SerialName("authType") val authType: String ) \ No newline at end of file diff --git a/data/src/main/java/com/terning/data/mapper/mypage/MyPageMapper.kt b/data/src/main/java/com/terning/data/mapper/mypage/MyPageMapper.kt index 2ae84fa1b..cfc5c65ba 100644 --- a/data/src/main/java/com/terning/data/mapper/mypage/MyPageMapper.kt +++ b/data/src/main/java/com/terning/data/mapper/mypage/MyPageMapper.kt @@ -3,4 +3,9 @@ package com.terning.data.mapper.mypage import com.terning.data.dto.response.MyPageResponseDto import com.terning.domain.entity.mypage.MyPageProfileModel -fun MyPageResponseDto.toMyPageProfile() = MyPageProfileModel(name = name, authType = authType) +fun MyPageResponseDto.toMyPageProfile() = + MyPageProfileModel( + name = name, + profileImage = profileImage, + authType = authType + ) diff --git a/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileModel.kt b/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileModel.kt index 9576d68dc..b9a617564 100644 --- a/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileModel.kt +++ b/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileModel.kt @@ -2,5 +2,6 @@ package com.terning.domain.entity.mypage data class MyPageProfileModel( val name: String, + val profileImage: String, val authType: String ) \ No newline at end of file diff --git a/domain/src/main/java/com/terning/domain/entity/onboarding/SignUpRequest.kt b/domain/src/main/java/com/terning/domain/entity/onboarding/SignUpRequest.kt index 7b24e160e..dc74f8bdb 100644 --- a/domain/src/main/java/com/terning/domain/entity/onboarding/SignUpRequest.kt +++ b/domain/src/main/java/com/terning/domain/entity/onboarding/SignUpRequest.kt @@ -2,6 +2,6 @@ package com.terning.domain.entity.onboarding data class SignUpRequest ( val name : String, - val profileImage : Int, + val profileImage : String, val authType : String ) \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt index b31050de1..8dec567d4 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt @@ -1,5 +1,6 @@ package com.terning.feature.mypage.mypage +import android.util.Log import androidx.compose.foundation.background import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Column @@ -15,15 +16,12 @@ import androidx.compose.material3.HorizontalDivider import androidx.compose.material3.Text import androidx.compose.material3.VerticalDivider import androidx.compose.runtime.Composable -import androidx.compose.runtime.CompositionLocalProvider import androidx.compose.runtime.DisposableEffect import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.SideEffect -import androidx.compose.runtime.compositionLocalOf import androidx.compose.runtime.getValue import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier -import androidx.compose.ui.graphics.Color import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview @@ -52,7 +50,7 @@ import com.terning.feature.mypage.mypage.component.MyPageItem @Composable fun MyPageRoute( paddingValues: PaddingValues, - navigateToProfileEdit: (String, Int) -> Unit, + navigateToProfileEdit: (String, String) -> Unit, viewModel: MyPageViewModel = hiltViewModel(), ) { val state by viewModel.state.collectAsStateWithLifecycle() @@ -81,7 +79,7 @@ fun MyPageRoute( when (sideEffect) { is MyPageSideEffect.NavigateToProfileEdit -> navigateToProfileEdit( state.name, - state.profile + state.profileImage ) } } @@ -127,13 +125,18 @@ fun MyPageRoute( onServiceClick = {}, onPersonalClick = {}, name = state.name, - profile = state.profile + profileImage = state.profileImage ) } - is UiState.Loading -> {} + is UiState.Loading -> { + Log.d("LYB", "로딩중") + } is UiState.Empty -> {} - is UiState.Failure -> {} + is UiState.Failure -> { + Log.d("LYB", "실패") + + } } if (state.showNotice) { @@ -158,7 +161,7 @@ fun MyPageScreen( onPersonalClick: () -> Unit, paddingValues: PaddingValues = PaddingValues(), name: String = "", - profile: Int = 0 + profileImage: String = "" ) { Column( modifier = Modifier @@ -168,7 +171,7 @@ fun MyPageScreen( ) { UserProfile( name = name, - profile = profile, + profileImage = profileImage, onEditClick = onEditClick ) TerningCommunity( @@ -221,7 +224,7 @@ fun UserProfile( name: String, onEditClick: () -> Unit, modifier: Modifier = Modifier, - profile: Int = 0, + profileImage: String = "", ) { Row( modifier = modifier.padding( @@ -230,7 +233,7 @@ fun UserProfile( bottom = 32.dp ) ) { - MyPageProfile(profile = profile) + MyPageProfile(profileImage = profileImage) Column { Text( text = name, diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageState.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageState.kt index bf072cb13..24f76c1ae 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageState.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageState.kt @@ -6,7 +6,7 @@ data class MyPageState( val isLogoutAndQuitSuccess: UiState = UiState.Loading, val isGetSuccess: UiState = UiState.Loading, val name: String = "", - val profile: Int = 0, + val profileImage: String = "", val authType : String ="", val showNotice: Boolean = false, val showOpinion: Boolean = false, diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageViewModel.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageViewModel.kt index b4f39bb61..b079d413b 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageViewModel.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageViewModel.kt @@ -104,6 +104,7 @@ class MyPageViewModel @Inject constructor( _state.value = _state.value.copy( isGetSuccess = UiState.Success(true), name = response.name, + profileImage = response.profileImage, authType = response.authType ) }.onFailure { diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/component/MyPageProfile.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/component/MyPageProfile.kt index cd12d2623..a0d985004 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/component/MyPageProfile.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/component/MyPageProfile.kt @@ -10,36 +10,21 @@ import androidx.compose.ui.draw.clip import androidx.compose.ui.res.painterResource import androidx.compose.ui.unit.dp import com.terning.core.R +import com.terning.core.type.ProfileImage @Composable fun MyPageProfile( modifier: Modifier = Modifier, - profile: Int + profileImage: String ) { - val options = listOf( - R.drawable.ic_terning_profile_00, - R.drawable.ic_terning_profile_01, - R.drawable.ic_terning_profile_02, - R.drawable.ic_terning_profile_03, - R.drawable.ic_terning_profile_04, - R.drawable.ic_terning_profile_05 - ) - - val option = when (profile) { - 0 -> options[0] - 1 -> options[1] - 2 -> options[2] - 3 -> options[3] - 4 -> options[4] - else -> options[5] - } + val userProfile = ProfileImage.fromString(profileImage) Image( - painter = painterResource(id = option), + painter = painterResource(id = userProfile.drawableResId), modifier = modifier .size(72.dp) .clip(shape = CircleShape) .aspectRatio(1f), contentDescription = "profile image" ) -} +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/navigation/MyPageNavigation.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/navigation/MyPageNavigation.kt index 7248c8a2a..e2543a085 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/navigation/MyPageNavigation.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/navigation/MyPageNavigation.kt @@ -25,10 +25,10 @@ fun NavGraphBuilder.myPageNavGraph( composable { MyPageRoute( paddingValues = paddingValues, - navigateToProfileEdit = { name, profile -> + navigateToProfileEdit = { name, profileImage -> navHostController.navigateProfileEdit( name, - profile + profileImage ) } ) diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt index 577c5689b..24a81239a 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt @@ -35,13 +35,14 @@ import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.designsystem.theme.White import com.terning.core.extension.addFocusCleaner import com.terning.core.extension.noRippleClickable +import com.terning.core.type.ProfileImage import com.terning.feature.R @Composable fun ProfileEditRoute( navigateUp: () -> Unit, initialName: String, - initialProfile: Int, + initialProfile: String, viewModel: ProfileEditViewModel = hiltViewModel(), ) { val state by viewModel.state.collectAsStateWithLifecycle() @@ -57,7 +58,10 @@ fun ProfileEditRoute( } LaunchedEffect(key1 = true) { - viewModel.updateInitialInfo(initialName = initialName, initialProfile = initialProfile) + viewModel.updateInitialInfo( + initialName = initialName, + initialProfile = initialProfile + ) } LaunchedEffect(viewModel.sideEffects, lifecycleOwner) { @@ -72,14 +76,15 @@ fun ProfileEditRoute( if (state.showBottomSheet) { ProfileBottomSheet( onDismiss = { viewModel.updateBottomSheet(false) }, - onSaveClick = { index -> + onSaveClick = { profileImage -> viewModel.updateBottomSheet(false) - viewModel.updateProfile(index) + viewModel.updateProfile(profileImage.stringValue) }, initialSelectedOption = state.profile ) } + ProfileEditScreen( profileEditState = state, onProfileEditClick = { isVisible -> @@ -137,7 +142,7 @@ fun ProfileEditScreen( onProfileEditClick(true) } .align(Alignment.CenterHorizontally), - index = profileEditState.profile + profileImage = profileEditState.profile ) Spacer(modifier = Modifier.height(48.dp)) Text( diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditState.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditState.kt index eb34b9548..a8f1d2b96 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditState.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditState.kt @@ -3,7 +3,7 @@ package com.terning.feature.mypage.profileedit data class ProfileEditState( val name: String = "", val initialName: String = "", - val profile: Int = 0, + val profile: String = "", val initialView: Boolean = true, val isButtonValid: Boolean = false, val authType: String = "", diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditViewModel.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditViewModel.kt index 58bf6349f..ecc575a98 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditViewModel.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditViewModel.kt @@ -27,7 +27,7 @@ class ProfileEditViewModel @Inject constructor() : ViewModel() { _state.value = _state.value.copy(showBottomSheet = isVisible) } - fun updateInitialInfo(initialName: String, initialProfile: Int) { + fun updateInitialInfo(initialName: String, initialProfile: String) { _state.value = _state.value.copy( name = initialName, initialName = initialName, @@ -36,11 +36,17 @@ class ProfileEditViewModel @Inject constructor() : ViewModel() { } fun updateName(name: String) { - _state.value = _state.value.copy(name = name, initialView = false) + _state.value = _state.value.copy( + name = name, + initialView = false + ) } - fun updateProfile(profile: Int) { - _state.value = _state.value.copy(profile = profile, initialView = false) + fun updateProfile(profile: String) { + _state.value = _state.value.copy( + profile = profile, + initialView = false + ) } fun updateButtonValidation(isValid: Boolean) { diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/navigation/ProfileEditNavigation.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/navigation/ProfileEditNavigation.kt index 71ef7f910..61b250f75 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/navigation/ProfileEditNavigation.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/navigation/ProfileEditNavigation.kt @@ -16,11 +16,11 @@ import kotlinx.serialization.Serializable fun NavController.navigateProfileEdit( name: String, - profile: Int, + profileImage: String, navOptions: NavOptions? = null ) { navigate( - route = ProfileEdit(name = name, profile = profile), + route = ProfileEdit(name = name, profileImage = profileImage), navOptions = navOptions ) } @@ -45,7 +45,7 @@ fun NavGraphBuilder.profileEditNavGraph( val args = it.toRoute() ProfileEditRoute( initialName = args.name, - initialProfile = args.profile, + initialProfile = args.profileImage, navigateUp = { navHostController.navigateUp() } ) } @@ -54,5 +54,5 @@ fun NavGraphBuilder.profileEditNavGraph( @Serializable data class ProfileEdit( val name: String, - val profile: Int + val profileImage: String ) : Route \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpRoute.kt b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpRoute.kt index 4be2f12c7..ba7e5c715 100644 --- a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpRoute.kt +++ b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpRoute.kt @@ -63,9 +63,9 @@ fun SignUpRoute( if (state.showBottomSheet) { ProfileBottomSheet( onDismiss = { viewModel.updateBottomSheet(false) }, - onSaveClick = { index -> + onSaveClick = { profileImage -> viewModel.updateBottomSheet(false) - viewModel.updateProfileImage(index) + viewModel.updateProfileImage(profileImage.stringValue) }, initialSelectedOption = state.profileImage ) @@ -127,7 +127,7 @@ fun SignUpScreen( modifier = Modifier.noRippleClickable { onProfileEditClick(true) }, - index = state.profileImage + profileImage = state.profileImage ) } Column( @@ -167,7 +167,7 @@ fun SignUpScreenPreview() { onSignUpClick = {}, onInputChange = {}, onProfileEditClick = {}, - onValidationChanged = {} + onValidationChanged = {}, ) } } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpState.kt b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpState.kt index 5a3f8b253..02c6c1796 100644 --- a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpState.kt +++ b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpState.kt @@ -2,7 +2,7 @@ package com.terning.feature.onboarding.signup data class SignUpState( val name: String = "", - val profileImage: Int = 0, + val profileImage: String = "", val isButtonValid: Boolean = false, val authId: String = "", val showBottomSheet: Boolean = false diff --git a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpViewModel.kt b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpViewModel.kt index 504bf3ada..6493c627b 100644 --- a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpViewModel.kt +++ b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpViewModel.kt @@ -36,7 +36,7 @@ class SignUpViewModel @Inject constructor( _state.value = _state.value.copy(name = name) } - fun updateProfileImage(profileImage: Int) { + fun updateProfileImage(profileImage: String) { _state.value = _state.value.copy(profileImage = profileImage) } From e34d4d99e2015eca54e1a6eb229794c40d89185c Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 12:12:14 +0900 Subject: [PATCH 22/33] =?UTF-8?q?[FEAT/#221]=20=EB=A7=88=EC=9D=B4=ED=8E=98?= =?UTF-8?q?=EC=9D=B4=EC=A7=80=20=EC=8B=A4=ED=8C=A8=20=ED=99=94=EB=A9=B4=20?= =?UTF-8?q?=EC=A0=81=EC=9A=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../bottomsheet/ProfileBottomSheet.kt | 4 +- .../com/terning/core/type/ProfileImage.kt | 6 +- .../drawable/ic_terning_profile_default.xml | 9 +++ .../feature/mypage/mypage/MyPageRoute.kt | 28 ++++--- .../feature/mypage/mypage/MyPageSideEffect.kt | 3 + .../feature/mypage/mypage/MyPageViewModel.kt | 2 + .../mypage/profileedit/ProfileEditRoute.kt | 1 - .../res/drawable/ic_terning_profile_00.xml | 60 -------------- .../res/drawable/ic_terning_profile_01.xml | 80 ------------------- .../res/drawable/ic_terning_profile_02.xml | 75 ----------------- .../res/drawable/ic_terning_profile_03.xml | 76 ------------------ .../res/drawable/ic_terning_profile_04.xml | 74 ----------------- .../res/drawable/ic_terning_profile_05.xml | 73 ----------------- 13 files changed, 34 insertions(+), 457 deletions(-) create mode 100644 core/src/main/res/drawable/ic_terning_profile_default.xml delete mode 100644 feature/src/main/res/drawable/ic_terning_profile_00.xml delete mode 100644 feature/src/main/res/drawable/ic_terning_profile_01.xml delete mode 100644 feature/src/main/res/drawable/ic_terning_profile_02.xml delete mode 100644 feature/src/main/res/drawable/ic_terning_profile_03.xml delete mode 100644 feature/src/main/res/drawable/ic_terning_profile_04.xml delete mode 100644 feature/src/main/res/drawable/ic_terning_profile_05.xml diff --git a/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt b/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt index 640952599..9ed4fbe71 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt @@ -97,10 +97,8 @@ fun RadioButtonGroup( initialSelectedOption: String, modifier: Modifier = Modifier, ) { - // 모든 ProfileImage 옵션을 가져옵니다. val options = ProfileImage.entries - // 초기 선택된 옵션을 ProfileImage로 변환하여 인덱스를 저장합니다. var selectedOptionIndex by rememberSaveable { mutableIntStateOf(ProfileImage.toIndex(ProfileImage.fromString(initialSelectedOption))) } @@ -111,7 +109,7 @@ fun RadioButtonGroup( horizontalArrangement = Arrangement.spacedBy(20.dp), modifier = modifier.padding(horizontal = 34.dp) ) { - itemsIndexed(options) { index, option -> + itemsIndexed(options.take(6)) { index, option -> val imageModifier = if (selectedOptionIndex == index) { Modifier .border( diff --git a/core/src/main/java/com/terning/core/type/ProfileImage.kt b/core/src/main/java/com/terning/core/type/ProfileImage.kt index 79fd6a1a4..eac0fda9d 100644 --- a/core/src/main/java/com/terning/core/type/ProfileImage.kt +++ b/core/src/main/java/com/terning/core/type/ProfileImage.kt @@ -12,7 +12,8 @@ enum class ProfileImage( SMART(drawableResId = R.drawable.ic_terning_profile_02, stringValue = "smart"), GLASS(drawableResId = R.drawable.ic_terning_profile_03, stringValue = "glass"), CALENDAR(drawableResId = R.drawable.ic_terning_profile_04, stringValue = "calendar"), - PASSION(drawableResId = R.drawable.ic_terning_profile_05, stringValue = "passion"); + PASSION(drawableResId = R.drawable.ic_terning_profile_05, stringValue = "passion"), + DEFAULT(drawableResId = R.drawable.ic_terning_profile_default, stringValue = "default"); companion object { fun fromString(value: String): ProfileImage = when (value) { @@ -21,7 +22,8 @@ enum class ProfileImage( "smart" -> SMART "glass" -> GLASS "calendar" -> CALENDAR - else -> PASSION + "passion" -> PASSION + else -> DEFAULT } fun toIndex(profileImage: ProfileImage): Int { diff --git a/core/src/main/res/drawable/ic_terning_profile_default.xml b/core/src/main/res/drawable/ic_terning_profile_default.xml new file mode 100644 index 000000000..e3a32368c --- /dev/null +++ b/core/src/main/res/drawable/ic_terning_profile_default.xml @@ -0,0 +1,9 @@ + + + diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt index 8dec567d4..4ec22dbcc 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageRoute.kt @@ -1,6 +1,5 @@ package com.terning.feature.mypage.mypage -import android.util.Log import androidx.compose.foundation.background import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Column @@ -42,6 +41,7 @@ import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.designsystem.theme.White import com.terning.core.extension.noRippleClickable +import com.terning.core.extension.toast import com.terning.core.state.UiState import com.terning.feature.R import com.terning.feature.mypage.component.MyPageProfile @@ -81,6 +81,8 @@ fun MyPageRoute( state.name, state.profileImage ) + + is MyPageSideEffect.ShowToast -> context.toast(sideEffect.message) } } } @@ -129,13 +131,13 @@ fun MyPageRoute( ) } - is UiState.Loading -> { - Log.d("LYB", "로딩중") - } + is UiState.Loading -> {} is UiState.Empty -> {} is UiState.Failure -> { - Log.d("LYB", "실패") - + MyPageScreen( + paddingValues = paddingValues, + profileImage = state.profileImage, + ) } } @@ -152,13 +154,13 @@ fun MyPageRoute( @Composable fun MyPageScreen( - onEditClick: () -> Unit, - onLogoutClick: () -> Unit, - onQuitClick: () -> Unit, - onNoticeClick: () -> Unit, - onOpinionClick: () -> Unit, - onServiceClick: () -> Unit, - onPersonalClick: () -> Unit, + onEditClick: () -> Unit = {}, + onLogoutClick: () -> Unit = {}, + onQuitClick: () -> Unit = {}, + onNoticeClick: () -> Unit = {}, + onOpinionClick: () -> Unit = {}, + onServiceClick: () -> Unit = {}, + onPersonalClick: () -> Unit = {}, paddingValues: PaddingValues = PaddingValues(), name: String = "", profileImage: String = "" diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageSideEffect.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageSideEffect.kt index 26d1e5856..edeb627ea 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageSideEffect.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageSideEffect.kt @@ -1,5 +1,8 @@ package com.terning.feature.mypage.mypage +import androidx.annotation.StringRes + sealed class MyPageSideEffect { data object NavigateToProfileEdit : MyPageSideEffect() + data class ShowToast(@StringRes val message: Int) : MyPageSideEffect() } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageViewModel.kt b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageViewModel.kt index b079d413b..535cf4b6d 100644 --- a/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageViewModel.kt +++ b/feature/src/main/java/com/terning/feature/mypage/mypage/MyPageViewModel.kt @@ -13,6 +13,7 @@ import com.kakao.sdk.user.UserApiClient import com.terning.core.state.UiState import com.terning.domain.repository.MyPageRepository import com.terning.domain.repository.TokenRepository +import com.terning.feature.R import com.terning.feature.main.MainActivity import dagger.hilt.android.lifecycle.HiltViewModel import kotlinx.coroutines.flow.MutableSharedFlow @@ -108,6 +109,7 @@ class MyPageViewModel @Inject constructor( authType = response.authType ) }.onFailure { + _sideEffects.emit(MyPageSideEffect.ShowToast(R.string.server_failure)) _state.value = _state.value.copy(isGetSuccess = UiState.Failure(it.toString())) } } diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt index 24a81239a..4e33d719f 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt @@ -84,7 +84,6 @@ fun ProfileEditRoute( ) } - ProfileEditScreen( profileEditState = state, onProfileEditClick = { isVisible -> diff --git a/feature/src/main/res/drawable/ic_terning_profile_00.xml b/feature/src/main/res/drawable/ic_terning_profile_00.xml deleted file mode 100644 index 99edfdf96..000000000 --- a/feature/src/main/res/drawable/ic_terning_profile_00.xml +++ /dev/null @@ -1,60 +0,0 @@ - - - - - - - - - - - - - - - - - diff --git a/feature/src/main/res/drawable/ic_terning_profile_01.xml b/feature/src/main/res/drawable/ic_terning_profile_01.xml deleted file mode 100644 index 0bfcc7b29..000000000 --- a/feature/src/main/res/drawable/ic_terning_profile_01.xml +++ /dev/null @@ -1,80 +0,0 @@ - - - - - - - - - - - - - - - - - - - - diff --git a/feature/src/main/res/drawable/ic_terning_profile_02.xml b/feature/src/main/res/drawable/ic_terning_profile_02.xml deleted file mode 100644 index 8ba5ffc15..000000000 --- a/feature/src/main/res/drawable/ic_terning_profile_02.xml +++ /dev/null @@ -1,75 +0,0 @@ - - - - - - - - - - - - - - - - - - - diff --git a/feature/src/main/res/drawable/ic_terning_profile_03.xml b/feature/src/main/res/drawable/ic_terning_profile_03.xml deleted file mode 100644 index 25e878efb..000000000 --- a/feature/src/main/res/drawable/ic_terning_profile_03.xml +++ /dev/null @@ -1,76 +0,0 @@ - - - - - - - - - - - - - - - - - - - - diff --git a/feature/src/main/res/drawable/ic_terning_profile_04.xml b/feature/src/main/res/drawable/ic_terning_profile_04.xml deleted file mode 100644 index 8b27c5c6c..000000000 --- a/feature/src/main/res/drawable/ic_terning_profile_04.xml +++ /dev/null @@ -1,74 +0,0 @@ - - - - - - - - - - - - - - - - diff --git a/feature/src/main/res/drawable/ic_terning_profile_05.xml b/feature/src/main/res/drawable/ic_terning_profile_05.xml deleted file mode 100644 index 9a32c789e..000000000 --- a/feature/src/main/res/drawable/ic_terning_profile_05.xml +++ /dev/null @@ -1,73 +0,0 @@ - - - - - - - - - - - - - - - - - - From f116f312cf41f29a6e77e0a5cc2fd35ccf49d4c6 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 12:15:48 +0900 Subject: [PATCH 23/33] =?UTF-8?q?[FEAT/#221]=20=EC=A3=BC=EC=84=9D=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 --- .../component/bottomsheet/ProfileBottomSheet.kt | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt b/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt index 9ed4fbe71..8067b2af7 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt @@ -39,7 +39,7 @@ import kotlinx.coroutines.launch * @param modifier 바텀시트에 적용할 Modifier입니다. * @param onDismiss 바텀시트가 닫힐 때 호출되는 콜백 함수입니다. * @param onSaveClick 저장하기 버튼 클릭 시, 호출되는 콜백 함수입니다. - * @param initialSelectedOption 초기에 선택된 이미지를 나타내는 인덱스 값입니다. + * @param initialSelectedOption 초기에 선택된 이미지의 이름을 string 값입니다. */ @OptIn(ExperimentalMaterial3Api::class) @Composable @@ -87,8 +87,8 @@ fun ProfileBottomSheet( /** * 6개의 프로필 이미지 중, 하나의 이미지만 선택할 수 있는 라디오 버튼입니다. * - * @param onOptionSelected 선택된 이미지의 인덱스 값을 나타내는 콜백 함수입니다. - * @param initialSelectedOption 초기에 선택된 이미지를 나타내는 인덱스 값입니다. + * @param onOptionSelected 선택된 이미지의 이름을 나타내는 콜백 함수입니다. + * @param initialSelectedOption 초기에 선택된 이미지의 이름을 나타내는 string 값입니다. * @param modifier 라디오 버튼에 적용할 Modifier입니다. */ @Composable From e3643d33f911f1090fbef214f229cbc2374c1eb8 Mon Sep 17 00:00:00 2001 From: boiledegg Date: Sat, 7 Sep 2024 16:09:11 +0900 Subject: [PATCH 24/33] =?UTF-8?q?[ADD/#223]=20=EA=B7=B8=EB=9E=98=ED=94=BD?= =?UTF-8?q?=20=ED=8C=8C=EC=9D=BC=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- feature/src/main/assets/terning_onboarding_start.json | 1 + 1 file changed, 1 insertion(+) create mode 100644 feature/src/main/assets/terning_onboarding_start.json diff --git a/feature/src/main/assets/terning_onboarding_start.json b/feature/src/main/assets/terning_onboarding_start.json new file mode 100644 index 000000000..b233f8331 --- /dev/null +++ b/feature/src/main/assets/terning_onboarding_start.json @@ -0,0 +1 @@ +{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.5.10","a":"","k":"","d":"","tc":""},"fr":29.9700012207031,"ip":0,"op":66.0000026882351,"w":3120,"h":3720,"nm":"aos_onboarding","ddd":0,"assets":[{"id":"image_0","w":512,"h":420,"u":"/images/","p":"","e":0},{"id":"image_1","w":512,"h":421,"u":"/images/","p":"","e":0},{"id":"image_2","w":308,"h":366,"u":"/images/","p":"","e":0},{"id":"image_3","w":340,"h":389,"u":"/images/","p":"","e":0},{"id":"image_4","w":510,"h":353,"u":"/images/","p":"","e":0},{"id":"image_5","w":317,"h":498,"u":"/images/","p":"","e":0},{"id":"image_6","w":417,"h":369,"u":"/images/","p":"","e":0},{"id":"image_7","w":2672,"h":1966,"u":"/images/","p":"","e":0}],"layers":[{"ddd":0,"ind":1,"ty":2,"nm":"right_hand","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":30,"s":[10]},{"t":65.0000026475043,"s":[0]}],"ix":10},"p":{"a":0,"k":[2288.651,2057.194,0],"ix":2},"a":{"a":0,"k":[91.687,101.702,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":66.0000026882351,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":2,"nm":"left_hand","refId":"image_1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":30,"s":[-10]},{"t":65.0000026475043,"s":[0]}],"ix":10},"p":{"a":0,"k":[852.437,2074.236,0],"ix":2},"a":{"a":0,"k":[415.628,94.174,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":66.0000026882351,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":2,"nm":"paper1","refId":"image_2","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[629.348,1634.708,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":30,"s":[629.348,1604.7,0],"to":[0,0,0],"ti":[0,0,0]},{"t":65.0000026475043,"s":[629.348,1634.708,0]}],"ix":2},"a":{"a":0,"k":[153.785,182.706,0],"ix":1},"s":{"a":1,"k":[{"i":{"x":[0.833,0.833,0.833],"y":[0.833,0.833,0.833]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,0.167]},"t":0,"s":[100,100,100]},{"i":{"x":[0.833,0.833,0.833],"y":[0.833,0.833,0.833]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,0.167]},"t":40,"s":[97,97,100]},{"t":65.0000026475043,"s":[100,100,100]}],"ix":6}},"ao":0,"ip":0,"op":66.0000026882351,"st":0,"bm":0},{"ddd":0,"ind":4,"ty":2,"nm":"paper4","refId":"image_3","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[2175.905,1086.807,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":30,"s":[2175.905,1119,0],"to":[0,0,0],"ti":[0,0,0]},{"t":65.0000026475043,"s":[2175.905,1086.807,0]}],"ix":2},"a":{"a":0,"k":[169.638,194.06,0],"ix":1},"s":{"a":1,"k":[{"i":{"x":[0.833,0.833,0.833],"y":[0.833,0.833,0.833]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,0.167]},"t":0,"s":[100,100,100]},{"i":{"x":[0.833,0.833,0.833],"y":[0.833,0.833,0.833]},"o":{"x":[0.167,0.167,0.167],"y":[0.167,0.167,0.167]},"t":23,"s":[103,103,100]},{"t":65.0000026475043,"s":[100,100,100]}],"ix":6}},"ao":0,"ip":0,"op":66.0000026882351,"st":0,"bm":0},{"ddd":0,"ind":5,"ty":2,"nm":"paper3","refId":"image_4","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":35,"s":[-5]},{"t":65.0000026475043,"s":[0]}],"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[1557.1,796.965,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":35,"s":[1557.1,767,0],"to":[0,0,0],"ti":[0,0,0]},{"t":65.0000026475043,"s":[1557.1,796.965,0]}],"ix":2},"a":{"a":0,"k":[254.672,176.274,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":66.0000026882351,"st":0,"bm":0},{"ddd":0,"ind":6,"ty":2,"nm":"paper2","refId":"image_5","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":25,"s":[5]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":48,"s":[3]},{"t":65.0000026475043,"s":[0]}],"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[939.527,1085.535,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":25,"s":[939.527,1115,0],"to":[0,0,0],"ti":[0,0,0]},{"t":65.0000026475043,"s":[939.527,1085.535,0]}],"ix":2},"a":{"a":0,"k":[158.109,248.53,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":66.0000026882351,"st":0,"bm":0},{"ddd":0,"ind":7,"ty":2,"nm":"paper5","refId":"image_6","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":33,"s":[-8]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":53,"s":[-3]},{"t":65.0000026475043,"s":[0]}],"ix":10},"p":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[2486.008,1625.728,0],"to":[0,0,0],"ti":[0,0,0]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":30,"s":[2486.008,1595,0],"to":[0,0,0],"ti":[0,0,0]},{"t":65.0000026475043,"s":[2486.008,1625.728,0]}],"ix":2},"a":{"a":0,"k":[208.47,184.497,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":66.0000026882351,"st":0,"bm":0},{"ddd":0,"ind":8,"ty":2,"nm":"body","refId":"image_7","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1560,2117.53,0],"ix":2},"a":{"a":0,"k":[1335.962,982.843,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":66.0000026882351,"st":0,"bm":0},{"ddd":0,"ind":9,"ty":1,"nm":"back","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[1560,1860,0],"ix":2},"a":{"a":0,"k":[1560,1860,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"sw":3120,"sh":3720,"sc":"#ffffff","ip":0,"op":66.0000026882351,"st":0,"bm":0}],"markers":[]} \ No newline at end of file From 2090077659f9b3c5c0c8ec1fd763742c5a8b4c87 Mon Sep 17 00:00:00 2001 From: boiledegg Date: Sat, 7 Sep 2024 16:09:54 +0900 Subject: [PATCH 25/33] =?UTF-8?q?[UI/#223]=20=EC=98=A8=EB=B3=B4=EB=94=A9?= =?UTF-8?q?=20=EC=8B=9C=EC=9E=91=20=EA=B7=B8=EB=9E=98=ED=94=BD=20=EC=B6=94?= =?UTF-8?q?=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../component/item/TerningLottieAnimation.kt | 7 +++++-- .../filtering/startfiltering/StartFilteringRoute.kt | 13 ++++++++----- 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt b/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt index 65a0cbdcb..cdaca33d7 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt @@ -3,6 +3,8 @@ package com.terning.core.designsystem.component.item import androidx.compose.runtime.Composable import androidx.compose.runtime.getValue import androidx.compose.ui.Modifier +import androidx.compose.ui.draw.clip +import androidx.compose.ui.graphics.RectangleShape import com.airbnb.lottie.compose.LottieAnimation import com.airbnb.lottie.compose.LottieCompositionSpec import com.airbnb.lottie.compose.rememberLottieComposition @@ -14,7 +16,8 @@ fun TerningLottieAnimation( ) { val lottieComposition by rememberLottieComposition(LottieCompositionSpec.Asset(jsonString)) LottieAnimation( - modifier = modifier, - composition = lottieComposition + modifier = modifier.clip(RectangleShape), + composition = lottieComposition, + clipToCompositionBounds = false ) } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt index dd7326109..d2fef703e 100644 --- a/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt @@ -27,6 +27,7 @@ import androidx.compose.ui.unit.dp import androidx.hilt.navigation.compose.hiltViewModel import androidx.lifecycle.compose.collectAsStateWithLifecycle import com.terning.core.designsystem.component.button.RectangleButton +import com.terning.core.designsystem.component.item.TerningLottieAnimation import com.terning.core.designsystem.theme.TerningPointTheme import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.designsystem.theme.White @@ -79,16 +80,18 @@ fun StartFilteringScreen( Text( text = stringResource(id = R.string.start_filtering_title), style = TerningTheme.typography.title1, - modifier = Modifier.padding(bottom = 35.dp), + modifier = Modifier.padding(bottom = 36.dp), textAlign = TextAlign.Center ) - Image( - painter = painterResource(id = R.drawable.ic_terning_onboarding), + + TerningLottieAnimation( + jsonString = "terning_onboarding_start.json", modifier = Modifier .fillMaxWidth() - .padding(horizontal = 24.dp), - contentDescription = "terning image" + .height(372.dp) + .padding(horizontal = 24.dp) ) + Spacer(modifier = Modifier.weight(2f)) } Box( From e86534132b8eaa92f14a1db83e63a99e0a755c0d Mon Sep 17 00:00:00 2001 From: boiledegg Date: Sat, 7 Sep 2024 16:16:44 +0900 Subject: [PATCH 26/33] =?UTF-8?q?[UI/#223]=20=EC=95=A0=EB=8B=88=EB=A9=94?= =?UTF-8?q?=EC=9D=B4=EC=85=98=20=EB=B0=98=EB=B3=B5=20=EC=84=A4=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../designsystem/component/item/TerningLottieAnimation.kt | 5 ++++- .../feature/filtering/startfiltering/StartFilteringRoute.kt | 2 ++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt b/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt index cdaca33d7..a3468d931 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt @@ -7,17 +7,20 @@ import androidx.compose.ui.draw.clip import androidx.compose.ui.graphics.RectangleShape import com.airbnb.lottie.compose.LottieAnimation import com.airbnb.lottie.compose.LottieCompositionSpec +import com.airbnb.lottie.compose.LottieConstants import com.airbnb.lottie.compose.rememberLottieComposition @Composable fun TerningLottieAnimation( jsonString: String, - modifier: Modifier = Modifier + modifier: Modifier = Modifier, + iterations: Int = 1, ) { val lottieComposition by rememberLottieComposition(LottieCompositionSpec.Asset(jsonString)) LottieAnimation( modifier = modifier.clip(RectangleShape), composition = lottieComposition, + iterations = iterations, clipToCompositionBounds = false ) } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt index d2fef703e..47c47b9fc 100644 --- a/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt +++ b/feature/src/main/java/com/terning/feature/filtering/startfiltering/StartFilteringRoute.kt @@ -26,6 +26,7 @@ import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import androidx.hilt.navigation.compose.hiltViewModel import androidx.lifecycle.compose.collectAsStateWithLifecycle +import com.airbnb.lottie.compose.LottieConstants import com.terning.core.designsystem.component.button.RectangleButton import com.terning.core.designsystem.component.item.TerningLottieAnimation import com.terning.core.designsystem.theme.TerningPointTheme @@ -86,6 +87,7 @@ fun StartFilteringScreen( TerningLottieAnimation( jsonString = "terning_onboarding_start.json", + iterations = LottieConstants.IterateForever, modifier = Modifier .fillMaxWidth() .height(372.dp) From dcf7894c126a14e3f4129a40e03929006f675787 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 19:06:25 +0900 Subject: [PATCH 27/33] =?UTF-8?q?[FEAT/#221]=20=ED=94=84=EB=A1=9C=ED=95=84?= =?UTF-8?q?=20=EC=88=98=EC=A0=95=20=EB=B7=B0=20=EC=84=9C=EB=B2=84=ED=86=B5?= =?UTF-8?q?=EC=8B=A0=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../data/datasource/MyPageDataSource.kt | 5 +++++ .../datasourceimpl/MyPageDataSourceImpl.kt | 5 +++++ .../request/MyPageProfileEditRequestDto.kt | 12 ++++++++++ .../data/mapper/mypage/MyPageMapper.kt | 4 ++-- .../mapper/mypage/MyPageProfileEditMapper.kt | 10 +++++++++ .../repositoryimpl/MyPageRepositoryImpl.kt | 15 +++++++++++-- .../com/terning/data/service/MyPageService.kt | 4 ++++ ...MyPageProfileModel.kt => MyPageProfile.kt} | 2 +- .../domain/entity/mypage/MyPageProfileEdit.kt | 6 +++++ .../domain/repository/MyPageRepository.kt | 9 ++++++-- .../mypage/profileedit/ProfileEditRoute.kt | 10 +++++++-- .../profileedit/ProfileEditSideEffect.kt | 3 +++ .../profileedit/ProfileEditViewModel.kt | 22 ++++++++++++++++++- 13 files changed, 97 insertions(+), 10 deletions(-) create mode 100644 data/src/main/java/com/terning/data/dto/request/MyPageProfileEditRequestDto.kt create mode 100644 data/src/main/java/com/terning/data/mapper/mypage/MyPageProfileEditMapper.kt rename domain/src/main/java/com/terning/domain/entity/mypage/{MyPageProfileModel.kt => MyPageProfile.kt} (79%) create mode 100644 domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileEdit.kt diff --git a/data/src/main/java/com/terning/data/datasource/MyPageDataSource.kt b/data/src/main/java/com/terning/data/datasource/MyPageDataSource.kt index 5eee61e1b..60361d5f2 100644 --- a/data/src/main/java/com/terning/data/datasource/MyPageDataSource.kt +++ b/data/src/main/java/com/terning/data/datasource/MyPageDataSource.kt @@ -2,6 +2,7 @@ package com.terning.data.datasource import com.terning.data.dto.BaseResponse import com.terning.data.dto.NonDataBaseResponse +import com.terning.data.dto.request.MyPageProfileEditRequestDto import com.terning.data.dto.response.MyPageResponseDto interface MyPageDataSource { @@ -10,4 +11,8 @@ interface MyPageDataSource { suspend fun deleteQuit(): NonDataBaseResponse suspend fun getProfile(): BaseResponse + + suspend fun editProfile( + request: MyPageProfileEditRequestDto + ): NonDataBaseResponse } \ No newline at end of file diff --git a/data/src/main/java/com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt b/data/src/main/java/com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt index d1636d0d5..faf607c61 100644 --- a/data/src/main/java/com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt +++ b/data/src/main/java/com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt @@ -3,6 +3,7 @@ package com.terning.data.datasourceimpl import com.terning.data.datasource.MyPageDataSource import com.terning.data.dto.BaseResponse import com.terning.data.dto.NonDataBaseResponse +import com.terning.data.dto.request.MyPageProfileEditRequestDto import com.terning.data.dto.response.MyPageResponseDto import com.terning.data.service.MyPageService import javax.inject.Inject @@ -15,4 +16,8 @@ class MyPageDataSourceImpl @Inject constructor( override suspend fun deleteQuit(): NonDataBaseResponse = myPageService.deleteQuit() override suspend fun getProfile(): BaseResponse = myPageService.getProfile() + + override suspend fun editProfile( + request: MyPageProfileEditRequestDto + ): NonDataBaseResponse = myPageService.modifyProfile() } \ No newline at end of file diff --git a/data/src/main/java/com/terning/data/dto/request/MyPageProfileEditRequestDto.kt b/data/src/main/java/com/terning/data/dto/request/MyPageProfileEditRequestDto.kt new file mode 100644 index 000000000..3f4c7ef8a --- /dev/null +++ b/data/src/main/java/com/terning/data/dto/request/MyPageProfileEditRequestDto.kt @@ -0,0 +1,12 @@ +package com.terning.data.dto.request + +import kotlinx.serialization.SerialName +import kotlinx.serialization.Serializable + +@Serializable +data class MyPageProfileEditRequestDto( + @SerialName("name") + val name: String, + @SerialName("profileImage") + val profileImage: String, +) \ No newline at end of file diff --git a/data/src/main/java/com/terning/data/mapper/mypage/MyPageMapper.kt b/data/src/main/java/com/terning/data/mapper/mypage/MyPageMapper.kt index cfc5c65ba..0a19f6e76 100644 --- a/data/src/main/java/com/terning/data/mapper/mypage/MyPageMapper.kt +++ b/data/src/main/java/com/terning/data/mapper/mypage/MyPageMapper.kt @@ -1,10 +1,10 @@ package com.terning.data.mapper.mypage import com.terning.data.dto.response.MyPageResponseDto -import com.terning.domain.entity.mypage.MyPageProfileModel +import com.terning.domain.entity.mypage.MyPageProfile fun MyPageResponseDto.toMyPageProfile() = - MyPageProfileModel( + MyPageProfile( name = name, profileImage = profileImage, authType = authType diff --git a/data/src/main/java/com/terning/data/mapper/mypage/MyPageProfileEditMapper.kt b/data/src/main/java/com/terning/data/mapper/mypage/MyPageProfileEditMapper.kt new file mode 100644 index 000000000..892bbd425 --- /dev/null +++ b/data/src/main/java/com/terning/data/mapper/mypage/MyPageProfileEditMapper.kt @@ -0,0 +1,10 @@ +package com.terning.data.mapper.mypage + +import com.terning.data.dto.request.MyPageProfileEditRequestDto +import com.terning.domain.entity.mypage.MyPageProfileEdit + +fun MyPageProfileEdit.toMyPageProfileEditRequestDto(): MyPageProfileEditRequestDto = + MyPageProfileEditRequestDto( + name = name, + profileImage = profileImage + ) diff --git a/data/src/main/java/com/terning/data/repositoryimpl/MyPageRepositoryImpl.kt b/data/src/main/java/com/terning/data/repositoryimpl/MyPageRepositoryImpl.kt index 45cafad9b..76aa84af2 100644 --- a/data/src/main/java/com/terning/data/repositoryimpl/MyPageRepositoryImpl.kt +++ b/data/src/main/java/com/terning/data/repositoryimpl/MyPageRepositoryImpl.kt @@ -2,7 +2,9 @@ package com.terning.data.repositoryimpl import com.terning.data.datasource.MyPageDataSource import com.terning.data.mapper.mypage.toMyPageProfile -import com.terning.domain.entity.mypage.MyPageProfileModel +import com.terning.data.mapper.mypage.toMyPageProfileEditRequestDto +import com.terning.domain.entity.mypage.MyPageProfile +import com.terning.domain.entity.mypage.MyPageProfileEdit import com.terning.domain.repository.MyPageRepository import javax.inject.Inject @@ -19,8 +21,17 @@ class MyPageRepositoryImpl @Inject constructor( myPageDataSource.deleteQuit() } - override suspend fun getProfile(): Result = + override suspend fun getProfile(): Result = runCatching { myPageDataSource.getProfile().result.toMyPageProfile() } + + override suspend fun editProfile( + request: MyPageProfileEdit + ): Result = + runCatching { + myPageDataSource.editProfile( + request.toMyPageProfileEditRequestDto() + ) + } } \ No newline at end of file diff --git a/data/src/main/java/com/terning/data/service/MyPageService.kt b/data/src/main/java/com/terning/data/service/MyPageService.kt index 26a7d76ca..d033094d0 100644 --- a/data/src/main/java/com/terning/data/service/MyPageService.kt +++ b/data/src/main/java/com/terning/data/service/MyPageService.kt @@ -5,6 +5,7 @@ import com.terning.data.dto.NonDataBaseResponse import com.terning.data.dto.response.MyPageResponseDto import retrofit2.http.DELETE import retrofit2.http.GET +import retrofit2.http.PATCH import retrofit2.http.POST interface MyPageService { @@ -16,4 +17,7 @@ interface MyPageService { @GET("api/v1/mypage/profile") suspend fun getProfile(): BaseResponse + + @PATCH("api/v1/mypage/profile") + suspend fun modifyProfile(): NonDataBaseResponse } \ No newline at end of file diff --git a/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileModel.kt b/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfile.kt similarity index 79% rename from domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileModel.kt rename to domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfile.kt index b9a617564..356758d3e 100644 --- a/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileModel.kt +++ b/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfile.kt @@ -1,6 +1,6 @@ package com.terning.domain.entity.mypage -data class MyPageProfileModel( +data class MyPageProfile( val name: String, val profileImage: String, val authType: String diff --git a/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileEdit.kt b/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileEdit.kt new file mode 100644 index 000000000..398575b04 --- /dev/null +++ b/domain/src/main/java/com/terning/domain/entity/mypage/MyPageProfileEdit.kt @@ -0,0 +1,6 @@ +package com.terning.domain.entity.mypage + +data class MyPageProfileEdit( + val name: String, + val profileImage: String +) \ No newline at end of file diff --git a/domain/src/main/java/com/terning/domain/repository/MyPageRepository.kt b/domain/src/main/java/com/terning/domain/repository/MyPageRepository.kt index 26eaed11f..917b82c17 100644 --- a/domain/src/main/java/com/terning/domain/repository/MyPageRepository.kt +++ b/domain/src/main/java/com/terning/domain/repository/MyPageRepository.kt @@ -1,11 +1,16 @@ package com.terning.domain.repository -import com.terning.domain.entity.mypage.MyPageProfileModel +import com.terning.domain.entity.mypage.MyPageProfile +import com.terning.domain.entity.mypage.MyPageProfileEdit interface MyPageRepository { suspend fun postLogout(): Result suspend fun deleteQuit(): Result - suspend fun getProfile(): Result + suspend fun getProfile(): Result + + suspend fun editProfile( + request: MyPageProfileEdit + ): Result } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt index 4e33d719f..565969645 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt @@ -15,6 +15,7 @@ import androidx.compose.runtime.SideEffect import androidx.compose.runtime.getValue import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier +import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.platform.LocalFocusManager import androidx.compose.ui.res.stringResource import androidx.compose.ui.tooling.preview.Preview @@ -35,7 +36,7 @@ import com.terning.core.designsystem.theme.TerningTheme import com.terning.core.designsystem.theme.White import com.terning.core.extension.addFocusCleaner import com.terning.core.extension.noRippleClickable -import com.terning.core.type.ProfileImage +import com.terning.core.extension.toast import com.terning.feature.R @Composable @@ -48,6 +49,7 @@ fun ProfileEditRoute( val state by viewModel.state.collectAsStateWithLifecycle() val lifecycleOwner = LocalLifecycleOwner.current + val context = LocalContext.current val systemUiController = rememberSystemUiController() @@ -69,6 +71,7 @@ fun ProfileEditRoute( .collect { sideEffect -> when (sideEffect) { is ProfileEditSideEffect.NavigateUp -> navigateUp() + is ProfileEditSideEffect.ShowToast -> context.toast(sideEffect.message) } } } @@ -92,7 +95,10 @@ fun ProfileEditRoute( onInputChange = { editName -> viewModel.updateName(editName) }, - onSaveClick = { viewModel.navigateUp() }, + onSaveClick = { + viewModel.modifyUserInfo() + // viewModel.navigateUp() + }, name = state.name, onBackButtonClick = { viewModel.navigateUp() }, onValidationChanged = { isValid -> diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditSideEffect.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditSideEffect.kt index 6fd2f3668..9d16e2bc8 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditSideEffect.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditSideEffect.kt @@ -1,5 +1,8 @@ package com.terning.feature.mypage.profileedit +import androidx.annotation.StringRes + sealed class ProfileEditSideEffect { data object NavigateUp : ProfileEditSideEffect() + data class ShowToast(@StringRes val message: Int) : ProfileEditSideEffect() } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditViewModel.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditViewModel.kt index ecc575a98..5516b79c2 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditViewModel.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditViewModel.kt @@ -2,6 +2,9 @@ package com.terning.feature.mypage.profileedit import androidx.lifecycle.ViewModel import androidx.lifecycle.viewModelScope +import com.terning.domain.entity.mypage.MyPageProfileEdit +import com.terning.domain.repository.MyPageRepository +import com.terning.feature.R import dagger.hilt.android.lifecycle.HiltViewModel import kotlinx.coroutines.flow.MutableSharedFlow import kotlinx.coroutines.flow.MutableStateFlow @@ -13,7 +16,9 @@ import kotlinx.coroutines.launch import javax.inject.Inject @HiltViewModel -class ProfileEditViewModel @Inject constructor() : ViewModel() { +class ProfileEditViewModel @Inject constructor( + private val myPageRepository: MyPageRepository, +) : ViewModel() { private val _state: MutableStateFlow = MutableStateFlow(ProfileEditState()) val state: StateFlow get() = _state.asStateFlow() @@ -53,4 +58,19 @@ class ProfileEditViewModel @Inject constructor() : ViewModel() { _state.value = _state.value.copy(isButtonValid = isValid) } + fun modifyUserInfo() { + viewModelScope.launch { + myPageRepository.editProfile( + MyPageProfileEdit( + name = _state.value.name, + profileImage = _state.value.profile + ) + ).onSuccess { + _sideEffects.emit(ProfileEditSideEffect.NavigateUp) + }.onFailure { + _sideEffects.emit(ProfileEditSideEffect.ShowToast(R.string.server_failure)) + } + } + } + } \ No newline at end of file From b668696cb40c86fdbd606c4281fd5632e25d08d0 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 19:11:31 +0900 Subject: [PATCH 28/33] =?UTF-8?q?[FEAT/#221]=20=EC=BD=94=EB=93=9C=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 --- core/src/main/java/com/terning/core/type/ProfileImage.kt | 5 ++--- .../com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt | 2 +- data/src/main/java/com/terning/data/service/MyPageService.kt | 2 +- .../terning/feature/mypage/profileedit/ProfileEditRoute.kt | 1 - 4 files changed, 4 insertions(+), 6 deletions(-) diff --git a/core/src/main/java/com/terning/core/type/ProfileImage.kt b/core/src/main/java/com/terning/core/type/ProfileImage.kt index eac0fda9d..df24f2d39 100644 --- a/core/src/main/java/com/terning/core/type/ProfileImage.kt +++ b/core/src/main/java/com/terning/core/type/ProfileImage.kt @@ -26,8 +26,7 @@ enum class ProfileImage( else -> DEFAULT } - fun toIndex(profileImage: ProfileImage): Int { - return entries.indexOf(profileImage) - } + fun toIndex(profileImage: ProfileImage): Int = + entries.indexOf(profileImage) } } diff --git a/data/src/main/java/com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt b/data/src/main/java/com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt index faf607c61..bc96ce7b0 100644 --- a/data/src/main/java/com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt +++ b/data/src/main/java/com/terning/data/datasourceimpl/MyPageDataSourceImpl.kt @@ -19,5 +19,5 @@ class MyPageDataSourceImpl @Inject constructor( override suspend fun editProfile( request: MyPageProfileEditRequestDto - ): NonDataBaseResponse = myPageService.modifyProfile() + ): NonDataBaseResponse = myPageService.editProfile() } \ No newline at end of file diff --git a/data/src/main/java/com/terning/data/service/MyPageService.kt b/data/src/main/java/com/terning/data/service/MyPageService.kt index d033094d0..6ce2d16ae 100644 --- a/data/src/main/java/com/terning/data/service/MyPageService.kt +++ b/data/src/main/java/com/terning/data/service/MyPageService.kt @@ -19,5 +19,5 @@ interface MyPageService { suspend fun getProfile(): BaseResponse @PATCH("api/v1/mypage/profile") - suspend fun modifyProfile(): NonDataBaseResponse + suspend fun editProfile(): NonDataBaseResponse } \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt index 565969645..7dba0d325 100644 --- a/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt +++ b/feature/src/main/java/com/terning/feature/mypage/profileedit/ProfileEditRoute.kt @@ -97,7 +97,6 @@ fun ProfileEditRoute( }, onSaveClick = { viewModel.modifyUserInfo() - // viewModel.navigateUp() }, name = state.name, onBackButtonClick = { viewModel.navigateUp() }, From 34cab10ce1c5648948d02773380b478e9b012ad7 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 19:18:55 +0900 Subject: [PATCH 29/33] =?UTF-8?q?[FEAT/#221]=20@DrawableRes=20=EC=96=B4?= =?UTF-8?q?=EB=85=B8=ED=85=8C=EC=9D=B4=EC=85=98=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- core/src/main/java/com/terning/core/type/ProfileImage.kt | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/core/src/main/java/com/terning/core/type/ProfileImage.kt b/core/src/main/java/com/terning/core/type/ProfileImage.kt index df24f2d39..8ccc58040 100644 --- a/core/src/main/java/com/terning/core/type/ProfileImage.kt +++ b/core/src/main/java/com/terning/core/type/ProfileImage.kt @@ -1,9 +1,10 @@ package com.terning.core.type +import androidx.annotation.DrawableRes import com.terning.core.R enum class ProfileImage( - val drawableResId: Int, + @DrawableRes val drawableResId: Int, val stringValue: String ) { From a4f1c0c081921cb25af21b742350f2d6fe6e1f35 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 19:20:38 +0900 Subject: [PATCH 30/33] =?UTF-8?q?[MOD/#221]=20=EC=A3=BC=EC=84=9D=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/bottomsheet/ProfileBottomSheet.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt b/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt index 8067b2af7..9109deb87 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/bottomsheet/ProfileBottomSheet.kt @@ -39,7 +39,7 @@ import kotlinx.coroutines.launch * @param modifier 바텀시트에 적용할 Modifier입니다. * @param onDismiss 바텀시트가 닫힐 때 호출되는 콜백 함수입니다. * @param onSaveClick 저장하기 버튼 클릭 시, 호출되는 콜백 함수입니다. - * @param initialSelectedOption 초기에 선택된 이미지의 이름을 string 값입니다. + * @param initialSelectedOption 초기에 선택된 이미지의 이름을 나타내는 string 값입니다. */ @OptIn(ExperimentalMaterial3Api::class) @Composable From fdba10ce2f6041dffea6ab996a3f3c6b03bfe8c4 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sat, 7 Sep 2024 20:27:02 +0900 Subject: [PATCH 31/33] =?UTF-8?q?[FEAT/#221]=20SnackBar=20=EA=B5=AC?= =?UTF-8?q?=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../snackbar/TerningBasicSnackBar.kt | 23 ++++++++++++++ .../com/terning/feature/main/MainScreen.kt | 31 ++++++++++++++----- 2 files changed, 47 insertions(+), 7 deletions(-) create mode 100644 core/src/main/java/com/terning/core/designsystem/component/snackbar/TerningBasicSnackBar.kt diff --git a/core/src/main/java/com/terning/core/designsystem/component/snackbar/TerningBasicSnackBar.kt b/core/src/main/java/com/terning/core/designsystem/component/snackbar/TerningBasicSnackBar.kt new file mode 100644 index 000000000..0d12f3811 --- /dev/null +++ b/core/src/main/java/com/terning/core/designsystem/component/snackbar/TerningBasicSnackBar.kt @@ -0,0 +1,23 @@ +package com.terning.core.designsystem.component.snackbar + +import androidx.compose.foundation.background +import androidx.compose.foundation.layout.Box +import androidx.compose.foundation.layout.padding +import androidx.compose.foundation.shape.CircleShape +import androidx.compose.runtime.Composable +import androidx.compose.ui.Modifier +import androidx.compose.ui.draw.clip +import androidx.compose.ui.unit.dp +import com.terning.core.designsystem.theme.Grey500 + +@Composable +fun TerningBasicSnackBar(content: @Composable () -> Unit) { + Box( + modifier = Modifier + .clip(CircleShape) + .background(Grey500) + .padding(vertical = 7.dp, horizontal = 20.dp) + ) { + content() + } +} \ No newline at end of file diff --git a/feature/src/main/java/com/terning/feature/main/MainScreen.kt b/feature/src/main/java/com/terning/feature/main/MainScreen.kt index 5836eeeb1..516f63bf1 100644 --- a/feature/src/main/java/com/terning/feature/main/MainScreen.kt +++ b/feature/src/main/java/com/terning/feature/main/MainScreen.kt @@ -1,8 +1,6 @@ package com.terning.feature.main import android.app.Activity -import android.content.Intent -import android.widget.Toast import androidx.activity.compose.BackHandler import androidx.compose.animation.AnimatedVisibility import androidx.compose.animation.EnterTransition @@ -17,6 +15,9 @@ import androidx.compose.material3.Icon import androidx.compose.material3.NavigationBar import androidx.compose.material3.NavigationBarItem import androidx.compose.material3.Scaffold +import androidx.compose.material3.SnackbarDuration +import androidx.compose.material3.SnackbarHost +import androidx.compose.material3.SnackbarHostState import androidx.compose.material3.Text import androidx.compose.runtime.Composable import androidx.compose.runtime.getValue @@ -30,8 +31,8 @@ import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.stringResource import androidx.compose.ui.unit.IntOffset import androidx.compose.ui.unit.sp -import androidx.core.content.ContextCompat.startActivity import androidx.navigation.compose.NavHost +import com.terning.core.designsystem.component.snackbar.TerningBasicSnackBar import com.terning.core.designsystem.theme.Grey300 import com.terning.core.designsystem.theme.TerningMain import com.terning.core.designsystem.theme.White @@ -44,7 +45,6 @@ import com.terning.feature.filtering.startfiltering.navigation.startFilteringNav import com.terning.feature.filtering.starthome.navigation.startHomeNavGraph import com.terning.feature.home.changefilter.navigation.changeFilterNavGraph import com.terning.feature.home.home.navigation.homeNavGraph -import com.terning.feature.home.home.navigation.navigateHome import com.terning.feature.intern.navigation.internNavGraph import com.terning.feature.mypage.mypage.navigation.myPageNavGraph import com.terning.feature.mypage.profileedit.navigation.profileEditNavGraph @@ -53,7 +53,6 @@ import com.terning.feature.onboarding.signup.navigation.signUpNavGraph import com.terning.feature.onboarding.splash.navigation.splashNavGraph import com.terning.feature.search.search.navigation.searchNavGraph import com.terning.feature.search.searchprocess.navigation.searchProcessNavGraph -import kotlinx.coroutines.delay import kotlinx.coroutines.launch @Composable @@ -64,17 +63,35 @@ fun MainScreen( var backPressedState by remember { mutableStateOf(true) } var backPressedTime = 0L + val snackBarHostState = remember { SnackbarHostState() } + val coroutineScope = rememberCoroutineScope() + BackHandler(enabled = backPressedState) { - if(System.currentTimeMillis() - backPressedTime <= 3000) { + if (System.currentTimeMillis() - backPressedTime <= 3000) { (context as Activity).finish() } else { backPressedState = true - Toast.makeText(context, "한 번 더 누르시면 앱이 종료됩니다.", Toast.LENGTH_SHORT).show() + coroutineScope.launch { + snackBarHostState.showSnackbar( + message = "버튼을 한 번 더 누르면 종료돼요", + duration = SnackbarDuration.Short + ) + } } backPressedTime = System.currentTimeMillis() } Scaffold( + snackbarHost = { + SnackbarHost(hostState = snackBarHostState) { snackBarData -> + TerningBasicSnackBar { + Text( + text = snackBarData.visuals.message, + color = White, + ) + } + } + }, bottomBar = { MainBottomBar( isVisible = navigator.showBottomBar(), From 348b2a03101ccaecb8241a4a3c1c8ccf775ab3e4 Mon Sep 17 00:00:00 2001 From: LEE YOU BIN Date: Sun, 8 Sep 2024 14:25:27 +0900 Subject: [PATCH 32/33] =?UTF-8?q?[FEAT/#221]=20=EC=9E=84=EC=8B=9C=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 --- core/src/main/java/com/terning/core/type/ProfileImage.kt | 2 +- .../java/com/terning/feature/onboarding/signup/SignUpState.kt | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/core/src/main/java/com/terning/core/type/ProfileImage.kt b/core/src/main/java/com/terning/core/type/ProfileImage.kt index 8ccc58040..f4836df27 100644 --- a/core/src/main/java/com/terning/core/type/ProfileImage.kt +++ b/core/src/main/java/com/terning/core/type/ProfileImage.kt @@ -24,7 +24,7 @@ enum class ProfileImage( "glass" -> GLASS "calendar" -> CALENDAR "passion" -> PASSION - else -> DEFAULT + else -> BASIC } fun toIndex(profileImage: ProfileImage): Int = diff --git a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpState.kt b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpState.kt index 02c6c1796..773904e4c 100644 --- a/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpState.kt +++ b/feature/src/main/java/com/terning/feature/onboarding/signup/SignUpState.kt @@ -2,7 +2,7 @@ package com.terning.feature.onboarding.signup data class SignUpState( val name: String = "", - val profileImage: String = "", + val profileImage: String = "basic", val isButtonValid: Boolean = false, val authId: String = "", val showBottomSheet: Boolean = false From acd21dbef513494121ec33ca4ffbbbf1d1e7ac77 Mon Sep 17 00:00:00 2001 From: boiledegg Date: Sun, 8 Sep 2024 23:31:01 +0900 Subject: [PATCH 33/33] =?UTF-8?q?[DEL/#223]=20=EB=9D=BC=EC=9D=B4=EB=B8=8C?= =?UTF-8?q?=EB=9F=AC=EB=A6=AC=20=EC=A0=9C=EA=B1=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../core/designsystem/component/item/TerningLottieAnimation.kt | 1 - 1 file changed, 1 deletion(-) diff --git a/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt b/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt index a3468d931..1ff5c5df3 100644 --- a/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt +++ b/core/src/main/java/com/terning/core/designsystem/component/item/TerningLottieAnimation.kt @@ -7,7 +7,6 @@ import androidx.compose.ui.draw.clip import androidx.compose.ui.graphics.RectangleShape import com.airbnb.lottie.compose.LottieAnimation import com.airbnb.lottie.compose.LottieCompositionSpec -import com.airbnb.lottie.compose.LottieConstants import com.airbnb.lottie.compose.rememberLottieComposition @Composable