Skip to content

Commit

Permalink
replace material lib by material3 lib and enable edge to edge #ANDROI…
Browse files Browse the repository at this point in the history
…D-15563 (#47)

* replace material lib by material3 lib and enable edge to edge #ANDROID-15563

* fix edge to edge #ANDROID-15563
  • Loading branch information
juangardi21 authored Jan 7, 2025
1 parent b8e57af commit 98dee1e
Show file tree
Hide file tree
Showing 8 changed files with 129 additions and 107 deletions.
2 changes: 1 addition & 1 deletion app/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ dependencies {
implementation 'com.google.android.material:material:1.11.0'

implementation "androidx.compose.ui:ui:$compose_version"
implementation "androidx.compose.material:material:$compose_version"
implementation "androidx.compose.material3:material3:$compose_material3_version"
implementation "androidx.compose.ui:ui-tooling-preview:$compose_version"
implementation 'androidx.lifecycle:lifecycle-runtime-ktx:2.7.0'
implementation 'androidx.activity:activity-compose:1.9.0'
Expand Down
30 changes: 16 additions & 14 deletions app/src/main/java/com/telefonica/tweaks/demo/MainActivity.kt
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,16 @@ package com.telefonica.tweaks.demo

import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.SystemBarStyle
import androidx.activity.compose.setContent
import androidx.activity.enableEdgeToEdge
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.padding
import androidx.compose.material.MaterialTheme
import androidx.compose.material.Scaffold
import androidx.compose.material.Surface
import androidx.compose.material.Text
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
Expand All @@ -19,28 +20,29 @@ import androidx.navigation.NavHostController
import androidx.navigation.compose.NavHost
import androidx.navigation.compose.composable
import androidx.navigation.compose.rememberNavController
import com.telefonica.tweaks.demo.theme.DebugTweaksTheme
import com.telefonica.tweaks.addTweakGraph
import com.telefonica.tweaks.demo.theme.DebugTweaksTheme
import com.telefonica.tweaks.navigateToTweaksOnShake

class MainActivity : ComponentActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
enableEdgeToEdge(
statusBarStyle = SystemBarStyle.dark(android.graphics.Color.TRANSPARENT),
navigationBarStyle = SystemBarStyle.dark(android.graphics.Color.TRANSPARENT)
)

super.onCreate(savedInstanceState)

setContent {
DebugTweaksTheme {
val navController = rememberNavController()
navController.navigateToTweaksOnShake()
Surface(color = MaterialTheme.colors.background) {
Scaffold { innerPadding ->
DemoNavHost(
navController = navController,
modifier = Modifier.padding(innerPadding),
initialScreen = "tweaks",
)
}

Surface(color = MaterialTheme.colorScheme.background) {
DemoNavHost(
navController = navController,
initialScreen = "tweaks",
)
}
}
}
Expand Down
6 changes: 3 additions & 3 deletions app/src/main/java/com/telefonica/tweaks/demo/theme/Color.kt
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
package com.telefonica.tweaks.demo.theme

import androidx.compose.material.darkColors
import androidx.compose.ui.graphics.Color
import androidx.compose.material3.darkColorScheme

val TweaksColorPalette = darkColors(
val TweaksColorPalette = darkColorScheme(
primary = Color.Blue,
primaryVariant = Color.Blue,
inversePrimary = Color.Blue,
surface = Color.Black,
onSurface = Color.Black,
background = Color.Black,
Expand Down
4 changes: 2 additions & 2 deletions app/src/main/java/com/telefonica/tweaks/demo/theme/Theme.kt
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
package com.telefonica.tweaks.demo.theme

import androidx.compose.material.MaterialTheme
import androidx.compose.material3.MaterialTheme
import androidx.compose.runtime.Composable
import com.telefonica.tweaks.ui.theme.TweaksTypography

@Composable
fun DebugTweaksTheme(
content: @Composable () -> Unit
) {
MaterialTheme(colors = TweaksColorPalette, typography = TweaksTypography, content = content)
MaterialTheme(colorScheme = TweaksColorPalette, typography = TweaksTypography, content = content)
}
1 change: 1 addition & 0 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ buildscript {
ext {
compose_compiler_version = '1.5.12'
compose_version = '1.6.6'
compose_material3_version = '1.3.1'

kotlin_version = '1.9.23'
dagger_version = "2.51.1"
Expand Down
2 changes: 1 addition & 1 deletion library/build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ dependencies {
enabledImplementation 'androidx.appcompat:appcompat:1.6.1'
enabledImplementation 'com.google.android.material:material:1.11.0'

enabledImplementation "androidx.compose.material:material:$compose_version"
enabledImplementation "androidx.compose.material3:material3:$compose_material3_version"
enabledImplementation "androidx.compose.ui:ui-tooling-preview:$compose_version"
enabledImplementation 'androidx.lifecycle:lifecycle-runtime-ktx:2.7.0'
enabledImplementation 'androidx.activity:activity-compose:1.9.0'
Expand Down
131 changes: 70 additions & 61 deletions library/src/enabled/java/com/telefonica/tweaks/ui/TweakComponents.kt
Original file line number Diff line number Diff line change
Expand Up @@ -9,38 +9,41 @@ import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.ColumnScope
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.WindowInsets
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.navigationBars
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.size
import androidx.compose.foundation.layout.statusBars
import androidx.compose.foundation.layout.windowInsetsBottomHeight
import androidx.compose.foundation.layout.windowInsetsTopHeight
import androidx.compose.foundation.rememberScrollState
import androidx.compose.foundation.text.KeyboardActions
import androidx.compose.foundation.text.KeyboardOptions
import androidx.compose.foundation.verticalScroll
import androidx.compose.material.Button
import androidx.compose.material.ButtonColors
import androidx.compose.material.ButtonDefaults.buttonColors
import androidx.compose.material.Card
import androidx.compose.material.Checkbox
import androidx.compose.material.CheckboxColors
import androidx.compose.material.CheckboxDefaults
import androidx.compose.material.ContentAlpha
import androidx.compose.material.Divider
import androidx.compose.material.DropdownMenu
import androidx.compose.material.DropdownMenuItem
import androidx.compose.material.ExperimentalMaterialApi
import androidx.compose.material.Icon
import androidx.compose.material.IconButton
import androidx.compose.material.LocalMinimumInteractiveComponentEnforcement
import androidx.compose.material.MaterialTheme
import androidx.compose.material.Text
import androidx.compose.material.TextField
import androidx.compose.material.TextFieldColors
import androidx.compose.material.TextFieldDefaults
import androidx.compose.material.contentColorFor
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.filled.Delete
import androidx.compose.material3.Button
import androidx.compose.material3.ButtonColors
import androidx.compose.material3.ButtonDefaults
import androidx.compose.material3.Card
import androidx.compose.material3.CardDefaults.cardElevation
import androidx.compose.material3.Checkbox
import androidx.compose.material3.CheckboxColors
import androidx.compose.material3.CheckboxDefaults
import androidx.compose.material3.DropdownMenu
import androidx.compose.material3.DropdownMenuItem
import androidx.compose.material3.HorizontalDivider
import androidx.compose.material3.Icon
import androidx.compose.material3.IconButton
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Text
import androidx.compose.material3.TextField
import androidx.compose.material3.TextFieldColors
import androidx.compose.material3.TextFieldDefaults
import androidx.compose.material3.contentColorFor
import androidx.compose.runtime.Composable
import androidx.compose.runtime.CompositionLocalProvider
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.runtime.collectAsState
import androidx.compose.runtime.getValue
Expand Down Expand Up @@ -95,11 +98,13 @@ fun TweaksScreen(
modifier = Modifier
.fillMaxSize()
.background(TweaksTheme.colors.tweaksBackground)
.padding(16.dp)
.padding(horizontal = 16.dp)
.verticalScroll(scrollState),
verticalArrangement = Arrangement.spacedBy(8.dp),
horizontalAlignment = Alignment.CenterHorizontally,
) {
Spacer(modifier = Modifier.windowInsetsTopHeight(WindowInsets.statusBars))

tweaksGraph.cover?.let {
TweakGroupBody(
tweakGroup = it,
Expand All @@ -113,6 +118,7 @@ fun TweaksScreen(
text = category.title,
)
}
Spacer(modifier = Modifier.windowInsetsBottomHeight(WindowInsets.navigationBars))
}
}

Expand All @@ -127,14 +133,16 @@ fun TweaksCategoryScreen(
modifier = Modifier
.fillMaxSize()
.background(TweaksTheme.colors.tweaksBackground)
.padding(16.dp)
.padding(horizontal = 16.dp)
.verticalScroll(scrollState),
verticalArrangement = Arrangement.spacedBy(8.dp),
horizontalAlignment = Alignment.CenterHorizontally,
) {
Spacer(modifier = Modifier.windowInsetsTopHeight(WindowInsets.statusBars))

Text(
tweakCategory.title,
style = MaterialTheme.typography.h4,
text = tweakCategory.title,
style = MaterialTheme.typography.headlineLarge,
color = TweaksTheme.colors.tweaksOnBackground,
)

Expand All @@ -145,6 +153,8 @@ fun TweaksCategoryScreen(
onCustomNavigation = onCustomNavigation
)
}

Spacer(modifier = Modifier.windowInsetsBottomHeight(WindowInsets.navigationBars))
}
}

Expand All @@ -155,9 +165,7 @@ fun TweakGroupBody(
onNavigationEvent: (String) -> Unit,
onCustomNavigation: ((NavController) -> Unit) -> Unit,
) {
Card(
elevation = 3.dp
) {
Card(elevation = cardElevation(3.dp)) {
Column(
modifier = Modifier
.background(TweaksTheme.colors.tweaksGroupBackground)
Expand All @@ -166,10 +174,10 @@ fun TweakGroupBody(
) {
Text(
tweakGroup.title,
style = MaterialTheme.typography.h5,
style = MaterialTheme.typography.headlineMedium,
color = TweaksTheme.colors.tweaksOnBackground,
)
Divider(thickness = 2.dp)
HorizontalDivider(thickness = 2.dp)
tweakGroup.entries.iterator().forEach { entry ->
when (entry) {
is EditableStringTweakEntry -> EditableStringTweakEntryBody(
Expand Down Expand Up @@ -208,7 +216,7 @@ fun TweakGroupBody(
}

if (tweakGroup.entries.any { it is Editable<*> } && tweakGroup.withClearButton) {
Divider(thickness = 2.dp)
HorizontalDivider(thickness = 2.dp)
ResetButton(onResetClicked = { tweakGroupViewModel.reset(tweakGroup) })
}
}
Expand Down Expand Up @@ -304,7 +312,6 @@ fun EditableStringTweakEntryBody(
)
}

@OptIn(ExperimentalMaterialApi::class)
@Composable
fun EditableBooleanTweakEntryBody(
tweakRowViewModel: EditableTweakEntryViewModel<Boolean>,
Expand All @@ -322,15 +329,15 @@ fun EditableBooleanTweakEntryBody(
},
shouldShowOverriddenLabel = isOverridden
) {
CompositionLocalProvider(LocalMinimumInteractiveComponentEnforcement provides false) {
Checkbox(
checked = tweakRowViewModel.value ?: false,
onCheckedChange = {
tweakRowViewModel.updateValue(it)
},
colors = tweaksCheckboxColors(),
)
}
Checkbox(
modifier = Modifier.size(48.dp),
checked = tweakRowViewModel.value ?: false,
onCheckedChange = {
tweakRowViewModel.updateValue(it)
},
colors = tweaksCheckboxColors(),
)

}
}

Expand Down Expand Up @@ -412,16 +419,18 @@ fun DropDownMenuTweakEntryBody(
) {
items.forEachIndexed { index, value ->
DropdownMenuItem(
text = {
Text(
text = value,
color = TweaksTheme.colors.tweaksOnSurface
)
},
onClick = {
selectedIndex = index
expanded = false
tweakRowViewModel.updateValue(items[selectedIndex])
}) {
Text(
text = value,
color = TweaksTheme.colors.tweaksOnSurface
)
}
selectedIndex = index
expanded = false
tweakRowViewModel.updateValue(items[selectedIndex])
}
)
}
}
}
Expand Down Expand Up @@ -530,29 +539,29 @@ private fun TweakNameText(
) {
Text(
text = entry.name,
style = MaterialTheme.typography.h6,
style = MaterialTheme.typography.headlineSmall,
color = TweaksTheme.colors.tweaksOnBackground,
fontWeight = FontWeight.Bold,
modifier = Modifier.weight(1f, false)
)
if (shouldShowOverriddenLabel) {
Text(
" (Modified)",
style = MaterialTheme.typography.caption,
style = MaterialTheme.typography.labelMedium,
color = TweaksTheme.colors.tweaksColorModified,
)
}
}
}

@Composable
private fun tweaksButtonColors(): ButtonColors = buttonColors(
backgroundColor = TweaksTheme.colors.tweaksPrimary,
private fun tweaksButtonColors(): ButtonColors = ButtonDefaults.buttonColors(
containerColor = TweaksTheme.colors.tweaksPrimary,
contentColor = contentColorFor(backgroundColor = TweaksTheme.colors.tweaksBackground),
disabledBackgroundColor = TweaksTheme.colors.tweaksOnSurface.copy(alpha = 0.12f)
disabledContainerColor = TweaksTheme.colors.tweaksOnSurface.copy(alpha = 0.12f)
.compositeOver(TweaksTheme.colors.tweaksSurface),
disabledContentColor = TweaksTheme.colors.tweaksOnSurface.copy(alpha = 0.38f)
.compositeOver(TweaksTheme.colors.tweaksSurface),
disabledContentColor = TweaksTheme.colors.tweaksOnSurface
.copy(alpha = ContentAlpha.disabled),
)

@Composable
Expand All @@ -564,15 +573,15 @@ private fun tweaksCheckboxColors(): CheckboxColors = CheckboxDefaults.colors(

@Composable
private fun tweaksTextFieldColors(): TextFieldColors =
TextFieldDefaults.textFieldColors(
textColor = TweaksTheme.colors.tweaksOnBackground,
TextFieldDefaults.colors(
focusedTextColor = TweaksTheme.colors.tweaksOnBackground,
disabledTextColor = TweaksTheme.colors.tweaksOnBackground.copy(alpha = 0.8F),
cursorColor = TweaksTheme.colors.tweaksPrimary,
focusedLabelColor = TweaksTheme.colors.tweaksPrimary,
focusedIndicatorColor = TweaksTheme.colors.tweaksPrimary,
unfocusedIndicatorColor = TweaksTheme.colors.tweaksPrimary,
unfocusedLabelColor = TweaksTheme.colors.tweaksPrimary,
disabledLabelColor = TweaksTheme.colors.tweaksPrimary,
disabledLabelColor = TweaksTheme.colors.tweaksPrimary
)

@Composable
Expand Down
Loading

0 comments on commit 98dee1e

Please sign in to comment.