mirror of
				https://github.com/mihonapp/mihon.git
				synced 2025-10-30 22:07:57 +01:00 
			
		
		
		
	move display profile pref
This commit is contained in:
		| @@ -28,4 +28,6 @@ class BasePreferences( | ||||
|         SHIZUKU(MR.strings.ext_installer_shizuku, false), | ||||
|         PRIVATE(MR.strings.ext_installer_private, false), | ||||
|     } | ||||
|  | ||||
|     fun displayProfile() = preferenceStore.getString("pref_display_profile_key", "") | ||||
| } | ||||
|   | ||||
| @@ -6,6 +6,8 @@ import android.content.Intent | ||||
| import android.provider.Settings | ||||
| import android.webkit.WebStorage | ||||
| import android.webkit.WebView | ||||
| import androidx.activity.compose.rememberLauncherForActivityResult | ||||
| import androidx.activity.result.contract.ActivityResultContracts | ||||
| import androidx.compose.material3.AlertDialog | ||||
| import androidx.compose.material3.Text | ||||
| import androidx.compose.material3.TextButton | ||||
| @@ -83,6 +85,16 @@ object SettingsAdvancedScreen : SearchableSettings { | ||||
|         val basePreferences = remember { Injekt.get<BasePreferences>() } | ||||
|         val networkPreferences = remember { Injekt.get<NetworkPreferences>() } | ||||
|  | ||||
|         val chooseColorProfile = rememberLauncherForActivityResult( | ||||
|             contract = ActivityResultContracts.OpenDocument(), | ||||
|         ) { uri -> | ||||
|             uri?.let { | ||||
|                 val flags = Intent.FLAG_GRANT_READ_URI_PERMISSION | ||||
|                 context.contentResolver.takePersistableUriPermission(uri, flags) | ||||
|                 basePreferences.displayProfile().set(uri.toString()) | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return listOf( | ||||
|             Preference.PreferenceItem.TextPreference( | ||||
|                 title = stringResource(MR.strings.pref_dump_crash_logs), | ||||
| @@ -119,6 +131,13 @@ object SettingsAdvancedScreen : SearchableSettings { | ||||
|                     context.startActivity(intent) | ||||
|                 }, | ||||
|             ), | ||||
|             Preference.PreferenceItem.TextPreference( | ||||
|                 title = stringResource(MR.strings.pref_display_profile), | ||||
|                 subtitle = basePreferences.displayProfile().get(), | ||||
|                 onClick = { | ||||
|                     chooseColorProfile.launch(arrayOf("*/*")) | ||||
|                 }, | ||||
|             ), | ||||
|             getBackgroundActivityGroup(), | ||||
|             getDataGroup(), | ||||
|             getNetworkGroup(networkPreferences = networkPreferences), | ||||
|   | ||||
| @@ -1,14 +1,10 @@ | ||||
| package eu.kanade.presentation.more.settings.screen | ||||
|  | ||||
| import android.content.Intent | ||||
| import android.os.Build | ||||
| import androidx.activity.compose.rememberLauncherForActivityResult | ||||
| import androidx.activity.result.contract.ActivityResultContracts | ||||
| import androidx.compose.runtime.Composable | ||||
| import androidx.compose.runtime.ReadOnlyComposable | ||||
| import androidx.compose.runtime.getValue | ||||
| import androidx.compose.runtime.remember | ||||
| import androidx.compose.ui.platform.LocalContext | ||||
| import androidx.compose.ui.platform.LocalView | ||||
| import eu.kanade.presentation.more.settings.Preference | ||||
| import eu.kanade.tachiyomi.ui.reader.setting.ReaderOrientation | ||||
| @@ -33,17 +29,6 @@ object SettingsReaderScreen : SearchableSettings { | ||||
|     @Composable | ||||
|     override fun getPreferences(): List<Preference> { | ||||
|         val readerPref = remember { Injekt.get<ReaderPreferences>() } | ||||
|         val context = LocalContext.current | ||||
|  | ||||
|         val chooseColorProfile = rememberLauncherForActivityResult( | ||||
|             contract = ActivityResultContracts.OpenDocument(), | ||||
|         ) { uri -> | ||||
|             uri?.let { | ||||
|                 val flags = Intent.FLAG_GRANT_READ_URI_PERMISSION | ||||
|                 context.contentResolver.takePersistableUriPermission(uri, flags) | ||||
|                 readerPref.displayProfile().set(uri.toString()) | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return listOf( | ||||
|             Preference.PreferenceItem.ListPreference( | ||||
| @@ -72,13 +57,6 @@ object SettingsReaderScreen : SearchableSettings { | ||||
|                 title = stringResource(MR.strings.pref_show_navigation_mode), | ||||
|                 subtitle = stringResource(MR.strings.pref_show_navigation_mode_summary), | ||||
|             ), | ||||
|             Preference.PreferenceItem.TextPreference( | ||||
|                 title = stringResource(MR.strings.pref_display_profile), | ||||
|                 subtitle = readerPref.displayProfile().get(), | ||||
|                 onClick = { | ||||
|                     chooseColorProfile.launch(arrayOf("*/*")) | ||||
|                 }, | ||||
|             ), | ||||
|             Preference.PreferenceItem.SwitchPreference( | ||||
|                 pref = readerPref.pageTransitions(), | ||||
|                 title = stringResource(MR.strings.pref_page_transitions), | ||||
|   | ||||
| @@ -816,7 +816,7 @@ class ReaderActivity : BaseActivity() { | ||||
|                 } | ||||
|                 .launchIn(lifecycleScope) | ||||
|  | ||||
|             readerPreferences.displayProfile().changes() | ||||
|             preferences.displayProfile().changes() | ||||
|                 .onEach { setDisplayProfile(it) } | ||||
|                 .launchIn(lifecycleScope) | ||||
|  | ||||
|   | ||||
| @@ -23,8 +23,6 @@ class ReaderPreferences( | ||||
|  | ||||
|     fun showReadingMode() = preferenceStore.getBoolean("pref_show_reading_mode", true) | ||||
|  | ||||
|     fun displayProfile() = preferenceStore.getString("pref_display_profile_key", "") | ||||
|  | ||||
|     fun fullscreen() = preferenceStore.getBoolean("fullscreen", true) | ||||
|  | ||||
|     fun cutoutShort() = preferenceStore.getBoolean("cutout_short", true) | ||||
|   | ||||
| @@ -22,7 +22,6 @@ abstract class ViewerConfig(readerPreferences: ReaderPreferences, private val sc | ||||
|     var doubleTapAnimDuration = 500 | ||||
|     var volumeKeysEnabled = false | ||||
|     var volumeKeysInverted = false | ||||
|     var displayProfile = "" | ||||
|     var alwaysShowChapterTransition = true | ||||
|     var navigationMode = 0 | ||||
|         protected set | ||||
| @@ -65,9 +64,6 @@ abstract class ViewerConfig(readerPreferences: ReaderPreferences, private val sc | ||||
|         readerPreferences.alwaysShowChapterTransition() | ||||
|             .register({ alwaysShowChapterTransition = it }) | ||||
|  | ||||
|         readerPreferences.displayProfile() | ||||
|             .register({ displayProfile = it }, { imagePropertyChangedListener?.invoke() }) | ||||
|  | ||||
|         forceNavigationOverlay = readerPreferences.showNavigationOverlayNewUser().get() | ||||
|         if (forceNavigationOverlay) { | ||||
|             readerPreferences.showNavigationOverlayNewUser().set(false) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user