restyle settings items
This commit is contained in:
@ -16,9 +16,9 @@ import app.omnivore.omnivore.feature.library.LibraryView
|
||||
import app.omnivore.omnivore.feature.library.SearchView
|
||||
import app.omnivore.omnivore.feature.library.SearchViewModel
|
||||
import app.omnivore.omnivore.feature.save.SaveViewModel
|
||||
import app.omnivore.omnivore.feature.settings.PolicyWebView
|
||||
import app.omnivore.omnivore.feature.settings.SettingsScreen
|
||||
import app.omnivore.omnivore.feature.settings.SettingsViewModel
|
||||
import app.omnivore.omnivore.feature.web.WebViewScreen
|
||||
import app.omnivore.omnivore.navigation.Routes
|
||||
|
||||
@Composable
|
||||
@ -92,15 +92,15 @@ fun PrimaryNavigator(
|
||||
}
|
||||
|
||||
composable(Routes.Documentation.route) {
|
||||
PolicyWebView(navController = navController, url = "https://docs.omnivore.app")
|
||||
WebViewScreen(navController = navController, url = "https://docs.omnivore.app")
|
||||
}
|
||||
|
||||
composable(Routes.PrivacyPolicy.route) {
|
||||
PolicyWebView(navController = navController, url = "https://omnivore.app/privacy")
|
||||
WebViewScreen(navController = navController, url = "https://omnivore.app/privacy")
|
||||
}
|
||||
|
||||
composable(Routes.TermsAndConditions.route) {
|
||||
PolicyWebView(navController = navController, url = "https://omnivore.app/app/terms")
|
||||
WebViewScreen(navController = navController, url = "https://omnivore.app/app/terms")
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -11,11 +11,11 @@ import androidx.compose.foundation.layout.padding
|
||||
import androidx.compose.foundation.rememberScrollState
|
||||
import androidx.compose.foundation.shape.RoundedCornerShape
|
||||
import androidx.compose.foundation.verticalScroll
|
||||
import androidx.compose.material.Text
|
||||
import androidx.compose.material.icons.Icons
|
||||
import androidx.compose.material.icons.filled.Refresh
|
||||
import androidx.compose.material3.Icon
|
||||
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
|
||||
|
||||
@ -1,20 +1,15 @@
|
||||
package app.omnivore.omnivore.feature.settings
|
||||
|
||||
import androidx.compose.foundation.background
|
||||
import androidx.compose.foundation.clickable
|
||||
import androidx.compose.foundation.layout.Arrangement
|
||||
import androidx.compose.foundation.layout.Box
|
||||
import androidx.compose.foundation.layout.Column
|
||||
import androidx.compose.foundation.layout.PaddingValues
|
||||
import androidx.compose.foundation.layout.Row
|
||||
import androidx.compose.foundation.layout.Spacer
|
||||
import androidx.compose.foundation.layout.fillMaxSize
|
||||
import androidx.compose.foundation.layout.fillMaxWidth
|
||||
import androidx.compose.foundation.layout.height
|
||||
import androidx.compose.foundation.layout.padding
|
||||
import androidx.compose.foundation.rememberScrollState
|
||||
import androidx.compose.foundation.verticalScroll
|
||||
import androidx.compose.foundation.lazy.LazyColumn
|
||||
import androidx.compose.foundation.lazy.rememberLazyListState
|
||||
import androidx.compose.material.icons.Icons
|
||||
import androidx.compose.material.icons.filled.Home
|
||||
import androidx.compose.material.icons.automirrored.outlined.ArrowBack
|
||||
import androidx.compose.material3.ExperimentalMaterial3Api
|
||||
import androidx.compose.material3.HorizontalDivider
|
||||
import androidx.compose.material3.Icon
|
||||
@ -29,7 +24,6 @@ import androidx.compose.runtime.mutableStateOf
|
||||
import androidx.compose.runtime.remember
|
||||
import androidx.compose.ui.Alignment
|
||||
import androidx.compose.ui.Modifier
|
||||
import androidx.compose.ui.res.painterResource
|
||||
import androidx.compose.ui.res.stringResource
|
||||
import androidx.compose.ui.unit.dp
|
||||
import androidx.compose.ui.unit.sp
|
||||
@ -41,31 +35,32 @@ import app.omnivore.omnivore.navigation.Routes
|
||||
|
||||
@OptIn(ExperimentalMaterial3Api::class)
|
||||
@Composable
|
||||
fun SettingsScreen(
|
||||
internal fun SettingsScreen(
|
||||
loginViewModel: LoginViewModel,
|
||||
settingsViewModel: SettingsViewModel,
|
||||
navController: NavHostController,
|
||||
) {
|
||||
Scaffold(topBar = {
|
||||
TopAppBar(title = { Text(stringResource(R.string.settings_view_title)) }, actions = {
|
||||
IconButton(onClick = { navController.navigate(Routes.Library.route) }) {
|
||||
Icon(
|
||||
imageVector = Icons.Default.Home, contentDescription = null
|
||||
)
|
||||
}
|
||||
}, colors = TopAppBarDefaults.topAppBarColors(
|
||||
containerColor = MaterialTheme.colorScheme.surfaceVariant
|
||||
)
|
||||
TopAppBar(
|
||||
title = { Text(stringResource(R.string.settings_view_title)) },
|
||||
navigationIcon = {
|
||||
IconButton(onClick = { navController.navigateUp() }) {
|
||||
Icon(
|
||||
imageVector = Icons.AutoMirrored.Outlined.ArrowBack, contentDescription = null
|
||||
)
|
||||
}
|
||||
|
||||
},
|
||||
colors = TopAppBarDefaults.topAppBarColors(
|
||||
containerColor = MaterialTheme.colorScheme.background
|
||||
),
|
||||
)
|
||||
}) { paddingValues ->
|
||||
SettingsViewContent(
|
||||
loginViewModel = loginViewModel,
|
||||
settingsViewModel = settingsViewModel,
|
||||
navController = navController,
|
||||
modifier = Modifier.padding(
|
||||
top = paddingValues.calculateTopPadding(),
|
||||
bottom = paddingValues.calculateBottomPadding()
|
||||
)
|
||||
paddingValues = paddingValues
|
||||
)
|
||||
}
|
||||
}
|
||||
@ -75,61 +70,64 @@ fun SettingsViewContent(
|
||||
loginViewModel: LoginViewModel,
|
||||
settingsViewModel: SettingsViewModel,
|
||||
navController: NavHostController,
|
||||
modifier: Modifier
|
||||
paddingValues: PaddingValues
|
||||
) {
|
||||
val showLogoutDialog = remember { mutableStateOf(false) }
|
||||
val showManageAccountDialog = remember { mutableStateOf(false) }
|
||||
|
||||
Box(
|
||||
modifier = modifier.fillMaxSize()
|
||||
) {
|
||||
|
||||
val state = rememberLazyListState()
|
||||
val version = "Omnivore Version: " + BuildConfig.VERSION_NAME
|
||||
|
||||
Column(
|
||||
verticalArrangement = Arrangement.Top,
|
||||
horizontalAlignment = Alignment.Start,
|
||||
modifier = Modifier
|
||||
.background(MaterialTheme.colorScheme.background)
|
||||
.fillMaxSize()
|
||||
.padding(horizontal = 6.dp)
|
||||
.verticalScroll(rememberScrollState())
|
||||
LazyColumn(
|
||||
state = state,
|
||||
contentPadding = paddingValues,
|
||||
) {
|
||||
|
||||
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_documentation)) {
|
||||
navController.navigate(Routes.Documentation.route)
|
||||
}
|
||||
RowDivider()
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_feedback)) {
|
||||
settingsViewModel.presentIntercom()
|
||||
}
|
||||
RowDivider()
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_privacy_policy)) {
|
||||
navController.navigate(Routes.PrivacyPolicy.route)
|
||||
}
|
||||
RowDivider()
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_terms_and_conditions)) {
|
||||
navController.navigate(Routes.TermsAndConditions.route)
|
||||
item {
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_documentation)) {
|
||||
navController.navigate(Routes.Documentation.route)
|
||||
}
|
||||
}
|
||||
|
||||
SectionSpacer()
|
||||
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_manage_account)) {
|
||||
showManageAccountDialog.value = true
|
||||
item {
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_feedback)) {
|
||||
settingsViewModel.presentIntercom()
|
||||
}
|
||||
}
|
||||
RowDivider()
|
||||
SettingRow(
|
||||
text = stringResource(R.string.settings_view_setting_row_logout),
|
||||
includeIcon = false
|
||||
) {
|
||||
showLogoutDialog.value = true
|
||||
}
|
||||
RowDivider()
|
||||
|
||||
Text(
|
||||
text = version, fontSize = 12.sp, modifier = Modifier.padding(15.dp)
|
||||
)
|
||||
item {
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_privacy_policy)) {
|
||||
navController.navigate(Routes.PrivacyPolicy.route)
|
||||
}
|
||||
}
|
||||
|
||||
item {
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_terms_and_conditions)) {
|
||||
navController.navigate(Routes.TermsAndConditions.route)
|
||||
}
|
||||
}
|
||||
|
||||
item { HorizontalDivider() }
|
||||
|
||||
item {
|
||||
SettingRow(text = stringResource(R.string.settings_view_setting_row_manage_account)) {
|
||||
showManageAccountDialog.value = true
|
||||
}
|
||||
}
|
||||
|
||||
item {
|
||||
SettingRow(
|
||||
text = stringResource(R.string.settings_view_setting_row_logout)
|
||||
) {
|
||||
showLogoutDialog.value = true
|
||||
}
|
||||
}
|
||||
|
||||
item {
|
||||
Text(
|
||||
text = version, fontSize = 12.sp, modifier = Modifier.padding(15.dp)
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
if (showLogoutDialog.value) {
|
||||
@ -147,26 +145,11 @@ fun SettingsViewContent(
|
||||
settingsViewModel = settingsViewModel
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Composable
|
||||
private fun RowDivider() {
|
||||
HorizontalDivider(
|
||||
modifier = Modifier.padding(horizontal = 12.dp),
|
||||
color = MaterialTheme.colorScheme.onSurface.copy(alpha = 0.1f)
|
||||
)
|
||||
}
|
||||
|
||||
@Composable
|
||||
private fun SectionSpacer() {
|
||||
RowDivider()
|
||||
Spacer(Modifier.height(60.dp))
|
||||
RowDivider()
|
||||
}
|
||||
|
||||
@Composable
|
||||
private fun SettingRow(text: String, includeIcon: Boolean = true, tapAction: () -> Unit) {
|
||||
private fun SettingRow(text: String, tapAction: () -> Unit) {
|
||||
Row(horizontalArrangement = Arrangement.SpaceBetween,
|
||||
verticalAlignment = Alignment.CenterVertically,
|
||||
modifier = Modifier
|
||||
@ -176,14 +159,7 @@ private fun SettingRow(text: String, includeIcon: Boolean = true, tapAction: ()
|
||||
text = text,
|
||||
modifier = Modifier
|
||||
.align(Alignment.CenterVertically)
|
||||
.padding(16.dp),
|
||||
style = MaterialTheme.typography.titleMedium
|
||||
.padding(16.dp)
|
||||
)
|
||||
|
||||
if (includeIcon) {
|
||||
Icon(
|
||||
painter = painterResource(id = R.drawable.chevron_right), contentDescription = null
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,4 +1,4 @@
|
||||
package app.omnivore.omnivore.feature.settings
|
||||
package app.omnivore.omnivore.feature.web
|
||||
|
||||
import android.annotation.SuppressLint
|
||||
import android.view.ViewGroup
|
||||
@ -27,7 +27,7 @@ import app.omnivore.omnivore.navigation.Routes
|
||||
@SuppressLint("UnusedMaterial3ScaffoldPaddingParameter", "SetJavaScriptEnabled")
|
||||
@OptIn(ExperimentalMaterial3Api::class)
|
||||
@Composable
|
||||
fun PolicyWebView(navController: NavHostController, url: String) {
|
||||
fun WebViewScreen(navController: NavHostController, url: String) {
|
||||
Scaffold(topBar = {
|
||||
TopAppBar(title = { Text(stringResource(R.string.policy_webview_title)) }, actions = {
|
||||
IconButton(onClick = { navController.navigate(Routes.Settings.route) }) {
|
||||
@ -66,9 +66,6 @@ fun PolicyWebView(navController: NavHostController, url: String) {
|
||||
view?.animate()?.alpha(1.0f)?.duration = 200
|
||||
}
|
||||
}
|
||||
|
||||
// val themeID = if (isDarkMode) "Gray" else "LightGray"
|
||||
// loadUrl(url, mutableMapOf("Set-Cookie" to "theme=$themeID; Max-Age=31536000;"))
|
||||
loadUrl(url, mutableMapOf())
|
||||
}
|
||||
}, update = {})
|
||||
Reference in New Issue
Block a user