diff --git a/.github/pics/desktop.png b/.github/pics/desktop.png new file mode 100644 index 00000000..dffb3026 Binary files /dev/null and b/.github/pics/desktop.png differ diff --git a/.github/pics/foldable.png b/.github/pics/foldable.png new file mode 100644 index 00000000..9b7d4806 Binary files /dev/null and b/.github/pics/foldable.png differ diff --git a/.github/pics/img.png b/.github/pics/img.png deleted file mode 100644 index 1d1679fc..00000000 Binary files a/.github/pics/img.png and /dev/null differ diff --git a/.github/pics/phone.png b/.github/pics/phone.png new file mode 100644 index 00000000..627c98cf Binary files /dev/null and b/.github/pics/phone.png differ diff --git a/.github/pics/tablet.png b/.github/pics/tablet.png new file mode 100644 index 00000000..64dd6c32 Binary files /dev/null and b/.github/pics/tablet.png differ diff --git a/mobile/src/main/kotlin/org/michaelbel/template/ui/MainActivityContent.kt b/mobile/src/main/kotlin/org/michaelbel/template/ui/MainActivityContent.kt index 6d4cac03..48ff373a 100644 --- a/mobile/src/main/kotlin/org/michaelbel/template/ui/MainActivityContent.kt +++ b/mobile/src/main/kotlin/org/michaelbel/template/ui/MainActivityContent.kt @@ -19,6 +19,7 @@ import androidx.compose.foundation.layout.offset import androidx.compose.foundation.layout.padding import androidx.compose.foundation.layout.size import androidx.compose.foundation.layout.sizeIn +import androidx.compose.foundation.layout.statusBarsPadding import androidx.compose.foundation.rememberScrollState import androidx.compose.foundation.shape.CircleShape import androidx.compose.foundation.verticalScroll @@ -41,6 +42,7 @@ import androidx.compose.material3.NavigationRail import androidx.compose.material3.NavigationRailItem import androidx.compose.material3.PermanentDrawerSheet 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 @@ -61,9 +63,7 @@ import androidx.compose.ui.layout.Layout import androidx.compose.ui.layout.Measurable import androidx.compose.ui.layout.MeasurePolicy import androidx.compose.ui.layout.layoutId -import androidx.compose.ui.res.stringResource import androidx.compose.ui.text.font.FontWeight -import androidx.compose.ui.text.style.TextAlign import androidx.compose.ui.unit.dp import androidx.compose.ui.unit.offset import androidx.compose.ui.unit.sp @@ -76,7 +76,6 @@ import kotlinx.serialization.Serializable import org.koin.androidx.compose.koinViewModel import org.michaelbel.core.ktx.navigationSuiteType import org.michaelbel.template.MainViewModel -import org.michaelbel.template.R @Composable fun MainActivityContent( @@ -187,19 +186,28 @@ fun MainActivityContent( verticalArrangement = Arrangement.spacedBy(4.dp) ) { FloatingActionButton( - onClick = {}, - modifier = Modifier.padding(top = 8.dp, bottom = 32.dp), + onClick = { + coroutineScope.launch { + snackbarHostState.showSnackbar( + message = "Single-line snackbar with action", + actionLabel = "Action", + duration = SnackbarDuration.Short + ) + } + }, + modifier = Modifier + .statusBarsPadding() + .padding(top = 16.dp), containerColor = MaterialTheme.colorScheme.tertiaryContainer, contentColor = MaterialTheme.colorScheme.onTertiaryContainer ) { Icon( imageVector = Icons.Default.Edit, - contentDescription = null, - modifier = Modifier.size(18.dp) + contentDescription = null ) } - Spacer(Modifier.height(8.dp)) // NavigationRailHeaderPadding - Spacer(Modifier.height(4.dp)) // NavigationRailVerticalPadding + + Spacer(Modifier.height(16.dp)) NavigationRailItem( selected = selectedRoute == Navigation.Home, @@ -209,11 +217,6 @@ fun MainActivityContent( imageVector = Icons.Outlined.Home, contentDescription = null ) - }, - label = { - Text( - text = "Home" - ) } ) @@ -249,11 +252,6 @@ fun MainActivityContent( contentDescription = null ) } - }, - label = { - Text( - text = "Chat" - ) } ) @@ -265,11 +263,6 @@ fun MainActivityContent( imageVector = Icons.Outlined.Settings, contentDescription = null ) - }, - label = { - Text( - text = "Settings" - ) } ) } @@ -290,18 +283,19 @@ fun MainActivityContent( horizontalAlignment = Alignment.Start, verticalArrangement = Arrangement.spacedBy(4.dp) ) { - Text( - modifier = Modifier - .padding(16.dp), - text = stringResource(id = R.string.app_name).uppercase(), - style = MaterialTheme.typography.titleMedium, - color = MaterialTheme.colorScheme.primary - ) ExtendedFloatingActionButton( - onClick = { /*TODO*/ }, + onClick = { + coroutineScope.launch { + snackbarHostState.showSnackbar( + message = "Single-line snackbar with action", + actionLabel = "Action", + duration = SnackbarDuration.Short + ) + } + }, modifier = Modifier .fillMaxWidth() - .padding(top = 8.dp, bottom = 40.dp), + .statusBarsPadding(), containerColor = MaterialTheme.colorScheme.tertiaryContainer, contentColor = MaterialTheme.colorScheme.onTertiaryContainer ) { @@ -310,10 +304,10 @@ fun MainActivityContent( contentDescription = null, modifier = Modifier.size(24.dp) ) + Text( text = "Compose", - modifier = Modifier.weight(1f), - textAlign = TextAlign.Center + modifier = Modifier.padding(start = 8.dp), ) } } @@ -422,21 +416,31 @@ fun MainActivityContent( ) }, floatingActionButton = { - FloatingActionButton( - onClick = { - coroutineScope.launch { - snackbarHostState.showSnackbar( - message = "Single-line snackbar with action", - actionLabel = "Action" - ) - } - }, - modifier = Modifier.offset(y = 16.dp) - ) { - Icon( - imageVector = Icons.Outlined.Edit, - contentDescription = null - ) + if (navigationSuiteType == NavigationSuiteType.NavigationBar) { + ExtendedFloatingActionButton( + onClick = { + coroutineScope.launch { + snackbarHostState.showSnackbar( + message = "Single-line snackbar with action", + actionLabel = "Action", + duration = SnackbarDuration.Short + ) + } + }, + modifier = Modifier.offset(y = 16.dp), + containerColor = MaterialTheme.colorScheme.tertiaryContainer, + contentColor = MaterialTheme.colorScheme.onTertiaryContainer + ) { + Icon( + imageVector = Icons.Outlined.Edit, + contentDescription = null + ) + + Text( + text = "Compose", + modifier = Modifier.padding(start = 8.dp) + ) + } } } ) { innerPadding -> diff --git a/readme.md b/readme.md index 2f6a99af..da838d58 100644 --- a/readme.md +++ b/readme.md @@ -7,12 +7,27 @@ Android App Template This Android app template provides a foundation for quickly starting development across Mobile, Wear, TV, and Auto platforms. It includes pre-configured dependencies, code samples, and project structure, simplifying the creation and setup of new applications. The template helps reduce configuration time and allows developers to focus on implementing functionality, ensuring a smooth start. [data:image/s3,"s3://crabby-images/ba8ce/ba8ce9e9c29fb1e9e55ce280a3ae829765ba5249" alt="android-mobile"](https://github.com/michaelbel/android-template) +[data:image/s3,"s3://crabby-images/26323/263239c61f41e7dfaa2ab1f74398f3840986fcc5" alt="android-tablet"](https://github.com/michaelbel/android-template) +[data:image/s3,"s3://crabby-images/cd76c/cd76c2cf46950f0f7d6c4f6b27db4b97c122aae1" alt="android-foldable"](https://github.com/michaelbel/android-template) +[data:image/s3,"s3://crabby-images/51048/51048f15f96fba7353c8c4395c82bbca11fe78eb" alt="android-desktop"](https://github.com/michaelbel/android-template) [data:image/s3,"s3://crabby-images/570b2/570b25eee2777ac9710c3a1246e50cfe5b7d7a59" alt="android-wear"](https://github.com/michaelbel/android-template) [data:image/s3,"s3://crabby-images/746da/746da33889c2699055aa9d1d727516cd36a18bc2" alt="android-tv"](https://github.com/michaelbel/android-template) [data:image/s3,"s3://crabby-images/5ea33/5ea338cd79f78f98a561fe4321f2594ab2565e54" alt="android-auto"](https://github.com/michaelbel/android-template)