diff --git a/app/src/main/java/app/revanced/manager/compose/ui/screen/settings/AboutSettingsScreen.kt b/app/src/main/java/app/revanced/manager/compose/ui/screen/settings/AboutSettingsScreen.kt index 61d48f57bd..01f25d261e 100644 --- a/app/src/main/java/app/revanced/manager/compose/ui/screen/settings/AboutSettingsScreen.kt +++ b/app/src/main/java/app/revanced/manager/compose/ui/screen/settings/AboutSettingsScreen.kt @@ -1,19 +1,28 @@ package app.revanced.manager.compose.ui.screen.settings import androidx.compose.foundation.Image +import androidx.compose.foundation.border import androidx.compose.foundation.clickable import androidx.compose.foundation.layout.* import androidx.compose.foundation.rememberScrollState import androidx.compose.foundation.verticalScroll +import androidx.compose.material.icons.Icons +import androidx.compose.material.icons.outlined.Code +import androidx.compose.material.icons.outlined.FavoriteBorder +import androidx.compose.material.icons.outlined.Language +import androidx.compose.material.icons.outlined.MailOutline import androidx.compose.material3.* import androidx.compose.runtime.Composable import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier +import androidx.compose.ui.graphics.Color import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.res.stringResource import androidx.compose.ui.unit.dp +import app.revanced.manager.compose.BuildConfig import app.revanced.manager.compose.R import app.revanced.manager.compose.ui.component.AppTopBar +import app.revanced.manager.compose.util.openUrl import com.google.accompanist.drawablepainter.rememberDrawablePainter @OptIn(ExperimentalMaterial3Api::class) @@ -24,6 +33,30 @@ fun AboutSettingsScreen( val context = LocalContext.current val icon = rememberDrawablePainter(context.packageManager.getApplicationIcon(context.packageName)) + val filledButton = listOf( + Triple(Icons.Outlined.FavoriteBorder, stringResource(R.string.donate)) { + context.openUrl("https://github.com/sponsors/ReVanced") + }, + Triple(Icons.Outlined.Language, stringResource(R.string.website), third = { + context.openUrl("https://revanced.app") + }), + ) + + val outlinedButton = listOf( + Triple(Icons.Outlined.Code, stringResource(R.string.github), third = { + context.openUrl("https://revanced.app/github") + }), + Triple(Icons.Outlined.MailOutline, stringResource(R.string.contact), third = { + context.openUrl("mailto:contact@revanced.app") + }), + ) + + val listItems = listOf( + Triple(stringResource(R.string.submit_feedback), stringResource(R.string.submit_feedback_description), third = { /*TODO*/ }), + Triple(stringResource(R.string.contributors), stringResource(R.string.contributors_description), third = { /*TODO*/ }), + Triple(stringResource(R.string.developer_options), stringResource(R.string.developer_options_description), third = { /*TODO*/ }), + ) + Scaffold( topBar = { AppTopBar( @@ -38,45 +71,112 @@ fun AboutSettingsScreen( .padding(paddingValues) .verticalScroll(rememberScrollState()) ) { - Column( - modifier = Modifier.fillMaxWidth().padding(vertical = 15.dp), + modifier = Modifier.fillMaxWidth().padding(vertical = 16.dp), horizontalAlignment = Alignment.CenterHorizontally, - verticalArrangement = Arrangement.spacedBy(10.dp) + verticalArrangement = Arrangement.spacedBy(4.dp) ) { Image(painter = icon, contentDescription = null) Text(stringResource(R.string.app_name), style = MaterialTheme.typography.titleLarge) - Text("Version 1.0.0 (100000000)", style = MaterialTheme.typography.labelMedium) + Text( text = stringResource(R.string.version) + " " + BuildConfig.VERSION_NAME + " (" + BuildConfig.VERSION_CODE + ")", style = MaterialTheme.typography.bodyMedium) Row( - horizontalArrangement = Arrangement.spacedBy(10.dp) + modifier = Modifier.padding(top = 12.dp) ) { - FilledTonalButton(onClick = { /*TODO*/ }) { - Text("Website") - } - FilledTonalButton(onClick = { /*TODO*/ }) { - Text("Donate") + filledButton.forEach { (icon, text, onClick) -> + FilledTonalButton( + onClick = onClick, + modifier = Modifier.padding(end = 8.dp) + ) { + Row( + verticalAlignment = Alignment.CenterVertically, + ) { + Icon( + icon, + contentDescription = null, + modifier = Modifier + .size(28.dp) + .padding(end = 8.dp), + tint = MaterialTheme.colorScheme.primary + ) + Text( + text, + style = MaterialTheme.typography.labelLarge, + ) + } + } } } + Row( - horizontalArrangement = Arrangement.spacedBy(10.dp) + modifier = Modifier.padding(top = 12.dp) ) { - OutlinedButton(onClick = { /*TODO*/ }) { - Text("GitHub") - } - OutlinedButton(onClick = { /*TODO*/ }) { - Text("Contact") - } - OutlinedButton(onClick = { /*TODO*/ }) { - Text("License") + outlinedButton.forEach { (icon, text, onClick) -> + Button( + onClick = onClick, + modifier = Modifier.padding(end = 8.dp), + colors = ButtonDefaults.buttonColors( + containerColor = Color.Transparent, + contentColor = MaterialTheme.colorScheme.onSecondaryContainer + ), + border = ButtonDefaults.outlinedButtonBorder + ) { + Row( + verticalAlignment = Alignment.CenterVertically, + ) { + Icon( + icon, + contentDescription = null, + modifier = Modifier + .size(28.dp) + .padding(end = 8.dp), + tint = MaterialTheme.colorScheme.primary + ) + Text( + text, + style = MaterialTheme.typography.labelLarge, + color = MaterialTheme.colorScheme.primary + ) + } + } } } } - ListItem( - modifier = Modifier.clickable { }, - headlineContent = { Text(stringResource(R.string.contributors)) }, - supportingContent = { Text(stringResource(R.string.contributors_description)) } - ) + Box( + modifier = Modifier + .padding(vertical = 8.dp, horizontal = 16.dp) + .border( + width = 1.dp, + color = MaterialTheme.colorScheme.outlineVariant, + shape = MaterialTheme.shapes.medium + ) + .padding(16.dp) + ) { + Column { + Text( + text = stringResource(R.string.about_revanced_manager), + style = MaterialTheme.typography.titleMedium, + modifier = Modifier.padding(bottom = 8.dp), + ) + Text( + text = stringResource(R.string.revanced_manager_description), + style = MaterialTheme.typography.bodyMedium, + color = MaterialTheme.colorScheme.onSurfaceVariant + ) + } + + } + + listItems.forEach { (title, description, onClick) -> + ListItem( + modifier = Modifier + .fillMaxWidth() + .padding(8.dp) + .clickable { onClick() }, + headlineContent = { Text(title, style = MaterialTheme.typography.titleLarge) }, + supportingContent = { Text(description, style = MaterialTheme.typography.bodyMedium) } + ) + } } } } \ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 758984dd74..528645550b 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -73,4 +73,15 @@ Patching Saving Write patched Apk + Donate + Website + GitHub + Contact + Version + Submit issue or feedback + Help us improve this application + Developer options + Options for debugging issues + About ReVanced Manager + ReVanced Manager is an application designed to work with ReVanced Patcher, which allows for long-lasting patches to be created for Android apps. The patching system is designed to automatically work with new versions of apps with minimal maintenance. \ No newline at end of file