diff --git a/app/src/main/java/com/cherrish/android/presentation/challenge/loading/ChallengeLoadingScreen.kt b/app/src/main/java/com/cherrish/android/presentation/challenge/loading/ChallengeLoadingScreen.kt index 0f9ab4ed..742e91bd 100644 --- a/app/src/main/java/com/cherrish/android/presentation/challenge/loading/ChallengeLoadingScreen.kt +++ b/app/src/main/java/com/cherrish/android/presentation/challenge/loading/ChallengeLoadingScreen.kt @@ -1,29 +1,34 @@ package com.cherrish.android.presentation.challenge.loading -import androidx.compose.foundation.Image import androidx.compose.foundation.background import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.PaddingValues import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.Spacer +import androidx.compose.foundation.layout.aspectRatio import androidx.compose.foundation.layout.fillMaxSize +import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.navigationBarsPadding import androidx.compose.foundation.layout.padding -import androidx.compose.foundation.layout.size 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.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.graphics.vector.ImageVector -import androidx.compose.ui.res.painterResource import androidx.compose.ui.res.vectorResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import androidx.hilt.navigation.compose.hiltViewModel +import com.airbnb.lottie.compose.LottieAnimation +import com.airbnb.lottie.compose.LottieCompositionSpec +import com.airbnb.lottie.compose.LottieConstants +import com.airbnb.lottie.compose.animateLottieCompositionAsState +import com.airbnb.lottie.compose.rememberLottieComposition import com.cherrish.android.R import com.cherrish.android.core.common.extension.collectLatestSideEffect import com.cherrish.android.core.common.extension.noRippleClickable @@ -61,6 +66,14 @@ private fun ChallengeLoadingScreen( onClick: () -> Unit, modifier: Modifier = Modifier ) { + val composition by rememberLottieComposition( + LottieCompositionSpec.RawRes(R.raw.lt_challenge_loading) + ) + val progress by animateLottieCompositionAsState( + composition, + iterations = LottieConstants.IterateForever, + isPlaying = true + ) Column( modifier = modifier .fillMaxSize() @@ -106,12 +119,17 @@ private fun ChallengeLoadingScreen( style = CherrishTheme.typography.title1SB18 ) - Spacer(modifier = Modifier.height(60.dp)) + Spacer(modifier = Modifier.height(80.dp)) - Image( - painter = painterResource(id = R.drawable.img_challenge_loading), - contentDescription = null, - modifier = Modifier.size(150.dp) + LottieAnimation( + composition = composition, + progress = { progress }, + modifier = Modifier + .fillMaxWidth() + .padding(horizontal = 105.dp) + .aspectRatio(130f / 154f) + .align(Alignment.CenterHorizontally) + .noRippleClickable(onClick = onClick) ) Spacer(modifier = Modifier.height(80.dp)) diff --git a/app/src/main/java/com/cherrish/android/presentation/mypage/MyPageScreen.kt b/app/src/main/java/com/cherrish/android/presentation/mypage/MyPageScreen.kt index 9393cb07..fe9cfa60 100644 --- a/app/src/main/java/com/cherrish/android/presentation/mypage/MyPageScreen.kt +++ b/app/src/main/java/com/cherrish/android/presentation/mypage/MyPageScreen.kt @@ -72,7 +72,7 @@ private fun MyPageScreen( ) HorizontalDivider( - color = CherrishTheme.colors.gray100, + color = CherrishTheme.colors.gray200, thickness = 10.dp ) @@ -94,7 +94,7 @@ private fun MyPageScreen( Spacer(Modifier.weight(weight = 120f)) HorizontalDivider( - color = CherrishTheme.colors.gray100, + color = CherrishTheme.colors.gray200, thickness = 10.dp ) } diff --git a/app/src/main/java/com/cherrish/android/presentation/splash/SplashScreen.kt b/app/src/main/java/com/cherrish/android/presentation/splash/SplashScreen.kt index d70ccd08..52762218 100644 --- a/app/src/main/java/com/cherrish/android/presentation/splash/SplashScreen.kt +++ b/app/src/main/java/com/cherrish/android/presentation/splash/SplashScreen.kt @@ -1,30 +1,36 @@ package com.cherrish.android.presentation.splash -import androidx.compose.foundation.Image import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.PaddingValues import androidx.compose.foundation.layout.Spacer +import androidx.compose.foundation.layout.aspectRatio import androidx.compose.foundation.layout.fillMaxSize +import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding -import androidx.compose.foundation.layout.size import androidx.compose.runtime.Composable -import androidx.compose.runtime.LaunchedEffect +import androidx.compose.runtime.getValue +import androidx.compose.runtime.rememberCoroutineScope import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.draw.drawBehind import androidx.compose.ui.geometry.Offset import androidx.compose.ui.graphics.Brush -import androidx.compose.ui.graphics.vector.ImageVector -import androidx.compose.ui.res.painterResource -import androidx.compose.ui.res.vectorResource import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import androidx.hilt.navigation.compose.hiltViewModel +import androidx.lifecycle.Lifecycle +import androidx.lifecycle.compose.LifecycleEventEffect +import com.airbnb.lottie.compose.LottieAnimation +import com.airbnb.lottie.compose.LottieCompositionSpec +import com.airbnb.lottie.compose.LottieConstants +import com.airbnb.lottie.compose.animateLottieCompositionAsState +import com.airbnb.lottie.compose.rememberLottieComposition import com.cherrish.android.R import com.cherrish.android.core.common.extension.collectLatestSideEffect import com.cherrish.android.core.designsystem.theme.CherrishTheme import kotlinx.coroutines.delay +import kotlinx.coroutines.launch @Composable fun SplashRoute( @@ -33,20 +39,19 @@ fun SplashRoute( paddingValues: PaddingValues, viewModel: SplashViewModel = hiltViewModel() ) { - LaunchedEffect(Unit) { - viewModel.isAutoLoginCheck() + val scope = rememberCoroutineScope() + + LifecycleEventEffect(Lifecycle.Event.ON_START) { + scope.launch { + delay(3000) + viewModel.isAutoLoginCheck() + } } viewModel.sideEffect.collectLatestSideEffect { sideEffect -> - delay(3000) - when (sideEffect) { - SplashSideEffect.NavigateToOnboarding -> { - navigateToOnboarding() - } - SplashSideEffect.NavigateToHome -> { - navigateToHome() - } + SplashSideEffect.NavigateToOnboarding -> navigateToOnboarding() + SplashSideEffect.NavigateToHome -> navigateToHome() } } @@ -60,6 +65,15 @@ private fun SplashScreen( paddingValues: PaddingValues, modifier: Modifier = Modifier ) { + val composition by rememberLottieComposition( + LottieCompositionSpec.RawRes(R.raw.lt_challenge_loading) + ) + val progress by animateLottieCompositionAsState( + composition, + iterations = LottieConstants.IterateForever, + isPlaying = true + ) + val gradationColors = listOf(CherrishTheme.colors.gradation, CherrishTheme.colors.gradation2) Column( @@ -77,19 +91,18 @@ private fun SplashScreen( ) { Spacer(modifier = Modifier.weight(283f)) - Image( - painter = painterResource(id = R.drawable.ic_app_logo), - contentDescription = null, - modifier = Modifier.size(width = 114.dp, height = 100.dp) + LottieAnimation( + composition = composition, + progress = { progress }, + modifier = Modifier + .fillMaxWidth() + .padding(horizontal = 105.dp) + .aspectRatio(130f / 154f) + .align(Alignment.CenterHorizontally) ) Spacer(modifier = Modifier.height(14.dp)) - Image( - imageVector = ImageVector.vectorResource(id = R.drawable.ic_app_logo_title), - contentDescription = null - ) - Spacer(modifier = Modifier.weight(298f)) } } diff --git a/app/src/main/res/raw/lt_challenge_loading.json b/app/src/main/res/raw/lt_challenge_loading.json new file mode 100644 index 00000000..f481d639 --- /dev/null +++ b/app/src/main/res/raw/lt_challenge_loading.json @@ -0,0 +1,1085 @@ +{ + "nm": "Comp 1", + "ddd": 0, + "h": 154, + "w": 130, + "meta": { + "g": "@lottiefiles/toolkit-js 0.68.0", + "tc": "#0040ff" + }, + "layers": [ + { + "ty": 0, + "nm": "view_splash_logo_2", + "sr": 1, + "st": 0, + "op": 120, + "ip": 0, + "ln": "358", + "hasMask": false, + "ao": 0, + "ks": { + "a": { + "a": 0, + "k": [ + 181, + 181 + ] + }, + "s": { + "a": 0, + "k": [ + 45, + 45, + 97.826 + ] + }, + "p": { + "a": 0, + "k": [ + 65, + 56, + 0 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 0, + "k": 100 + } + }, + "w": 362, + "h": 362, + "refId": "1", + "ind": 1 + }, + { + "ty": 0, + "nm": "view_splash_logo", + "sr": 1, + "st": 0, + "op": 120, + "ip": 0, + "ln": "37", + "hasMask": false, + "ao": 0, + "ks": { + "a": { + "a": 0, + "k": [ + 187.5, + 406 + ] + }, + "s": { + "a": 0, + "k": [ + 100, + 100 + ] + }, + "p": { + "a": 0, + "k": [ + 65, + 97, + 0 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 0, + "k": 100 + } + }, + "w": 375, + "h": 812, + "refId": "7", + "ind": 2 + } + ], + "v": "5.7.0", + "fr": 29.97, + "op": 90.55451612903225, + "ip": 0, + "assets": [ + { + "nm": "view_splash_logo_2", + "id": "1", + "fr": 29.97, + "layers": [ + { + "ty": 4, + "nm": "Shape Layer 1", + "sr": 1, + "st": 23, + "op": 143, + "ip": 23, + "ln": "594", + "hasMask": false, + "ao": 0, + "ks": { + "a": { + "a": 0, + "k": [ + 48.187, + -83.45, + 0 + ] + }, + "s": { + "a": 0, + "k": [ + 100, + 100 + ] + }, + "p": { + "a": 0, + "k": [ + 289, + 89, + 0 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 0, + "k": 100 + } + }, + "shapes": [ + { + "ty": "gr", + "nm": "Ellipse 1", + "it": [ + { + "ty": "el", + "nm": "Ellipse Path 1", + "d": 1, + "p": { + "a": 0, + "k": [ + 0, + 0 + ] + }, + "s": { + "a": 0, + "k": [ + 34, + 34 + ] + } + }, + { + "ty": "tm", + "nm": "Trim Paths 1", + "e": { + "a": 1, + "k": [ + { + "o": { + "x": 0.774, + "y": 0 + }, + "i": { + "x": 0.548, + "y": 1 + }, + "s": [ + 0 + ], + "t": 23 + }, + { + "s": [ + 100 + ], + "t": 32 + } + ] + }, + "o": { + "a": 0, + "k": 0 + }, + "s": { + "a": 0, + "k": 0 + }, + "m": 2 + }, + { + "ty": "st", + "nm": "Stroke 1", + "lc": 1, + "lj": 1, + "ml": 4, + "o": { + "a": 0, + "k": 100 + }, + "w": { + "a": 0, + "k": 6 + }, + "c": { + "a": 0, + "k": [ + 1, + 0.5255, + 0.6314 + ] + } + }, + { + "ty": "fl", + "nm": "Fill 1", + "c": { + "a": 0, + "k": [ + 0, + 0.251, + 1 + ] + }, + "r": 1, + "o": { + "a": 0, + "k": 0 + } + }, + { + "ty": "tr", + "a": { + "a": 0, + "k": [ + 0, + 0 + ] + }, + "s": { + "a": 0, + "k": [ + 94.681, + 94.681 + ] + }, + "p": { + "a": 0, + "k": [ + 48.187, + -83.45 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 0, + "k": 100 + } + } + ] + } + ], + "ind": 1 + }, + { + "ty": 2, + "nm": "Layer 4", + "sr": 1, + "st": 0, + "op": 120, + "ip": 0, + "ln": "355", + "hasMask": false, + "ao": 0, + "ks": { + "a": { + "a": 0, + "k": [ + 19.266, + 19.266 + ] + }, + "s": { + "a": 0, + "k": [ + 100, + 100 + ] + }, + "p": { + "a": 0, + "k": [ + 287.839, + 89.118, + 0 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 1, + "k": [ + { + "o": { + "x": 0.6, + "y": 0 + }, + "i": { + "x": 0.781, + "y": 1 + }, + "s": [ + 0 + ], + "t": 34 + }, + { + "s": [ + 100 + ], + "t": 53.999 + } + ] + } + }, + "refId": "3", + "ind": 2 + }, + { + "ty": 2, + "nm": "Layer 3", + "sr": 1, + "st": 28, + "op": 127, + "ip": 7, + "ln": "353", + "hasMask": true, + "ao": 0, + "ks": { + "a": { + "a": 0, + "k": [ + 52.894, + 71.071 + ] + }, + "s": { + "a": 1, + "k": [ + { + "s": [ + 100, + 100, + 100 + ], + "i": { + "x": [ + 0.4, + 0.4, + 0.4 + ], + "y": [ + 1, + 1, + 1 + ] + }, + "o": { + "x": [ + 0.641, + 0.641, + 0.6 + ], + "y": [ + 0, + 0, + 0 + ] + }, + "t": 9 + }, + { + "s": [ + 110, + 110, + 100 + ], + "i": { + "x": [ + 0.41, + 0.41, + 0.4 + ], + "y": [ + 1, + 1, + 1 + ] + }, + "o": { + "x": [ + 0.6, + 0.6, + 0.6 + ], + "y": [ + 0, + 0, + 0 + ] + }, + "t": 13 + }, + { + "s": [ + 100, + 100, + 100 + ], + "i": { + "x": [ + 1, + 1, + 1 + ], + "y": [ + 1, + 1, + 1 + ] + }, + "o": { + "x": [ + 0, + 0, + 0 + ], + "y": [ + 0, + 0, + 0 + ] + }, + "t": 17 + } + ] + }, + "p": { + "a": 0, + "k": [ + 236.768, + 190.224, + 0 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 0, + "k": 100 + } + }, + "masksProperties": [ + { + "nm": "Mask 1", + "inv": false, + "mode": "a", + "x": { + "a": 0, + "k": 0 + }, + "o": { + "a": 0, + "k": 100 + }, + "pt": { + "a": 1, + "k": [ + { + "o": { + "x": 0.755, + "y": 0 + }, + "i": { + "x": 0.833, + "y": 1 + }, + "s": [ + { + "c": true, + "i": [ + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ] + ], + "o": [ + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ] + ], + "v": [ + [ + 17.596, + 55.484 + ], + [ + 10.494, + 50.193 + ], + [ + -19.08, + 91.949 + ], + [ + -11.554, + 96.668 + ] + ] + } + ], + "t": 7 + }, + { + "o": { + "x": 0.167, + "y": 0.001 + }, + "i": { + "x": 0.141, + "y": 1 + }, + "s": [ + { + "c": true, + "i": [ + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ] + ], + "o": [ + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ] + ], + "v": [ + [ + 99.322, + 117.403 + ], + [ + 10.494, + 50.193 + ], + [ + -19.08, + 91.949 + ], + [ + 72.398, + 156.585 + ] + ] + } + ], + "t": 14 + }, + { + "s": [ + { + "c": true, + "i": [ + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ] + ], + "o": [ + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ], + [ + 0, + 0 + ] + ], + "v": [ + [ + 153.7, + 34.606 + ], + [ + 65.402, + -27.027 + ], + [ + -19.08, + 91.949 + ], + [ + 72.398, + 156.585 + ] + ] + } + ], + "t": 23 + } + ] + } + } + ], + "refId": "4", + "ind": 3 + }, + { + "ty": 2, + "nm": "Layer 2", + "sr": 1, + "st": 0, + "op": 120, + "ip": 0, + "ln": "351", + "hasMask": false, + "ao": 0, + "ks": { + "a": { + "a": 0, + "k": [ + 84.5, + 195 + ] + }, + "s": { + "a": 1, + "k": [ + { + "s": [ + 30, + 30, + 100 + ], + "i": { + "x": [ + 0.516, + 0.516, + 0.4 + ], + "y": [ + 1, + 1, + 1 + ] + }, + "o": { + "x": [ + 0.745, + 0.745, + 0.6 + ], + "y": [ + 0, + 0, + 0 + ] + }, + "t": 0 + }, + { + "s": [ + 115, + 115, + 100 + ], + "i": { + "x": [ + 0, + 0, + 0.833 + ], + "y": [ + 1, + 1, + 1 + ] + }, + "o": { + "x": [ + 1, + 1, + 0.6 + ], + "y": [ + 0, + 0, + 0 + ] + }, + "t": 6 + }, + { + "s": [ + 100, + 100, + 100 + ], + "i": { + "x": [ + 1, + 1, + 1 + ], + "y": [ + 1, + 1, + 1 + ] + }, + "o": { + "x": [ + 0.167, + 0.167, + 0.167 + ], + "y": [ + 0, + 0, + 0 + ] + }, + "t": 11 + } + ] + }, + "p": { + "a": 0, + "k": [ + 139.252, + 291.115, + 0 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 1, + "k": [ + { + "o": { + "x": 0.6, + "y": 0 + }, + "i": { + "x": 0.4, + "y": 1 + }, + "s": [ + 0 + ], + "t": 0 + }, + { + "s": [ + 100 + ], + "t": 1 + } + ] + } + }, + "refId": "5", + "ind": 4 + } + ] + }, + { + "id": "3", + "e": 1, + "w": 39, + "h": 39, + "p": "", + "u": "" + }, + { + "id": "4", + "e": 1, + "w": 106, + "h": 143, + "p": "", + "u": "" + }, + { + "id": "5", + "e": 1, + "w": 169, + "h": 195, + "p": "", + "u": "" + }, + { + "nm": "view_splash_logo", + "id": "7", + "fr": 29.97, + "layers": [ + { + "ty": 0, + "nm": "splash_logotype", + "sr": 1, + "st": 0, + "op": 120, + "ip": 0, + "ln": "61", + "hasMask": false, + "ao": 0, + "ks": { + "a": { + "a": 0, + "k": [ + 300, + 100 + ] + }, + "s": { + "a": 0, + "k": [ + 21, + 21, + 105 + ] + }, + "p": { + "a": 0, + "k": [ + 187, + 448, + 0 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 1, + "k": [ + { + "o": { + "x": 0.6, + "y": 0 + }, + "i": { + "x": 0.67, + "y": 1 + }, + "s": [ + 0 + ], + "t": 37 + }, + { + "s": [ + 100 + ], + "t": 56.999 + } + ] + } + }, + "w": 600, + "h": 200, + "refId": "8", + "ind": 1 + } + ] + }, + { + "nm": "splash_logotype", + "id": "8", + "fr": 29.97, + "layers": [ + { + "ty": 2, + "nm": "Layer 1", + "sr": 1, + "st": 0, + "op": 120, + "ip": 0, + "ln": "60", + "hasMask": false, + "ao": 0, + "ks": { + "a": { + "a": 0, + "k": [ + 232.534, + 48.209 + ] + }, + "s": { + "a": 0, + "k": [ + 100, + 100 + ] + }, + "p": { + "a": 0, + "k": [ + 300, + 100.154, + 0 + ] + }, + "r": { + "a": 0, + "k": 0 + }, + "sa": { + "a": 0, + "k": 0 + }, + "o": { + "a": 0, + "k": 100 + } + }, + "refId": "9", + "ind": 1 + } + ] + }, + { + "id": "9", + "e": 1, + "w": 466, + "h": 97, + "p": "", + "u": "" + } + ] +}