-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add navigation and initial screen components for the app
- Loading branch information
Showing
11 changed files
with
382 additions
and
15 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
104 changes: 104 additions & 0 deletions
104
presenter/src/main/java/com/foke/together/presenter/navigation/NavGraph.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,104 @@ | ||
package com.foke.together.presenter.navigation | ||
import androidx.compose.runtime.Composable | ||
import androidx.navigation.NavGraphBuilder | ||
import androidx.navigation.NavHostController | ||
import androidx.navigation.NavType | ||
import androidx.navigation.compose.NavHost | ||
import androidx.navigation.compose.composable | ||
import androidx.navigation.navArgument | ||
import com.foke.together.presenter.screen.CameraScreen | ||
import com.foke.together.presenter.screen.FrameScreen | ||
import com.foke.together.presenter.screen.HomeScreen | ||
import com.foke.together.presenter.screen.SettingScreen | ||
import com.foke.together.presenter.screen.ShareScreen | ||
|
||
@Composable | ||
fun NavGraph(navController: NavHostController) { | ||
|
||
NavHost( | ||
navController = navController, | ||
startDestination = NavRoute.Home.path | ||
) { | ||
addHomeScreen(navController, this) | ||
addSettingScreen(navController, this) | ||
addCameraScreen(navController, this) | ||
addFrameScreen(navController, this) | ||
addShareScreen(navController, this) | ||
} | ||
} | ||
|
||
|
||
private fun addHomeScreen( | ||
navController: NavHostController, | ||
navGraphBuilder: NavGraphBuilder | ||
) { | ||
navGraphBuilder.composable(route = NavRoute.Home.path) { | ||
HomeScreen( | ||
navigateToSetting = { | ||
navController.navigate(NavRoute.Setting.path) | ||
}, | ||
navigateToCamera = { | ||
navController.navigate(NavRoute.Camera.path) | ||
}, | ||
popBackStack = { navController.popBackStack() } | ||
) | ||
} | ||
} | ||
|
||
private fun addCameraScreen( | ||
navController: NavHostController, | ||
navGraphBuilder: NavGraphBuilder | ||
) { | ||
navGraphBuilder.composable(route = NavRoute.Camera.path) { | ||
CameraScreen( | ||
navigateToFrame = { | ||
navController.navigate(NavRoute.Frame.path) | ||
}, | ||
popBackStack = { | ||
navController.popBackStack(NavRoute.Home.path, inclusive = false) | ||
} | ||
) | ||
} | ||
} | ||
|
||
private fun addSettingScreen( | ||
navController: NavHostController, | ||
navGraphBuilder: NavGraphBuilder | ||
) { | ||
navGraphBuilder.composable(route = NavRoute.Setting.path) { | ||
SettingScreen( | ||
popBackStack = { | ||
navController.popBackStack(NavRoute.Home.path, inclusive = false) | ||
} | ||
) | ||
} | ||
} | ||
|
||
private fun addFrameScreen( | ||
navController: NavHostController, | ||
navGraphBuilder: NavGraphBuilder | ||
) { | ||
navGraphBuilder.composable(route = NavRoute.Frame.path) { | ||
FrameScreen( | ||
navigateShare = { | ||
navController.navigate(NavRoute.Share.path) | ||
}, | ||
popBackStack = { | ||
navController.popBackStack(NavRoute.Home.path, inclusive = false) | ||
} | ||
) | ||
} | ||
} | ||
|
||
private fun addShareScreen( | ||
navController: NavHostController, | ||
navGraphBuilder: NavGraphBuilder | ||
) { | ||
navGraphBuilder.composable(route = NavRoute.Frame.path) { | ||
ShareScreen( | ||
popBackStack = { | ||
navController.popBackStack(NavRoute.Home.path, inclusive = false) | ||
} | ||
) | ||
} | ||
} |
32 changes: 32 additions & 0 deletions
32
presenter/src/main/java/com/foke/together/presenter/navigation/NavRoute.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
package com.foke.together.presenter.navigation | ||
|
||
sealed class NavRoute(val path: String) { | ||
|
||
object Camera: NavRoute("camera") | ||
|
||
object Home: NavRoute("home") | ||
|
||
object Frame: NavRoute("frame") | ||
object Share: NavRoute("share") | ||
object Setting: NavRoute("setting") | ||
|
||
// build navigation path (for screen navigation) | ||
fun withArgs(vararg args: String): String { | ||
return buildString { | ||
append(path) | ||
args.forEach{ arg -> | ||
append("/$arg") | ||
} | ||
} | ||
} | ||
|
||
// build and setup route format (in navigation graph) | ||
fun withArgsFormat(vararg args: String) : String { | ||
return buildString { | ||
append(path) | ||
args.forEach{ arg -> | ||
append("/{$arg}") | ||
} | ||
} | ||
} | ||
} |
46 changes: 46 additions & 0 deletions
46
presenter/src/main/java/com/foke/together/presenter/screen/CameraScreen.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
package com.foke.together.presenter.screen | ||
|
||
import androidx.compose.foundation.layout.Column | ||
import androidx.compose.foundation.layout.fillMaxSize | ||
import androidx.compose.foundation.layout.fillMaxWidth | ||
import androidx.compose.material3.Button | ||
import androidx.compose.material3.MaterialTheme | ||
import androidx.compose.material3.Surface | ||
import androidx.compose.material3.Text | ||
import androidx.compose.runtime.Composable | ||
import androidx.compose.ui.Alignment | ||
import androidx.compose.ui.Modifier | ||
import androidx.compose.ui.tooling.preview.Preview | ||
import androidx.compose.ui.unit.sp | ||
import com.foke.together.presenter.ui.theme.FourCutTogetherTheme | ||
|
||
@Composable | ||
fun CameraScreen( | ||
navigateToFrame: () -> Unit, | ||
popBackStack: () -> Unit | ||
) { | ||
Column ( | ||
modifier = Modifier.fillMaxWidth(), | ||
horizontalAlignment = Alignment.CenterHorizontally) { | ||
Text("Camera Screen", fontSize = 40.sp) | ||
Button(onClick = navigateToFrame){ | ||
Text("Frame") | ||
} | ||
} | ||
} | ||
|
||
@Preview(showBackground = true) | ||
@Composable | ||
private fun DefaultPreview() { | ||
FourCutTogetherTheme() { | ||
Surface( | ||
modifier = Modifier.fillMaxSize(), | ||
color = MaterialTheme.colorScheme.background | ||
) { | ||
CameraScreen( | ||
navigateToFrame = { }, | ||
popBackStack = { } | ||
) | ||
} | ||
} | ||
} |
47 changes: 47 additions & 0 deletions
47
presenter/src/main/java/com/foke/together/presenter/screen/FrameScreen.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
package com.foke.together.presenter.screen | ||
|
||
import androidx.compose.foundation.layout.Column | ||
import androidx.compose.foundation.layout.fillMaxSize | ||
import androidx.compose.foundation.layout.fillMaxWidth | ||
import androidx.compose.material3.Button | ||
import androidx.compose.material3.MaterialTheme | ||
import androidx.compose.material3.Surface | ||
import androidx.compose.material3.Text | ||
import androidx.compose.runtime.Composable | ||
import androidx.compose.ui.Alignment | ||
import androidx.compose.ui.Modifier | ||
import androidx.compose.ui.tooling.preview.Preview | ||
import androidx.compose.ui.unit.sp | ||
import com.foke.together.presenter.ui.theme.FourCutTogetherTheme | ||
|
||
@Composable | ||
fun FrameScreen( | ||
navigateShare: () -> Unit, | ||
popBackStack: () -> Unit | ||
) { | ||
Column ( | ||
modifier = Modifier.fillMaxWidth(), | ||
horizontalAlignment = Alignment.CenterHorizontally) { | ||
Text("Frame Screen", fontSize = 40.sp) | ||
|
||
Button(onClick = navigateShare){ | ||
Text("Share") | ||
} | ||
} | ||
} | ||
|
||
@Preview(showBackground = true) | ||
@Composable | ||
private fun DefaultPreview() { | ||
FourCutTogetherTheme() { | ||
Surface( | ||
modifier = Modifier.fillMaxSize(), | ||
color = MaterialTheme.colorScheme.background | ||
) { | ||
FrameScreen( | ||
navigateShare = {}, | ||
popBackStack = {} | ||
) | ||
} | ||
} | ||
} |
54 changes: 54 additions & 0 deletions
54
presenter/src/main/java/com/foke/together/presenter/screen/HomeScreen.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
package com.foke.together.presenter.screen | ||
|
||
import androidx.compose.foundation.layout.Column | ||
import androidx.compose.foundation.layout.fillMaxSize | ||
import androidx.compose.foundation.layout.fillMaxWidth | ||
import androidx.compose.material3.Button | ||
import androidx.compose.material3.MaterialTheme | ||
import androidx.compose.material3.Surface | ||
import androidx.compose.material3.Text | ||
import androidx.compose.runtime.Composable | ||
import androidx.compose.ui.Alignment | ||
import androidx.compose.ui.Modifier | ||
import androidx.compose.ui.tooling.preview.Preview | ||
import androidx.compose.ui.unit.sp | ||
import com.foke.together.presenter.ui.theme.FourCutTogetherTheme | ||
|
||
@Composable | ||
fun HomeScreen( | ||
navigateToCamera: (String) -> Unit, | ||
navigateToSetting: (String) -> Unit, | ||
popBackStack: () -> Unit | ||
) { | ||
|
||
Column ( | ||
modifier = Modifier.fillMaxWidth(), | ||
horizontalAlignment = Alignment.CenterHorizontally) { | ||
Text("Home Screen", fontSize = 40.sp) | ||
|
||
Button(onClick = { navigateToCamera("camera") }){ | ||
Text("Camera") | ||
} | ||
|
||
Button(onClick = { navigateToSetting("Setting") }){ | ||
Text("Setting") | ||
} | ||
} | ||
} | ||
|
||
@Preview(showBackground = true) | ||
@Composable | ||
private fun DefaultPreview() { | ||
FourCutTogetherTheme() { | ||
Surface( | ||
modifier = Modifier.fillMaxSize(), | ||
color = MaterialTheme.colorScheme.background | ||
) { | ||
HomeScreen( | ||
navigateToCamera = { }, | ||
navigateToSetting = {}, | ||
popBackStack = {} | ||
) | ||
} | ||
} | ||
} |
Oops, something went wrong.