From 87fc79f84b19a287709cf45e0fbf66fcaae5ccd5 Mon Sep 17 00:00:00 2001 From: ddyeon Date: Mon, 23 Sep 2024 00:17:32 +0900 Subject: [PATCH 1/3] =?UTF-8?q?[feat]=20splashactivity=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 --- .../java/com/mashup/dorabangs/MainActivity.kt | 24 +++++----- .../mashup/dorabangs/splash/SplashActivity.kt | 48 +++++++++++++++++++ .../mashup/dorabangs/splash/SplashScreen.kt | 19 ++++++++ .../designsystem/src/main/res/raw/splash.json | 1 + 4 files changed, 80 insertions(+), 12 deletions(-) create mode 100644 app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt create mode 100644 app/src/main/java/com/mashup/dorabangs/splash/SplashScreen.kt create mode 100644 core/designsystem/src/main/res/raw/splash.json diff --git a/app/src/main/java/com/mashup/dorabangs/MainActivity.kt b/app/src/main/java/com/mashup/dorabangs/MainActivity.kt index 3a24ef17..ae426c05 100644 --- a/app/src/main/java/com/mashup/dorabangs/MainActivity.kt +++ b/app/src/main/java/com/mashup/dorabangs/MainActivity.kt @@ -35,18 +35,18 @@ class MainActivity : ComponentActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) checkPermission() - - val userId = Settings.Secure.getString(contentResolver, Settings.Secure.ANDROID_ID) - splashViewModel.checkUserToken(userId) - - val url = intent.data?.path?.substring(1).orEmpty() - - installSplashScreen().apply { - setKeepOnScreenCondition { - (splashViewModel.isSplashShow.value || splashViewModel.firstEntryScreen.value == FirstEntryScreen.Splash) && - url.isBlank() - } - } +// +// val userId = Settings.Secure.getString(contentResolver, Settings.Secure.ANDROID_ID) +// splashViewModel.checkUserToken(userId) +// +// val url = intent.data?.path?.substring(1).orEmpty() +// +// installSplashScreen().apply { +// setKeepOnScreenCondition { +// (splashViewModel.isSplashShow.value || splashViewModel.firstEntryScreen.value == FirstEntryScreen.Splash) && +// url.isBlank() +// } +// } setContent { val firstEntryScreen = splashViewModel.firstEntryScreen.collectAsState() diff --git a/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt b/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt new file mode 100644 index 00000000..a9baa561 --- /dev/null +++ b/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt @@ -0,0 +1,48 @@ +package com.mashup.dorabangs.splash + +import android.annotation.SuppressLint +import android.content.Intent +import android.os.Bundle +import android.provider.Settings +import androidx.activity.ComponentActivity +import androidx.activity.compose.setContent +import androidx.activity.viewModels +import androidx.compose.runtime.LaunchedEffect +import androidx.compose.runtime.collectAsState +import androidx.compose.runtime.getValue +import androidx.core.splashscreen.SplashScreen.Companion.installSplashScreen +import com.mashup.dorabangs.MainActivity +import dagger.hilt.android.AndroidEntryPoint + +@AndroidEntryPoint +class SplashActivity: ComponentActivity() { + private val splashViewModel: SplashViewModel by viewModels() + + @SuppressLint("HardwareIds") + override fun onCreate(savedInstanceState: Bundle?) { + + super.onCreate(savedInstanceState) + val userId = Settings.Secure.getString(contentResolver, Settings.Secure.ANDROID_ID) + splashViewModel.checkUserToken(userId) + + val url = intent.data?.path?.substring(1).orEmpty() + + installSplashScreen().apply { + setKeepOnScreenCondition { + (splashViewModel.isSplashShow.value || splashViewModel.firstEntryScreen.value == FirstEntryScreen.Splash) && + url.isBlank() + } + } + + setContent { + val splashShowState by splashViewModel.isSplashShow.collectAsState() + +// if(!splashShowState) { +// val intent = Intent(this, MainActivity::class.java) +// startActivity(intent) +// } + + SplashScreen() + } + } +} \ No newline at end of file diff --git a/app/src/main/java/com/mashup/dorabangs/splash/SplashScreen.kt b/app/src/main/java/com/mashup/dorabangs/splash/SplashScreen.kt new file mode 100644 index 00000000..08f436eb --- /dev/null +++ b/app/src/main/java/com/mashup/dorabangs/splash/SplashScreen.kt @@ -0,0 +1,19 @@ +package com.mashup.dorabangs.splash + +import androidx.compose.foundation.layout.Box +import androidx.compose.foundation.layout.fillMaxSize +import androidx.compose.runtime.Composable +import androidx.compose.ui.Alignment +import androidx.compose.ui.Modifier +import com.mashup.dorabangs.core.designsystem.R as coreR +import com.mashup.dorabangs.core.designsystem.component.util.LottieLoader + +@Composable +fun SplashScreen() { + Box(modifier = Modifier.fillMaxSize()) { + LottieLoader( + lottieRes = coreR.raw.splash, + modifier = Modifier.align(Alignment.Center) + ) + } +} diff --git a/core/designsystem/src/main/res/raw/splash.json b/core/designsystem/src/main/res/raw/splash.json new file mode 100644 index 00000000..8e55a73f --- /dev/null +++ b/core/designsystem/src/main/res/raw/splash.json @@ -0,0 +1 @@ +{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.5.7","a":"","k":"","d":"","tc":"#FFFFFF"},"fr":30,"ip":0,"op":30,"w":400,"h":400,"nm":"Splash _","ddd":0,"assets":[{"id":"image_0","w":780,"h":780,"u":"","p":"","e":1},{"id":"image_1","w":780,"h":780,"u":"","p":"","e":1},{"id":"image_2","w":780,"h":780,"u":"","p":"","e":1},{"id":"image_3","w":489,"h":573,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":4,"nm":"Shape Layer 2","td":1,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[200,200,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":0,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[220,-336],[-120,-336],[-124,-304],[216,-304]],"c":true}]},{"t":10,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[230,-336],[-110,-336],[-77,120],[41,167]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.822671987496,0.822671987496,0.822671987496,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[1,1,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[3.938,15.414],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":2,"nm":"1","tt":1,"refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[200,200,0],"ix":2},"a":{"a":0,"k":[390,390,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":4,"nm":"Shape Layer 1","td":1,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[200,200,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":9,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-56.625,130.312],[31.125,164.375],[100,189.5],[129.5,147.5],[100.682,140.813],[39,126.5]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":10.091,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-57.125,133.812],[30.625,167.875],[99.5,193],[129,151],[100.182,144.313],[38.5,130]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":11.182,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-57.625,134.312],[-35.875,173.25],[5.5,249],[65,266],[58.95,227.47],[46,145]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":12.272,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-58.125,134.812],[-115.375,184.875],[-72,283],[1,381],[17.718,310.626],[53.5,160]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":14.455,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-58.125,134.812],[-160.375,183.875],[-254,260],[-78,382],[-13.199,315.447],[125.5,173]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":15.545,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-58.125,134.812],[-153.375,148.875],[-367,139],[-207,376],[-101.121,311.358],[125.5,173]],"c":true}]},{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":18.272,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-58.125,134.812],[-153.375,148.875],[-203,-1],[-396,222],[-103.982,370.33],[180.5,191]],"c":true}]},{"t":21,"s":[{"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"v":[[-58.125,134.813],[-47.375,124.875],[30,-88],[-412,124],[-103.982,370.33],[180.5,191]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"fl","c":{"a":0,"k":[1,1,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":2,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":4,"ty":2,"nm":"2","tt":1,"refId":"image_1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[200,200,0],"ix":2},"a":{"a":0,"k":[390,390,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":5,"ty":4,"nm":"Shape Layer 3","td":1,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[200,200,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":1,"k":[{"i":{"x":0.833,"y":0.833},"o":{"x":0.167,"y":0.167},"t":21,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[26,50],[-2,148],[25,163],[62,64]],"c":true}]},{"i":{"x":0.833,"y":0.75},"o":{"x":0.167,"y":0.167},"t":24.333,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[26,50],[-2,148],[108,222],[153,95]],"c":true}]},{"t":27,"s":[{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[26,50],[-10,181],[285,263],[269,99]],"c":true}]}],"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.822671987496,0.822671987496,0.822671987496,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[1,1,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":6,"ty":2,"nm":"3","tt":1,"refId":"image_2","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[200,200,0],"ix":2},"a":{"a":0,"k":[390,390,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":7,"ty":4,"nm":"Shape Layer 5","td":1,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[200,200,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-30.25,59],[-61.75,132.125],[-54.375,134.625],[-27.25,61.25]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.822671987496,0.822671987496,0.822671987496,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[1,1,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":20,"s":[0]},{"t":21,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":8,"ty":2,"nm":"Layer 4/bg.ai","cl":"ai","tt":1,"refId":"image_3","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[184,200,0],"ix":2},"a":{"a":0,"k":[244.5,286.5,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":9,"ty":4,"nm":"Shape Layer 4","td":1,"sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[200,200,0],"ix":2},"a":{"a":0,"k":[0,0,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"shapes":[{"ty":"gr","it":[{"ind":0,"ty":"sh","ix":1,"ks":{"a":0,"k":{"i":[[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0]],"v":[[-55.75,131.75],[-58,137],[24.25,169.25],[26.5,163]],"c":true},"ix":2},"nm":"Path 1","mn":"ADBE Vector Shape - Group","hd":false},{"ty":"st","c":{"a":0,"k":[0.822671987496,0.822671987496,0.822671987496,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":2,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"fl","c":{"a":0,"k":[1,1,1,1],"ix":4},"o":{"a":0,"k":100,"ix":5},"r":1,"bm":0,"nm":"Fill 1","mn":"ADBE Vector Graphic - Fill","hd":false},{"ty":"tr","p":{"a":0,"k":[0,0],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":10,"s":[0]},{"t":11,"s":[100]}],"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Shape 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":30,"st":0,"bm":0},{"ddd":0,"ind":10,"ty":2,"nm":"Layer 4/bg.ai","cl":"ai","tt":1,"refId":"image_3","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[184,200,0],"ix":2},"a":{"a":0,"k":[244.5,286.5,0],"ix":1},"s":{"a":0,"k":[55.897,55.897,100],"ix":6}},"ao":0,"ip":0,"op":30,"st":0,"bm":0}],"markers":[]} \ No newline at end of file From a9e17312af29b1ae06b1ba47548fccb36def373d Mon Sep 17 00:00:00 2001 From: ddyeon Date: Mon, 23 Sep 2024 23:15:24 +0900 Subject: [PATCH 2/3] =?UTF-8?q?[feat]=20=EC=8A=A4=ED=94=8C=EB=9E=98?= =?UTF-8?q?=EC=8B=9C=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 --- app/build.gradle.kts | 1 - app/src/main/AndroidManifest.xml | 7 ++- .../java/com/mashup/dorabangs/MainActivity.kt | 45 +++++++------------ .../mashup/dorabangs/splash/SplashActivity.kt | 33 +++++--------- .../mashup/dorabangs/splash/SplashScreen.kt | 6 ++- .../dorabangs/splash/SplashViewModel.kt | 17 ++++--- .../dorabangs/feature/home/HomeContract.kt | 2 +- 7 files changed, 47 insertions(+), 64 deletions(-) diff --git a/app/build.gradle.kts b/app/build.gradle.kts index 4d5dd596..077c0c7b 100644 --- a/app/build.gradle.kts +++ b/app/build.gradle.kts @@ -84,7 +84,6 @@ dependencies { implementation(libs.core.ktx) implementation(libs.kotlin.android) implementation(libs.kotlin.core) - implementation(libs.androidx.splash) testImplementation(libs.junit) androidTestImplementation(libs.androidx.test.ext.junit) androidTestImplementation(libs.espresso.core) diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 1d051e9f..b79dcede 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -19,12 +19,17 @@ tools:targetApi="31"> + + + diff --git a/app/src/main/java/com/mashup/dorabangs/MainActivity.kt b/app/src/main/java/com/mashup/dorabangs/MainActivity.kt index ae426c05..e45d707f 100644 --- a/app/src/main/java/com/mashup/dorabangs/MainActivity.kt +++ b/app/src/main/java/com/mashup/dorabangs/MainActivity.kt @@ -11,19 +11,14 @@ import android.widget.Toast import androidx.activity.ComponentActivity import androidx.activity.compose.setContent import androidx.activity.result.contract.ActivityResultContracts -import androidx.activity.viewModels -import androidx.compose.runtime.collectAsState -import androidx.core.splashscreen.SplashScreen.Companion.installSplashScreen import com.mashup.dorabangs.core.designsystem.theme.DorabangsTheme import com.mashup.dorabangs.navigation.DoraApp import com.mashup.dorabangs.splash.FirstEntryScreen -import com.mashup.dorabangs.splash.SplashViewModel import dagger.hilt.android.AndroidEntryPoint @AndroidEntryPoint class MainActivity : ComponentActivity() { - private val splashViewModel: SplashViewModel by viewModels() private val overlayPermissionLauncher = registerForActivityResult(ActivityResultContracts.StartActivityForResult()) { if (!Settings.canDrawOverlays(this)) { @@ -35,33 +30,25 @@ class MainActivity : ComponentActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) checkPermission() -// -// val userId = Settings.Secure.getString(contentResolver, Settings.Secure.ANDROID_ID) -// splashViewModel.checkUserToken(userId) -// -// val url = intent.data?.path?.substring(1).orEmpty() -// -// installSplashScreen().apply { -// setKeepOnScreenCondition { -// (splashViewModel.isSplashShow.value || splashViewModel.firstEntryScreen.value == FirstEntryScreen.Splash) && -// url.isBlank() -// } -// } + + val firstEntryScreen = intent.getStringExtra("firstEntry") + val url = intent.data?.path?.substring(1).orEmpty() setContent { - val firstEntryScreen = splashViewModel.firstEntryScreen.collectAsState() - if (firstEntryScreen.value != FirstEntryScreen.Splash) { - val imm = getSystemService(Context.INPUT_METHOD_SERVICE) as? InputMethodManager + firstEntryScreen?.let { + if (firstEntryScreen != FirstEntryScreen.Splash.name) { + val imm = getSystemService(Context.INPUT_METHOD_SERVICE) as? InputMethodManager - DorabangsTheme { - DoraApp( - isFirstEntry = firstEntryScreen.value == FirstEntryScreen.Onboarding, - hideKeyboardAction = { - currentFocus?.let { - imm?.hideSoftInputFromWindow(it.windowToken, 0) - } - }, - ) + DorabangsTheme { + DoraApp( + isFirstEntry = firstEntryScreen == FirstEntryScreen.Onboarding.name, + hideKeyboardAction = { + currentFocus?.let { + imm?.hideSoftInputFromWindow(it.windowToken, 0) + } + }, + ) + } } } } diff --git a/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt b/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt index a9baa561..4cfeec71 100644 --- a/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt +++ b/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt @@ -7,42 +7,33 @@ import android.provider.Settings import androidx.activity.ComponentActivity import androidx.activity.compose.setContent import androidx.activity.viewModels -import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.collectAsState -import androidx.compose.runtime.getValue -import androidx.core.splashscreen.SplashScreen.Companion.installSplashScreen import com.mashup.dorabangs.MainActivity import dagger.hilt.android.AndroidEntryPoint +@SuppressLint("CustomSplashScreen") @AndroidEntryPoint -class SplashActivity: ComponentActivity() { +class SplashActivity : ComponentActivity() { private val splashViewModel: SplashViewModel by viewModels() - @SuppressLint("HardwareIds") override fun onCreate(savedInstanceState: Bundle?) { - super.onCreate(savedInstanceState) + val userId = Settings.Secure.getString(contentResolver, Settings.Secure.ANDROID_ID) splashViewModel.checkUserToken(userId) val url = intent.data?.path?.substring(1).orEmpty() - installSplashScreen().apply { - setKeepOnScreenCondition { - (splashViewModel.isSplashShow.value || splashViewModel.firstEntryScreen.value == FirstEntryScreen.Splash) && - url.isBlank() - } - } - setContent { - val splashShowState by splashViewModel.isSplashShow.collectAsState() - -// if(!splashShowState) { -// val intent = Intent(this, MainActivity::class.java) -// startActivity(intent) -// } - SplashScreen() + + val firstEntryScreen = splashViewModel.firstEntryScreen.collectAsState() + if (firstEntryScreen.value != FirstEntryScreen.Splash) { + val intent = Intent(this, MainActivity::class.java) + intent.putExtra("firstEntry", firstEntryScreen.value.name) + startActivity(intent) + finish() + } } } -} \ No newline at end of file +} diff --git a/app/src/main/java/com/mashup/dorabangs/splash/SplashScreen.kt b/app/src/main/java/com/mashup/dorabangs/splash/SplashScreen.kt index 08f436eb..23a89498 100644 --- a/app/src/main/java/com/mashup/dorabangs/splash/SplashScreen.kt +++ b/app/src/main/java/com/mashup/dorabangs/splash/SplashScreen.kt @@ -2,18 +2,20 @@ package com.mashup.dorabangs.splash import androidx.compose.foundation.layout.Box import androidx.compose.foundation.layout.fillMaxSize +import androidx.compose.foundation.layout.size import androidx.compose.runtime.Composable import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier -import com.mashup.dorabangs.core.designsystem.R as coreR +import androidx.compose.ui.unit.dp import com.mashup.dorabangs.core.designsystem.component.util.LottieLoader +import com.mashup.dorabangs.core.designsystem.R as coreR @Composable fun SplashScreen() { Box(modifier = Modifier.fillMaxSize()) { LottieLoader( lottieRes = coreR.raw.splash, - modifier = Modifier.align(Alignment.Center) + modifier = Modifier.align(Alignment.Center).size(126.dp), ) } } diff --git a/app/src/main/java/com/mashup/dorabangs/splash/SplashViewModel.kt b/app/src/main/java/com/mashup/dorabangs/splash/SplashViewModel.kt index 3c0852ec..dbf7d9e0 100644 --- a/app/src/main/java/com/mashup/dorabangs/splash/SplashViewModel.kt +++ b/app/src/main/java/com/mashup/dorabangs/splash/SplashViewModel.kt @@ -10,11 +10,11 @@ import com.mashup.dorabangs.domain.usecase.user.GetUserAccessTokenUseCase import com.mashup.dorabangs.domain.usecase.user.RegisterUserUseCase import com.mashup.dorabangs.domain.usecase.user.SetUserAccessTokenUseCase import dagger.hilt.android.lifecycle.HiltViewModel +import kotlinx.coroutines.delay import kotlinx.coroutines.flow.MutableStateFlow import kotlinx.coroutines.flow.StateFlow import kotlinx.coroutines.flow.asStateFlow import kotlinx.coroutines.flow.firstOrNull -import kotlinx.coroutines.withTimeout import javax.inject.Inject @HiltViewModel @@ -40,19 +40,18 @@ class SplashViewModel @Inject constructor( token }.orEmpty() - withTimeout(SPLASH_SCREEN_TIME) { - if (userAccessToken.isNotEmpty()) { - splashShowFlow.value = false - _firstEntryScreen.value = if (getIsFirstEntryUseCase().firstOrNull() != false) FirstEntryScreen.Onboarding else FirstEntryScreen.Home - } else { - // Todo :: 유저 토큰 가져오기 실패에 대한 처리 해줘야함 (Like 토스트 메시지) - } + if (userAccessToken.isNotEmpty()) { + delay(SPLASH_SCREEN_TIME) + splashShowFlow.value = false + _firstEntryScreen.value = if (getIsFirstEntryUseCase().firstOrNull() != false) FirstEntryScreen.Onboarding else FirstEntryScreen.Home + } else { + // Todo :: 유저 토큰 가져오기 실패에 대한 처리 해줘야함 (Like 토스트 메시지) } } } companion object { - private const val SPLASH_SCREEN_TIME = 1000L + private const val SPLASH_SCREEN_TIME = 3000L } } diff --git a/feature/home/src/main/java/com/mashup/dorabangs/feature/home/HomeContract.kt b/feature/home/src/main/java/com/mashup/dorabangs/feature/home/HomeContract.kt index 56214d6d..d777c5c4 100644 --- a/feature/home/src/main/java/com/mashup/dorabangs/feature/home/HomeContract.kt +++ b/feature/home/src/main/java/com/mashup/dorabangs/feature/home/HomeContract.kt @@ -7,7 +7,7 @@ import com.mashup.dorabangs.domain.model.Folder import com.mashup.dorabangs.domain.utils.isValidUrl data class HomeState( - val isLoading: Boolean = false, + val isLoading: Boolean = true, val isScrollLoading: Boolean = false, val clipBoardState: ClipBoardState = ClipBoardState(), val tapElements: List = emptyList(), From d90406b63920e9ff30219c5d3f71de89f07fe71f Mon Sep 17 00:00:00 2001 From: devdayeon Date: Fri, 27 Sep 2024 13:38:07 +0900 Subject: [PATCH 3/3] =?UTF-8?q?[fix]=20=EC=BD=94=EB=93=9C=20=EB=A6=AC?= =?UTF-8?q?=EB=B7=B0=20=EB=B0=98=EC=98=81=20=EB=B0=8F=20=EC=95=A0=EB=8B=88?= =?UTF-8?q?=EB=A9=94=EC=9D=B4=EC=85=98=20=EC=A0=9C=EA=B1=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/com/mashup/dorabangs/MainActivity.kt | 27 +++++++++---------- .../mashup/dorabangs/splash/SplashActivity.kt | 3 +-- 2 files changed, 13 insertions(+), 17 deletions(-) diff --git a/app/src/main/java/com/mashup/dorabangs/MainActivity.kt b/app/src/main/java/com/mashup/dorabangs/MainActivity.kt index e45d707f..08108312 100644 --- a/app/src/main/java/com/mashup/dorabangs/MainActivity.kt +++ b/app/src/main/java/com/mashup/dorabangs/MainActivity.kt @@ -31,24 +31,21 @@ class MainActivity : ComponentActivity() { super.onCreate(savedInstanceState) checkPermission() - val firstEntryScreen = intent.getStringExtra("firstEntry") - val url = intent.data?.path?.substring(1).orEmpty() + val firstEntryScreen = intent.getStringExtra("firstEntry") ?: FirstEntryScreen.Onboarding.name setContent { - firstEntryScreen?.let { - if (firstEntryScreen != FirstEntryScreen.Splash.name) { - val imm = getSystemService(Context.INPUT_METHOD_SERVICE) as? InputMethodManager + if (firstEntryScreen != FirstEntryScreen.Splash.name) { + val imm = getSystemService(Context.INPUT_METHOD_SERVICE) as? InputMethodManager - DorabangsTheme { - DoraApp( - isFirstEntry = firstEntryScreen == FirstEntryScreen.Onboarding.name, - hideKeyboardAction = { - currentFocus?.let { - imm?.hideSoftInputFromWindow(it.windowToken, 0) - } - }, - ) - } + DorabangsTheme { + DoraApp( + isFirstEntry = firstEntryScreen == FirstEntryScreen.Onboarding.name, + hideKeyboardAction = { + currentFocus?.let { + imm?.hideSoftInputFromWindow(it.windowToken, 0) + } + }, + ) } } } diff --git a/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt b/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt index 4cfeec71..de730b69 100644 --- a/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt +++ b/app/src/main/java/com/mashup/dorabangs/splash/SplashActivity.kt @@ -22,8 +22,6 @@ class SplashActivity : ComponentActivity() { val userId = Settings.Secure.getString(contentResolver, Settings.Secure.ANDROID_ID) splashViewModel.checkUserToken(userId) - val url = intent.data?.path?.substring(1).orEmpty() - setContent { SplashScreen() @@ -31,6 +29,7 @@ class SplashActivity : ComponentActivity() { if (firstEntryScreen.value != FirstEntryScreen.Splash) { val intent = Intent(this, MainActivity::class.java) intent.putExtra("firstEntry", firstEntryScreen.value.name) + intent.addFlags(Intent.FLAG_ACTIVITY_NO_ANIMATION) startActivity(intent) finish() }