Change settings screen to object (#8604)

This commit is contained in:
Ivan Iskandar 2022-11-23 21:14:55 +07:00 committed by GitHub
parent e2179a6669
commit 7d34ff214c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
14 changed files with 150 additions and 152 deletions

View File

@ -52,7 +52,7 @@ import java.text.SimpleDateFormat
import java.util.Locale import java.util.Locale
import java.util.TimeZone import java.util.TimeZone
class AboutScreen : Screen { object AboutScreen : Screen {
@Composable @Composable
override fun Content() { override fun Content() {
@ -199,7 +199,6 @@ class AboutScreen : Screen {
} }
} }
companion object {
fun getVersionName(withBuildDate: Boolean): String { fun getVersionName(withBuildDate: Boolean): String {
return when { return when {
BuildConfig.DEBUG -> { BuildConfig.DEBUG -> {
@ -250,5 +249,4 @@ class AboutScreen : Screen {
BuildConfig.BUILD_TIME BuildConfig.BUILD_TIME
} }
} }
}
} }

View File

@ -68,7 +68,7 @@ import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
import java.io.File import java.io.File
class SettingsAdvancedScreen : SearchableSettings { object SettingsAdvancedScreen : SearchableSettings {
@ReadOnlyComposable @ReadOnlyComposable
@Composable @Composable
@StringRes @StringRes

View File

@ -27,7 +27,7 @@ import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
import java.util.Date import java.util.Date
class SettingsAppearanceScreen : SearchableSettings { object SettingsAppearanceScreen : SearchableSettings {
@ReadOnlyComposable @ReadOnlyComposable
@Composable @Composable

View File

@ -59,7 +59,7 @@ import kotlinx.coroutines.launch
import uy.kohesive.injekt.Injekt import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
class SettingsBackupScreen : SearchableSettings { object SettingsBackupScreen : SearchableSettings {
@ReadOnlyComposable @ReadOnlyComposable
@Composable @Composable

View File

@ -16,7 +16,7 @@ import eu.kanade.tachiyomi.util.system.AuthenticatorUtil.authenticate
import uy.kohesive.injekt.Injekt import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
class SettingsBrowseScreen : SearchableSettings { object SettingsBrowseScreen : SearchableSettings {
@ReadOnlyComposable @ReadOnlyComposable
@Composable @Composable

View File

@ -32,7 +32,7 @@ import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
import java.io.File import java.io.File
class SettingsDownloadScreen : SearchableSettings { object SettingsDownloadScreen : SearchableSettings {
@ReadOnlyComposable @ReadOnlyComposable
@Composable @Composable

View File

@ -25,7 +25,7 @@ import org.xmlpull.v1.XmlPullParser
import uy.kohesive.injekt.Injekt import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
class SettingsGeneralScreen : SearchableSettings { object SettingsGeneralScreen : SearchableSettings {
@Composable @Composable
@ReadOnlyComposable @ReadOnlyComposable

View File

@ -61,7 +61,7 @@ import kotlinx.coroutines.runBlocking
import uy.kohesive.injekt.Injekt import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
class SettingsLibraryScreen : SearchableSettings { object SettingsLibraryScreen : SearchableSettings {
@Composable @Composable
@ReadOnlyComposable @ReadOnlyComposable

View File

@ -175,76 +175,75 @@ object SettingsMainScreen : Screen {
private fun Navigator.navigate(screen: Screen, twoPane: Boolean) { private fun Navigator.navigate(screen: Screen, twoPane: Boolean) {
if (twoPane) replaceAll(screen) else push(screen) if (twoPane) replaceAll(screen) else push(screen)
} }
}
private data class Item( private data class Item(
@StringRes val titleRes: Int, @StringRes val titleRes: Int,
@StringRes val subtitleRes: Int, @StringRes val subtitleRes: Int,
val formatSubtitle: @Composable () -> String = { stringResource(subtitleRes) }, val formatSubtitle: @Composable () -> String = { stringResource(subtitleRes) },
val icon: ImageVector, val icon: ImageVector,
val screen: Screen, val screen: Screen,
) )
private val items = listOf( private val items = listOf(
Item( Item(
titleRes = R.string.pref_category_general, titleRes = R.string.pref_category_general,
subtitleRes = R.string.pref_general_summary, subtitleRes = R.string.pref_general_summary,
icon = Icons.Outlined.Tune, icon = Icons.Outlined.Tune,
screen = SettingsGeneralScreen(), screen = SettingsGeneralScreen,
), ),
Item( Item(
titleRes = R.string.pref_category_appearance, titleRes = R.string.pref_category_appearance,
subtitleRes = R.string.pref_appearance_summary, subtitleRes = R.string.pref_appearance_summary,
icon = Icons.Outlined.Palette, icon = Icons.Outlined.Palette,
screen = SettingsAppearanceScreen(), screen = SettingsAppearanceScreen,
), ),
Item( Item(
titleRes = R.string.pref_category_library, titleRes = R.string.pref_category_library,
subtitleRes = R.string.pref_library_summary, subtitleRes = R.string.pref_library_summary,
icon = Icons.Outlined.CollectionsBookmark, icon = Icons.Outlined.CollectionsBookmark,
screen = SettingsLibraryScreen(), screen = SettingsLibraryScreen,
), ),
Item( Item(
titleRes = R.string.pref_category_reader, titleRes = R.string.pref_category_reader,
subtitleRes = R.string.pref_reader_summary, subtitleRes = R.string.pref_reader_summary,
icon = Icons.Outlined.ChromeReaderMode, icon = Icons.Outlined.ChromeReaderMode,
screen = SettingsReaderScreen(), screen = SettingsReaderScreen,
), ),
Item( Item(
titleRes = R.string.pref_category_downloads, titleRes = R.string.pref_category_downloads,
subtitleRes = R.string.pref_downloads_summary, subtitleRes = R.string.pref_downloads_summary,
icon = Icons.Outlined.GetApp, icon = Icons.Outlined.GetApp,
screen = SettingsDownloadScreen(), screen = SettingsDownloadScreen,
), ),
Item( Item(
titleRes = R.string.pref_category_tracking, titleRes = R.string.pref_category_tracking,
subtitleRes = R.string.pref_tracking_summary, subtitleRes = R.string.pref_tracking_summary,
icon = Icons.Outlined.Sync, icon = Icons.Outlined.Sync,
screen = SettingsTrackingScreen(), screen = SettingsTrackingScreen,
), ),
Item( Item(
titleRes = R.string.browse, titleRes = R.string.browse,
subtitleRes = R.string.pref_browse_summary, subtitleRes = R.string.pref_browse_summary,
icon = Icons.Outlined.Explore, icon = Icons.Outlined.Explore,
screen = SettingsBrowseScreen(), screen = SettingsBrowseScreen,
), ),
Item( Item(
titleRes = R.string.label_backup, titleRes = R.string.label_backup,
subtitleRes = R.string.pref_backup_summary, subtitleRes = R.string.pref_backup_summary,
icon = Icons.Outlined.SettingsBackupRestore, icon = Icons.Outlined.SettingsBackupRestore,
screen = SettingsBackupScreen(), screen = SettingsBackupScreen,
), ),
Item( Item(
titleRes = R.string.pref_category_security, titleRes = R.string.pref_category_security,
subtitleRes = R.string.pref_security_summary, subtitleRes = R.string.pref_security_summary,
icon = Icons.Outlined.Security, icon = Icons.Outlined.Security,
screen = SettingsSecurityScreen(), screen = SettingsSecurityScreen,
), ),
Item( Item(
titleRes = R.string.pref_category_advanced, titleRes = R.string.pref_category_advanced,
subtitleRes = R.string.pref_advanced_summary, subtitleRes = R.string.pref_advanced_summary,
icon = Icons.Outlined.Code, icon = Icons.Outlined.Code,
screen = SettingsAdvancedScreen(), screen = SettingsAdvancedScreen,
), ),
Item( Item(
titleRes = R.string.pref_category_about, titleRes = R.string.pref_category_about,
@ -253,6 +252,7 @@ private val items = listOf(
"${stringResource(R.string.app_name)} ${AboutScreen.getVersionName(withBuildDate = false)}" "${stringResource(R.string.app_name)} ${AboutScreen.getVersionName(withBuildDate = false)}"
}, },
icon = Icons.Outlined.Info, icon = Icons.Outlined.Info,
screen = AboutScreen(), screen = AboutScreen,
), ),
) )
}

View File

@ -21,7 +21,7 @@ import eu.kanade.tachiyomi.util.system.isReleaseBuildType
import uy.kohesive.injekt.Injekt import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
class SettingsReaderScreen : SearchableSettings { object SettingsReaderScreen : SearchableSettings {
@ReadOnlyComposable @ReadOnlyComposable
@Composable @Composable

View File

@ -282,16 +282,16 @@ private fun getLocalizedBreadcrumb(path: String, node: String?): String {
} }
private val settingScreens = listOf( private val settingScreens = listOf(
SettingsGeneralScreen(), SettingsGeneralScreen,
SettingsAppearanceScreen(), SettingsAppearanceScreen,
SettingsLibraryScreen(), SettingsLibraryScreen,
SettingsReaderScreen(), SettingsReaderScreen,
SettingsDownloadScreen(), SettingsDownloadScreen,
SettingsTrackingScreen(), SettingsTrackingScreen,
SettingsBrowseScreen(), SettingsBrowseScreen,
SettingsBackupScreen(), SettingsBackupScreen,
SettingsSecurityScreen(), SettingsSecurityScreen,
SettingsAdvancedScreen(), SettingsAdvancedScreen,
) )
private data class SettingsData( private data class SettingsData(

View File

@ -18,7 +18,7 @@ import eu.kanade.tachiyomi.util.system.AuthenticatorUtil.isAuthenticationSupport
import uy.kohesive.injekt.Injekt import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
class SettingsSecurityScreen : SearchableSettings { object SettingsSecurityScreen : SearchableSettings {
@ReadOnlyComposable @ReadOnlyComposable
@Composable @Composable

View File

@ -59,7 +59,7 @@ import eu.kanade.tachiyomi.util.system.toast
import uy.kohesive.injekt.Injekt import uy.kohesive.injekt.Injekt
import uy.kohesive.injekt.api.get import uy.kohesive.injekt.api.get
class SettingsTrackingScreen : SearchableSettings { object SettingsTrackingScreen : SearchableSettings {
@ReadOnlyComposable @ReadOnlyComposable
@Composable @Composable

View File

@ -45,9 +45,9 @@ class SettingsMainController(bundle: Bundle = bundleOf()) : BasicFullComposeCont
if (!isTabletUi) { if (!isTabletUi) {
Navigator( Navigator(
screen = if (toBackupScreen) { screen = if (toBackupScreen) {
SettingsBackupScreen() SettingsBackupScreen
} else if (toAboutScreen) { } else if (toAboutScreen) {
AboutScreen() AboutScreen
} else { } else {
SettingsMainScreen SettingsMainScreen
}, },
@ -63,11 +63,11 @@ class SettingsMainController(bundle: Bundle = bundleOf()) : BasicFullComposeCont
} else { } else {
Navigator( Navigator(
screen = if (toBackupScreen) { screen = if (toBackupScreen) {
SettingsBackupScreen() SettingsBackupScreen
} else if (toAboutScreen) { } else if (toAboutScreen) {
AboutScreen() AboutScreen
} else { } else {
SettingsGeneralScreen() SettingsGeneralScreen
}, },
) { ) {
TwoPanelBox( TwoPanelBox(