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