Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

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

Merged
merged 2 commits into from
Jan 7, 2025
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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
22 changes: 15 additions & 7 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,18 @@ 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.consumeWindowInsets
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.Scaffold
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,24 +22,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) {
Surface(color = MaterialTheme.colorScheme.background) {
Scaffold { innerPadding ->
DemoNavHost(
navController = navController,
modifier = Modifier.padding(innerPadding),
modifier = Modifier.consumeWindowInsets(innerPadding),
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
128 changes: 71 additions & 57 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 @@ -100,6 +103,8 @@ fun TweaksScreen(
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,8 @@ fun TweaksScreen(
text = category.title,
)
}

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

Expand All @@ -132,9 +139,12 @@ fun TweaksCategoryScreen(
verticalArrangement = Arrangement.spacedBy(8.dp),
horizontalAlignment = Alignment.CenterHorizontally,
) {
Spacer(modifier = Modifier.windowInsetsTopHeight(WindowInsets.statusBars))

Text(
tweakCategory.title,
style = MaterialTheme.typography.h4,
modifier = Modifier.padding(top = 16.dp),
text = tweakCategory.title,
style = MaterialTheme.typography.headlineLarge,
color = TweaksTheme.colors.tweaksOnBackground,
)

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

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

Expand All @@ -156,7 +168,8 @@ fun TweakGroupBody(
onCustomNavigation: ((NavController) -> Unit) -> Unit,
) {
Card(
elevation = 3.dp
modifier = Modifier.padding(vertical = 16.dp),
elevation = cardElevation(3.dp),
) {
Column(
modifier = Modifier
Expand All @@ -166,10 +179,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 +221,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 +317,6 @@ fun EditableStringTweakEntryBody(
)
}

@OptIn(ExperimentalMaterialApi::class)
@Composable
fun EditableBooleanTweakEntryBody(
tweakRowViewModel: EditableTweakEntryViewModel<Boolean>,
Expand All @@ -322,15 +334,15 @@ fun EditableBooleanTweakEntryBody(
},
shouldShowOverriddenLabel = isOverridden
) {
CompositionLocalProvider(LocalMinimumInteractiveComponentEnforcement provides false) {
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LocalMinimumInteractiveComponentEnforcement was deprecated

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 +424,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 +544,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 +578,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
Loading