From 9ab3ffc2d8acc7e3d46c285a08af71e574225dff Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Thu, 31 Aug 2023 18:13:23 +0900 Subject: [PATCH 01/12] =?UTF-8?q?:sparkles:=20=ED=99=94=EB=A9=B4=20?= =?UTF-8?q?=EC=84=B8=EB=A1=9C=20=EA=B3=A0=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/src/main/AndroidManifest.xml | 1 + 1 file changed, 1 insertion(+) diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index c34ee587..c051a1c6 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -16,6 +16,7 @@ android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/Theme.AppCompat" + android:screenOrientation="portrait" tools:targetApi="31"> Date: Thu, 31 Aug 2023 18:16:55 +0900 Subject: [PATCH 02/12] =?UTF-8?q?:sparkles:=20=EC=83=9D=EC=9B=94=20?= =?UTF-8?q?=EC=98=A4=EC=B0=A8=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../presentation/screens/signin/SignInUserNameScreen.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/signin/SignInUserNameScreen.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/signin/SignInUserNameScreen.kt index 34217cdb..1ab6d47f 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/screens/signin/SignInUserNameScreen.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/signin/SignInUserNameScreen.kt @@ -136,7 +136,7 @@ fun SignInUserNameScreen(onSuccess: () -> Unit) { viewModel.setUserNameState( userNameState.copy( year = year, - month = month, + month = month + 1, day = day, ), ) From aa3710dbce32e6492db5ee25c11a5545cfeb1b5c Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Thu, 31 Aug 2023 18:26:16 +0900 Subject: [PATCH 03/12] =?UTF-8?q?:sparkles:=20=EB=8B=AC=EB=A6=AC=EA=B8=B0?= =?UTF-8?q?=20=EC=B4=88=20=EA=B0=84=EA=B2=A9=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/src/main/java/com/whyranoid/walkie/RunningWorker.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/src/main/java/com/whyranoid/walkie/RunningWorker.kt b/app/src/main/java/com/whyranoid/walkie/RunningWorker.kt index a4e2f96e..c5237270 100644 --- a/app/src/main/java/com/whyranoid/walkie/RunningWorker.kt +++ b/app/src/main/java/com/whyranoid/walkie/RunningWorker.kt @@ -139,7 +139,7 @@ class RunningWorker( const val WORKER_NAME = "RunningWorker" const val NOTIFICATION_ID = 2000 const val CHANNEL_ID = "Walkie Channel" - const val UPDATE_INTERVAL_MS = 2000L + const val UPDATE_INTERVAL_MS = 1000L } } From 063741efd963f9c4e23998fd20b0d17b331c8d7e Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Thu, 31 Aug 2023 19:10:25 +0900 Subject: [PATCH 04/12] =?UTF-8?q?:sparkles:=20=EB=A7=88=EC=9D=B4=ED=8E=98?= =?UTF-8?q?=EC=9D=B4=EC=A7=80=EC=97=90=20=EB=A1=9C=EC=BB=AC=20=EB=8D=B0?= =?UTF-8?q?=EC=9D=B4=ED=84=B0=20=EC=97=B0=EB=8F=99=20=EB=B0=8F=20=EC=9D=B4?= =?UTF-8?q?=EB=A6=84=20=EB=B3=80=EA=B2=BD=20=EB=B6=88=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/com/whyranoid/walkie/KoinModules.kt | 2 + .../data/repository/AccountRepositoryImpl.kt | 2 + .../domain/repository/AccountRepository.kt | 3 ++ .../{ => editprofile}/EditProfileScreen.kt | 50 +++++++++++-------- .../editprofile/EditProfileViewModel.kt | 11 ++++ 5 files changed, 47 insertions(+), 21 deletions(-) rename presentation/src/main/java/com/whyranoid/presentation/screens/mypage/{ => editprofile}/EditProfileScreen.kt (85%) create mode 100644 presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileViewModel.kt diff --git a/app/src/main/java/com/whyranoid/walkie/KoinModules.kt b/app/src/main/java/com/whyranoid/walkie/KoinModules.kt index 9232a994..b7529262 100644 --- a/app/src/main/java/com/whyranoid/walkie/KoinModules.kt +++ b/app/src/main/java/com/whyranoid/walkie/KoinModules.kt @@ -40,6 +40,7 @@ import com.whyranoid.domain.usecase.running.GetRunningFollowerUseCase import com.whyranoid.domain.usecase.running.RunningFinishUseCase import com.whyranoid.domain.usecase.running.RunningPauseOrResumeUseCase import com.whyranoid.domain.usecase.running.RunningStartUseCase +import com.whyranoid.presentation.screens.mypage.editprofile.EditProfileViewModel import com.whyranoid.presentation.viewmodel.ChallengeDetailViewModel import com.whyranoid.presentation.viewmodel.ChallengeExitViewModel import com.whyranoid.presentation.viewmodel.ChallengeMainViewModel @@ -70,6 +71,7 @@ val viewModelModule = module { factory { SplashViewModel(get()) } factory { SignInViewModel(get()) } factory { SelectHistoryViewModel(get()) } + factory { EditProfileViewModel(get()) } } val repositoryModule = module { diff --git a/data/src/main/java/com/whyranoid/data/repository/AccountRepositoryImpl.kt b/data/src/main/java/com/whyranoid/data/repository/AccountRepositoryImpl.kt index e4478a36..b14bdec4 100644 --- a/data/src/main/java/com/whyranoid/data/repository/AccountRepositoryImpl.kt +++ b/data/src/main/java/com/whyranoid/data/repository/AccountRepositoryImpl.kt @@ -14,6 +14,8 @@ class AccountRepositoryImpl( override val authId: Flow = accountDataStore.authId override val uId: Flow = accountDataStore.uId + override val userName: Flow = accountDataStore.userName + override val nickName: Flow = accountDataStore.nickName // TODO API Call override suspend fun signUp( diff --git a/domain/src/main/java/com/whyranoid/domain/repository/AccountRepository.kt b/domain/src/main/java/com/whyranoid/domain/repository/AccountRepository.kt index 807b876e..2117622b 100644 --- a/domain/src/main/java/com/whyranoid/domain/repository/AccountRepository.kt +++ b/domain/src/main/java/com/whyranoid/domain/repository/AccountRepository.kt @@ -7,6 +7,9 @@ interface AccountRepository { val authId: Flow val uId: Flow + val userName: Flow + val nickName: Flow + suspend fun signUp( authId: String, userName: String, diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/EditProfileScreen.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt similarity index 85% rename from presentation/src/main/java/com/whyranoid/presentation/screens/mypage/EditProfileScreen.kt rename to presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt index 0bea76b3..21c2403b 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/EditProfileScreen.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt @@ -1,4 +1,4 @@ -package com.whyranoid.presentation.screens.mypage +package com.whyranoid.presentation.screens.mypage.editprofile import androidx.compose.foundation.Image import androidx.compose.foundation.background @@ -22,8 +22,10 @@ import androidx.compose.material.icons.filled.Edit import androidx.compose.material3.Icon 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.saveable.rememberSaveable import androidx.compose.runtime.setValue import androidx.compose.ui.Alignment @@ -32,19 +34,28 @@ import androidx.compose.ui.draw.clip import androidx.compose.ui.graphics.Color import androidx.compose.ui.graphics.vector.ImageVector import androidx.compose.ui.res.painterResource +import androidx.compose.ui.text.TextStyle import androidx.compose.ui.unit.Dp import androidx.compose.ui.unit.dp +import androidx.lifecycle.compose.collectAsStateWithLifecycle import androidx.navigation.NavController import com.whyranoid.presentation.reusable.CheckableCustomTextField +import com.whyranoid.presentation.theme.WalkieColor import com.whyranoid.presentation.theme.WalkieTypography +import org.koin.androidx.compose.koinViewModel @Composable -fun EditProfileScreen(name: String = "", nick: String = "", navController: NavController) { - EditProfileContent(name = name, nick = nick) { +fun EditProfileScreen(navController: NavController) { + val viewModel = koinViewModel() + val name = viewModel.name.collectAsStateWithLifecycle(initialValue = "") + val nick = viewModel.nick.collectAsStateWithLifecycle(initialValue = "") + + EditProfileContent(name = name.value ?: "null", nick = nick.value ?: "null") { navController.popBackStack() } } +// TODO API 연결 @Composable fun EditProfileContent(name: String, nick: String, onCloseClicked: () -> Unit) { Column( @@ -118,17 +129,14 @@ fun EditProfileContent(name: String, nick: String, onCloseClicked: () -> Unit) { Text( modifier = Modifier.align(Alignment.Start), - text = "이름 변경", + text = "이름", fontWeight = WalkieTypography.Title.fontWeight, ) Spacer(modifier = Modifier.height(16.dp)) - var nameText by rememberSaveable { mutableStateOf(name) } - - CheckableCustomTextField( - text = nameText, - onTextChanged = { text -> nameText = text }, + Box( + contentAlignment = Alignment.CenterStart, modifier = Modifier .fillMaxWidth() .height(34.dp) @@ -136,15 +144,13 @@ fun EditProfileContent(name: String, nick: String, onCloseClicked: () -> Unit) { Color(0xFFEEEEEE), RoundedCornerShape(10.dp), ), - trailingIcon = { - Icon( - imageVector = Icons.Filled.Edit, - contentDescription = "Edit Icon", - tint = Color(0xFF989898), - ) - }, - placeholderText = "이름", - ) + ) { + Text( + modifier = Modifier.padding(start = 8.dp), + text = name, + style = TextStyle.Default.copy(color = WalkieColor.GrayDefault), + ) + } Spacer(modifier = Modifier.height(20.dp)) @@ -156,9 +162,12 @@ fun EditProfileContent(name: String, nick: String, onCloseClicked: () -> Unit) { Spacer(modifier = Modifier.height(16.dp)) - // TODO 임시로 만든 변수, viewModel, uiState로 관리하도록 변경 필요(139, 171 line) var nickCheckState: Boolean? by rememberSaveable { mutableStateOf(null) } - var nickName by rememberSaveable { mutableStateOf(nick) } + var nickName by remember { mutableStateOf(nick) } + + LaunchedEffect(key1 = nick) { + nickName = nick + } CheckableCustomTextField( text = nickName, @@ -177,7 +186,6 @@ fun EditProfileContent(name: String, nick: String, onCloseClicked: () -> Unit) { tint = Color(0xFF989898), ) }, - placeholderText = "닉네임", checkButton = { text -> Text( text = "확인", diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileViewModel.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileViewModel.kt new file mode 100644 index 00000000..df97383e --- /dev/null +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileViewModel.kt @@ -0,0 +1,11 @@ +package com.whyranoid.presentation.screens.mypage.editprofile + +import androidx.lifecycle.ViewModel +import com.whyranoid.domain.repository.AccountRepository + +class EditProfileViewModel( + private val accountRepository: AccountRepository, +) : ViewModel() { + val name = accountRepository.userName + val nick = accountRepository.nickName +} From f0a650c44579774de7515e66007e9add5dc1e6a4 Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Thu, 31 Aug 2023 19:19:32 +0900 Subject: [PATCH 05/12] =?UTF-8?q?:sparkles:=20=EC=8A=A4=ED=94=8C=EB=9E=98?= =?UTF-8?q?=EC=8B=9C=20=EC=A0=81=EC=9A=A9=20=EB=B0=8F=20=ED=8C=A8=ED=82=A4?= =?UTF-8?q?=EC=A7=80=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../whyranoid/presentation/screens/AppScreen.kt | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/AppScreen.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/AppScreen.kt index fef723ef..8e87fe1c 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/screens/AppScreen.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/AppScreen.kt @@ -40,11 +40,14 @@ import com.whyranoid.presentation.screens.Screen.Companion.bottomNavigationItems import com.whyranoid.presentation.screens.challenge.ChallengeDetailScreen import com.whyranoid.presentation.screens.challenge.ChallengeExitScreen import com.whyranoid.presentation.screens.challenge.ChallengeMainScreen -import com.whyranoid.presentation.screens.mypage.EditProfileScreen import com.whyranoid.presentation.screens.mypage.MyPageScreen import com.whyranoid.presentation.screens.mypage.addpost.AddPostScreen +import com.whyranoid.presentation.screens.mypage.editprofile.EditProfileScreen import com.whyranoid.presentation.screens.running.RunningScreen +import com.whyranoid.presentation.screens.signin.SignInScreen +import com.whyranoid.presentation.screens.splash.SplashScreen import com.whyranoid.presentation.theme.WalkieColor +import com.whyranoid.presentation.viewmodel.SplashState import com.whyranoid.presentation.viewmodel.SplashViewModel import org.koin.androidx.compose.koinViewModel @@ -87,11 +90,11 @@ fun AppScreen(startWorker: () -> Unit) { val splashState = splashViewModel.splashState.collectAsStateWithLifecycle() AppScreenContent(startWorker, navController) // TODO Splash 적용 -// when (splashState.value) { -// SplashState.InitialState -> SplashScreen() -// SplashState.SignInState -> SignInScreen { splashViewModel.finishSignIn() } -// SplashState.SignedInState -> AppScreenContent(startWorker, navController) -// } + when (splashState.value) { + SplashState.InitialState -> SplashScreen() + SplashState.SignInState -> SignInScreen { splashViewModel.finishSignIn() } + SplashState.SignedInState -> AppScreenContent(startWorker, navController) + } } @Composable From 95cd85678201841cea8746fd8cbb85ec09e4dfb2 Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Thu, 31 Aug 2023 19:26:36 +0900 Subject: [PATCH 06/12] =?UTF-8?q?:sparkles:=20=EB=82=B4=EC=9C=84=EC=B9=98?= =?UTF-8?q?=20=ED=9D=B0=20=ED=85=8C=EB=91=90=EB=A6=AC=20=EC=A0=81=EC=9A=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../whyranoid/presentation/screens/running/RunningScreen.kt | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/running/RunningScreen.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/running/RunningScreen.kt index 1d55eb13..d64df597 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/screens/running/RunningScreen.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/running/RunningScreen.kt @@ -295,6 +295,8 @@ fun RunningMapScreen( LocationOverlay( position = LatLng(location), icon = OverlayImage.fromResource(R.drawable.ic_running_screen_selected), + circleOutlineWidth = 2.dp, + circleOutlineColor = Color.White, ) } } @@ -305,6 +307,8 @@ fun RunningMapScreen( LocationOverlay( position = LatLng(location), icon = OverlayImage.fromResource(R.drawable.ic_running_screen_selected), + circleOutlineWidth = 2.dp, + circleOutlineColor = Color.White, ) } From 7beefebb65a8ba883bedcc62eb33dd3d3b856cab Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Thu, 31 Aug 2023 19:45:56 +0900 Subject: [PATCH 07/12] =?UTF-8?q?:sparkles:=20=ED=85=8D=EC=8A=A4=ED=8A=B8?= =?UTF-8?q?=20=EC=83=89=EC=83=81=20=EB=B3=80=EA=B2=BD=20=EC=A0=81=EC=9A=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../screens/mypage/addpost/PostingScreen.kt | 100 +++++++----------- 1 file changed, 39 insertions(+), 61 deletions(-) diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/addpost/PostingScreen.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/addpost/PostingScreen.kt index 75082105..07a4f870 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/addpost/PostingScreen.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/addpost/PostingScreen.kt @@ -19,6 +19,7 @@ import androidx.compose.foundation.layout.padding import androidx.compose.foundation.layout.size import androidx.compose.foundation.layout.wrapContentHeight import androidx.compose.foundation.layout.wrapContentSize +import androidx.compose.foundation.shape.CircleShape import androidx.compose.foundation.shape.RoundedCornerShape import androidx.compose.foundation.text.BasicTextField import androidx.compose.foundation.text.KeyboardActions @@ -70,27 +71,20 @@ import java.util.* @SuppressLint("SimpleDateFormat") @Composable fun PostingScreen(runningHistory: RunningHistory) { - var textVisibleState by remember { mutableStateOf(true) } + var textVisibleState by remember { mutableStateOf(TEXTVISIBLESTATE.WHITE) } var photoEditState by remember { mutableStateOf(false) } Column( - modifier = Modifier - .fillMaxWidth() - .wrapContentHeight(), + modifier = Modifier.fillMaxWidth().wrapContentHeight(), verticalArrangement = Arrangement.Top, ) { Box( - Modifier - .fillMaxWidth() - .padding(horizontal = 20.dp) - .padding(top = 20.dp), + Modifier.fillMaxWidth().padding(horizontal = 20.dp).padding(top = 20.dp), ) { Text( style = WalkieTypography.Title, text = "새 게시물", - modifier = Modifier - .align(Alignment.Center) - .padding(bottom = 24.dp), + modifier = Modifier.align(Alignment.Center).padding(bottom = 24.dp), ) } @@ -103,12 +97,8 @@ fun PostingScreen(runningHistory: RunningHistory) { Row( horizontalArrangement = Arrangement.Center, verticalAlignment = Alignment.CenterVertically, - modifier = Modifier - .padding(bottom = 12.dp) - .weight(1f) - .height(40.dp) - .clip(RoundedCornerShape(12.dp)) - .background(WalkieColor.GrayDefault), + modifier = Modifier.padding(bottom = 12.dp).weight(1f).height(40.dp) + .clip(RoundedCornerShape(12.dp)).background(WalkieColor.GrayDefault), ) { Text(text = it, style = WalkieTypography.SubTitle) } @@ -122,33 +112,28 @@ fun PostingScreen(runningHistory: RunningHistory) { Row( horizontalArrangement = Arrangement.SpaceAround, verticalAlignment = Alignment.CenterVertically, - modifier = Modifier - .padding(horizontal = 20.dp) - .align(Alignment.End) - .wrapContentSize(), + modifier = Modifier.padding(horizontal = 20.dp).align(Alignment.End).wrapContentSize(), ) { if (photoEditState) { Text("앨범", style = WalkieTypography.SubTitle) Spacer(Modifier.weight(1f)) } Icon( - modifier = Modifier - .clickable { - textVisibleState = textVisibleState.not() + modifier = Modifier.clickable { + textVisibleState = when (textVisibleState) { + TEXTVISIBLESTATE.WHITE -> TEXTVISIBLESTATE.BLACK + TEXTVISIBLESTATE.BLACK -> TEXTVISIBLESTATE.HIDE + TEXTVISIBLESTATE.HIDE -> TEXTVISIBLESTATE.WHITE } - .size(48.dp) - .padding(12.dp), + }.size(48.dp).clip(CircleShape).padding(12.dp), painter = painterResource(id = R.drawable.ic_timer), contentDescription = "textVisible", tint = WalkieColor.GrayDefault, ) Icon( - modifier = Modifier - .clickable { - photoEditState = photoEditState.not() - } - .size(48.dp) - .padding(12.dp), + modifier = Modifier.clickable { + photoEditState = photoEditState.not() + }.size(48.dp).clip(CircleShape).padding(12.dp), painter = painterResource(id = R.drawable.ic_gallery), contentDescription = "gallery", tint = WalkieColor.GrayDefault, @@ -166,13 +151,9 @@ fun PostingScreen(runningHistory: RunningHistory) { BasicTextField( keyboardActions = KeyboardActions(onDone = { focusManager.clearFocus() }), keyboardOptions = KeyboardOptions.Default.copy(imeAction = ImeAction.Done), - modifier = Modifier - .padding(horizontal = 20.dp) - .fillMaxWidth() - .height(92.dp) + modifier = Modifier.padding(horizontal = 20.dp).fillMaxWidth().height(92.dp) .background(Color.White) - .border(1.dp, WalkieColor.GrayDefault, RoundedCornerShape(12.dp)) - .padding(8.dp), + .border(1.dp, WalkieColor.GrayDefault, RoundedCornerShape(12.dp)).padding(8.dp), value = text, onValueChange = { text = it @@ -184,16 +165,12 @@ fun PostingScreen(runningHistory: RunningHistory) { } Box( - modifier = Modifier - .fillMaxSize() - .padding(20.dp), + modifier = Modifier.fillMaxSize().padding(20.dp), contentAlignment = Alignment.BottomCenter, ) { Button( shape = RoundedCornerShape(12.dp), - modifier = Modifier - .fillMaxWidth() - .height(48.dp), + modifier = Modifier.fillMaxWidth().height(48.dp), onClick = { if (photoEditState) { photoEditState = false @@ -213,7 +190,7 @@ fun PostingScreen(runningHistory: RunningHistory) { @Composable fun Map( runningHistory: RunningHistory, - textVisibleState: Boolean, + textVisibleState: TEXTVISIBLESTATE, ) { val runningHistoryUiModel = runningHistory.toRunningHistoryUiModel(LocalContext.current) @@ -261,9 +238,7 @@ fun Map( Box { NaverMap( - modifier = Modifier - .padding(horizontal = 20.dp) - .aspectRatio(1f), + modifier = Modifier.padding(horizontal = 20.dp).aspectRatio(1f), cameraPositionState = cameraPositionState, uiSettings = mapUiSettings, properties = mapProperties, @@ -289,20 +264,19 @@ fun Map( } } - Text( - text = SimpleDateFormat("yyyy.MM.dd HH:mm").format(Date(runningHistory.finishedAt)), - modifier = Modifier.padding(top = 12.dp).align(Alignment.TopCenter), - style = WalkieTypography.Body2, - ) - // 지도 하단 정보 - if (textVisibleState) { + if (textVisibleState != TEXTVISIBLESTATE.HIDE) { + val textColor = if (textVisibleState == TEXTVISIBLESTATE.WHITE) Color.White else Color.Black + + Text( + text = SimpleDateFormat("yyyy.MM.dd HH:mm").format(Date(runningHistory.finishedAt)), + modifier = Modifier.padding(top = 12.dp).align(Alignment.TopCenter), + style = WalkieTypography.Body2.copy(color = textColor), + ) + Row( - modifier = Modifier - .padding(horizontal = 20.dp) - .fillMaxWidth() - .align(Alignment.BottomCenter) - .padding(bottom = 12.dp) + modifier = Modifier.padding(horizontal = 20.dp).fillMaxWidth() + .align(Alignment.BottomCenter).padding(bottom = 12.dp) .padding(horizontal = 20.dp), horizontalArrangement = Arrangement.SpaceBetween, ) { @@ -313,10 +287,14 @@ fun Map( ).forEach { Text( it, - style = WalkieTypography.Title, + style = WalkieTypography.Title.copy(color = textColor), ) } } } } } + +enum class TEXTVISIBLESTATE { + WHITE, BLACK, HIDE +} From 100405d52ee9383a928969b0b1d44cd0e1c72f49 Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Thu, 31 Aug 2023 21:16:37 +0900 Subject: [PATCH 08/12] =?UTF-8?q?:sparkles:=20=EA=B2=B0=EA=B3=BC=20?= =?UTF-8?q?=EC=A4=91=EB=B3=B5=20=EC=A0=80=EC=9E=A5=20=ED=95=B4=EA=B2=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../data/datasource/runninghistory/RunningHistoryDao.kt | 3 ++- .../com/whyranoid/presentation/viewmodel/RunningViewModel.kt | 4 ++++ 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/data/src/main/java/com/whyranoid/data/datasource/runninghistory/RunningHistoryDao.kt b/data/src/main/java/com/whyranoid/data/datasource/runninghistory/RunningHistoryDao.kt index a90b4b41..010210b9 100644 --- a/data/src/main/java/com/whyranoid/data/datasource/runninghistory/RunningHistoryDao.kt +++ b/data/src/main/java/com/whyranoid/data/datasource/runninghistory/RunningHistoryDao.kt @@ -2,12 +2,13 @@ package com.whyranoid.data.datasource.runninghistory import androidx.room.Dao import androidx.room.Insert +import androidx.room.OnConflictStrategy import androidx.room.Query import com.whyranoid.data.model.RunningHistoryEntity @Dao interface RunningHistoryDao { - @Insert + @Insert(onConflict = OnConflictStrategy.REPLACE) fun insert(runningHistoryEntity: RunningHistoryEntity) @Query("SELECT * FROM running_history") diff --git a/presentation/src/main/java/com/whyranoid/presentation/viewmodel/RunningViewModel.kt b/presentation/src/main/java/com/whyranoid/presentation/viewmodel/RunningViewModel.kt index d6717943..ed8d4419 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/viewmodel/RunningViewModel.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/viewmodel/RunningViewModel.kt @@ -53,6 +53,8 @@ class RunningViewModel( private val runningHistoryRepository: RunningHistoryRepository, ) : ViewModel(), ContainerHost { + private var savedHistory: List>? = null + private val runningDataManager = RunningDataManager.getInstance() var startWorker: (() -> Unit)? = null @@ -194,6 +196,8 @@ class RunningViewModel( } fun saveHistory(bitmap: Bitmap, finishData: RunningFinishData) { + if (savedHistory == finishData.runningPositionList) return + savedHistory = finishData.runningPositionList intent { runningHistoryRepository.saveRunningHistory( RunningHistory( From 5ca219b7f1d82257713ae2d4fd418c24cbc7a3e3 Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Thu, 31 Aug 2023 21:52:25 +0900 Subject: [PATCH 09/12] =?UTF-8?q?:sparkles:=20=EB=8B=AC=EB=A6=AC=EA=B8=B0?= =?UTF-8?q?=20=EC=9C=84=EC=B9=98=20=EB=B2=84=EA=B7=B8=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../data/repository/RunningRepositoryImpl.kt | 18 +++++++++++++----- .../presentation/viewmodel/RunningViewModel.kt | 3 --- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/data/src/main/java/com/whyranoid/data/repository/RunningRepositoryImpl.kt b/data/src/main/java/com/whyranoid/data/repository/RunningRepositoryImpl.kt index 168d30e8..ddd5ecf0 100644 --- a/data/src/main/java/com/whyranoid/data/repository/RunningRepositoryImpl.kt +++ b/data/src/main/java/com/whyranoid/data/repository/RunningRepositoryImpl.kt @@ -19,11 +19,13 @@ class RunningRepositoryImpl(context: Context) : RunningRepository { private val fusedLocationClient = LocationServices.getFusedLocationProviderClient(context) private val locationRequest = LocationRequest.Builder(Priority.PRIORITY_HIGH_ACCURACY, 1000L).build() - private lateinit var locationCallback: LocationCallback + private var locationCallback: LocationCallback? = null override val userLocationState: MutableStateFlow = MutableStateFlow(UserLocation.NotTracking) + private var isTrackingUserLocation = true + override suspend fun startRunning() { } @@ -40,13 +42,16 @@ class RunningRepositoryImpl(context: Context) : RunningRepository { } override fun listenLocation() { + isTrackingUserLocation = true if (userLocationState.value is UserLocation.Tracking) return if ((runningDataManager.runningState.value is RunningState.NotRunning).not()) return locationCallback = object : LocationCallback() { override fun onLocationResult(locationResult: LocationResult) { locationResult.lastLocation?.let { location -> - userLocationState.value = - UserLocation.Tracking(location.latitude, location.longitude) + if (isTrackingUserLocation) { + userLocationState.value = + UserLocation.Tracking(location.latitude, location.longitude) + } } ?: run { removeListener() } @@ -55,7 +60,7 @@ class RunningRepositoryImpl(context: Context) : RunningRepository { try { fusedLocationClient.requestLocationUpdates( locationRequest, - locationCallback, + requireNotNull(locationCallback), Looper.getMainLooper(), ) } catch (e: SecurityException) { @@ -66,7 +71,10 @@ class RunningRepositoryImpl(context: Context) : RunningRepository { } override fun removeListener() { - fusedLocationClient.removeLocationUpdates(locationCallback) + isTrackingUserLocation = false + userLocationState.value = UserLocation.NotTracking + fusedLocationClient.removeLocationUpdates(requireNotNull(locationCallback)) + locationCallback = null } override fun removeUserLocation() { diff --git a/presentation/src/main/java/com/whyranoid/presentation/viewmodel/RunningViewModel.kt b/presentation/src/main/java/com/whyranoid/presentation/viewmodel/RunningViewModel.kt index ed8d4419..41657d5c 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/viewmodel/RunningViewModel.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/viewmodel/RunningViewModel.kt @@ -75,9 +75,6 @@ class RunningViewModel( } viewModelScope.launch { runningDataManager.runningState.collect { runningState -> - if (runningState.runningData.lastLocation != null) { - runningRepository.removeUserLocation() - } intent { reduce { val runningInfo = From 5126c28a0ddc6a445a027a161a9fed37a8d2aa1f Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Fri, 1 Sep 2023 14:34:11 +0900 Subject: [PATCH 10/12] =?UTF-8?q?:sparkles:=20enum=20=ED=81=B4=EB=9E=98?= =?UTF-8?q?=EC=8A=A4=20=EB=84=A4=EC=9D=B4=EB=B0=8D=20=EC=BB=A8=EB=B2=A4?= =?UTF-8?q?=EC=85=98=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../screens/mypage/addpost/PostingScreen.kt | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/addpost/PostingScreen.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/addpost/PostingScreen.kt index 07a4f870..07d0a1e2 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/addpost/PostingScreen.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/addpost/PostingScreen.kt @@ -71,7 +71,7 @@ import java.util.* @SuppressLint("SimpleDateFormat") @Composable fun PostingScreen(runningHistory: RunningHistory) { - var textVisibleState by remember { mutableStateOf(TEXTVISIBLESTATE.WHITE) } + var textVisibleState by remember { mutableStateOf(TextVisibleState.WHITE) } var photoEditState by remember { mutableStateOf(false) } Column( @@ -121,9 +121,9 @@ fun PostingScreen(runningHistory: RunningHistory) { Icon( modifier = Modifier.clickable { textVisibleState = when (textVisibleState) { - TEXTVISIBLESTATE.WHITE -> TEXTVISIBLESTATE.BLACK - TEXTVISIBLESTATE.BLACK -> TEXTVISIBLESTATE.HIDE - TEXTVISIBLESTATE.HIDE -> TEXTVISIBLESTATE.WHITE + TextVisibleState.WHITE -> TextVisibleState.BLACK + TextVisibleState.BLACK -> TextVisibleState.HIDE + TextVisibleState.HIDE -> TextVisibleState.WHITE } }.size(48.dp).clip(CircleShape).padding(12.dp), painter = painterResource(id = R.drawable.ic_timer), @@ -190,7 +190,7 @@ fun PostingScreen(runningHistory: RunningHistory) { @Composable fun Map( runningHistory: RunningHistory, - textVisibleState: TEXTVISIBLESTATE, + textVisibleState: TextVisibleState, ) { val runningHistoryUiModel = runningHistory.toRunningHistoryUiModel(LocalContext.current) @@ -265,8 +265,8 @@ fun Map( } // 지도 하단 정보 - if (textVisibleState != TEXTVISIBLESTATE.HIDE) { - val textColor = if (textVisibleState == TEXTVISIBLESTATE.WHITE) Color.White else Color.Black + if (textVisibleState != TextVisibleState.HIDE) { + val textColor = if (textVisibleState == TextVisibleState.WHITE) Color.White else Color.Black Text( text = SimpleDateFormat("yyyy.MM.dd HH:mm").format(Date(runningHistory.finishedAt)), @@ -295,6 +295,6 @@ fun Map( } } -enum class TEXTVISIBLESTATE { +enum class TextVisibleState { WHITE, BLACK, HIDE } From 39971f4b5b0453fc493c3882c14b35812c57bebb Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Fri, 1 Sep 2023 14:35:55 +0900 Subject: [PATCH 11/12] =?UTF-8?q?:sparkles:=20nullable=20string=20?= =?UTF-8?q?=ED=99=95=EC=9E=A5=ED=95=A8=EC=88=98=20=EC=82=AC=EC=9A=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../screens/mypage/editprofile/EditProfileScreen.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt index 21c2403b..5db89c46 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt @@ -50,7 +50,7 @@ fun EditProfileScreen(navController: NavController) { val name = viewModel.name.collectAsStateWithLifecycle(initialValue = "") val nick = viewModel.nick.collectAsStateWithLifecycle(initialValue = "") - EditProfileContent(name = name.value ?: "null", nick = nick.value ?: "null") { + EditProfileContent(name = name.value.orEmpty(), nick = nick.value.orEmpty()) { navController.popBackStack() } } From 79d75c505e381f6d34f744080f28040e1d56d4a6 Mon Sep 17 00:00:00 2001 From: yonghanJu Date: Fri, 1 Sep 2023 16:14:04 +0900 Subject: [PATCH 12/12] =?UTF-8?q?:sparkles:=20String=20=ED=99=95=EC=9E=A5?= =?UTF-8?q?=20=ED=94=84=EB=A1=9C=ED=8D=BC=ED=8B=B0=20=EC=82=AC=EC=9A=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- domain/src/main/java/com/whyranoid/domain/util/Extensions.kt | 3 +++ .../screens/mypage/editprofile/EditProfileScreen.kt | 5 +++-- 2 files changed, 6 insertions(+), 2 deletions(-) create mode 100644 domain/src/main/java/com/whyranoid/domain/util/Extensions.kt diff --git a/domain/src/main/java/com/whyranoid/domain/util/Extensions.kt b/domain/src/main/java/com/whyranoid/domain/util/Extensions.kt new file mode 100644 index 00000000..f3e388cd --- /dev/null +++ b/domain/src/main/java/com/whyranoid/domain/util/Extensions.kt @@ -0,0 +1,3 @@ +package com.whyranoid.domain.util + +val String.Companion.EMPTY: String get() = "" diff --git a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt index 5db89c46..62f3ee85 100644 --- a/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt +++ b/presentation/src/main/java/com/whyranoid/presentation/screens/mypage/editprofile/EditProfileScreen.kt @@ -39,6 +39,7 @@ import androidx.compose.ui.unit.Dp import androidx.compose.ui.unit.dp import androidx.lifecycle.compose.collectAsStateWithLifecycle import androidx.navigation.NavController +import com.whyranoid.domain.util.EMPTY import com.whyranoid.presentation.reusable.CheckableCustomTextField import com.whyranoid.presentation.theme.WalkieColor import com.whyranoid.presentation.theme.WalkieTypography @@ -47,8 +48,8 @@ import org.koin.androidx.compose.koinViewModel @Composable fun EditProfileScreen(navController: NavController) { val viewModel = koinViewModel() - val name = viewModel.name.collectAsStateWithLifecycle(initialValue = "") - val nick = viewModel.nick.collectAsStateWithLifecycle(initialValue = "") + val name = viewModel.name.collectAsStateWithLifecycle(initialValue = String.EMPTY) + val nick = viewModel.nick.collectAsStateWithLifecycle(initialValue = String.EMPTY) EditProfileContent(name = name.value.orEmpty(), nick = nick.value.orEmpty()) { navController.popBackStack()