diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/MainActivity.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/MainActivity.kt index 8bfadf2a..60d453c6 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/MainActivity.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/MainActivity.kt @@ -26,8 +26,6 @@ import androidx.compose.runtime.DisposableEffect import androidx.compose.runtime.compositionLocalOf import androidx.compose.runtime.getValue import androidx.compose.runtime.mutableIntStateOf -import androidx.compose.runtime.mutableFloatStateOf -import androidx.compose.runtime.mutableStateOf import androidx.compose.runtime.remember import androidx.compose.runtime.rememberCoroutineScope import androidx.compose.runtime.setValue @@ -54,9 +52,6 @@ import com.sukisu.ultra.ui.screen.ModulePager import com.sukisu.ultra.ui.screen.SettingPager import com.sukisu.ultra.ui.screen.SuperUserPager import com.sukisu.ultra.ui.theme.KernelSUTheme -import com.sukisu.ultra.ui.theme.LocalWallpaperState -import com.sukisu.ultra.ui.theme.wallpaperContainerColor -import com.sukisu.ultra.ui.theme.wallpaperTransitionAlpha import com.sukisu.ultra.ui.util.install import top.yukonga.miuix.kmp.basic.Scaffold import top.yukonga.miuix.kmp.theme.MiuixTheme @@ -75,14 +70,6 @@ class MainActivity : ComponentActivity() { val prefs = context.getSharedPreferences("settings", MODE_PRIVATE) var colorMode by remember { mutableIntStateOf(prefs.getInt("color_mode", 0)) } var keyColorInt by remember { mutableIntStateOf(prefs.getInt("key_color", 0)) } - val wallpaperUriPref = prefs.getString("wallpaper_uri", null) - var wallpaperUri by remember { mutableStateOf(wallpaperUriPref) } - var wallpaperAlpha by remember { - mutableFloatStateOf(prefs.getFloat("wallpaper_alpha", 0f)) - } - var wallpaperScaleMode by remember { - mutableIntStateOf(prefs.getInt("wallpaper_scale_mode", 0)) - } val keyColor = remember(keyColorInt) { if (keyColorInt == 0) null else Color(keyColorInt) } val darkMode = when (colorMode) { @@ -110,29 +97,18 @@ class MainActivity : ComponentActivity() { when (key) { "color_mode" -> colorMode = prefs.getInt("color_mode", 0) "key_color" -> keyColorInt = prefs.getInt("key_color", 0) - "wallpaper_uri" -> wallpaperUri = prefs.getString("wallpaper_uri", null) - "wallpaper_alpha" -> wallpaperAlpha = prefs.getFloat("wallpaper_alpha", 0f) - "wallpaper_scale_mode" -> wallpaperScaleMode = prefs.getInt("wallpaper_scale_mode", 0) } } prefs.registerOnSharedPreferenceChangeListener(listener) onDispose { prefs.unregisterOnSharedPreferenceChangeListener(listener) } } - KernelSUTheme( - colorMode = colorMode, - keyColor = keyColor, - wallpaperUri = wallpaperUri, - wallpaperAlpha = wallpaperAlpha, - wallpaperScaleMode = wallpaperScaleMode - ) { + KernelSUTheme(colorMode = colorMode, keyColor = keyColor) { val navController = rememberNavController() val navigator = navController.rememberDestinationsNavigator() val initialIntent = remember { intent } - Scaffold( - containerColor = wallpaperContainerColor() - ) { + Scaffold { DestinationsNavHost( modifier = Modifier, navGraph = NavGraphs.root, @@ -189,12 +165,9 @@ fun MainScreen(navController: DestinationsNavigator) { val coroutineScope = rememberCoroutineScope() val pagerState = rememberPagerState(initialPage = 0, pageCount = { 4 }) val hazeState = remember { HazeState() } - val wallpaperState = LocalWallpaperState.current - val hazeBackgroundAlpha = wallpaperTransitionAlpha(wallpaperState.surfaceAlpha) - val hazeTintAlpha = wallpaperTransitionAlpha(0.8f * wallpaperState.surfaceAlpha) val hazeStyle = HazeStyle( - backgroundColor = MiuixTheme.colorScheme.background.copy(alpha = hazeBackgroundAlpha), - tint = HazeTint(MiuixTheme.colorScheme.background.copy(alpha = hazeTintAlpha)) + backgroundColor = MiuixTheme.colorScheme.background, + tint = HazeTint(MiuixTheme.colorScheme.background.copy(0.8f)) ) val handlePageChange: (Int) -> Unit = remember(pagerState, coroutineScope) { { page -> @@ -217,7 +190,6 @@ fun MainScreen(navController: DestinationsNavigator) { LocalHandlePageChange provides handlePageChange ) { Scaffold( - containerColor = wallpaperContainerColor(), bottomBar = { BottomBar(hazeState, hazeStyle) }, diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/component/DynamicManagerCard.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/component/DynamicManagerCard.kt index 4ba5cea4..7cc9b277 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/component/DynamicManagerCard.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/component/DynamicManagerCard.kt @@ -37,7 +37,6 @@ import top.yukonga.miuix.kmp.extra.SuperArrow import top.yukonga.miuix.kmp.extra.SuperDialog import top.yukonga.miuix.kmp.extra.SuperSwitch import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors @Composable fun DynamicManagerCard() { @@ -45,7 +44,6 @@ fun DynamicManagerCard() { modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val context = LocalContext.current val scope = rememberCoroutineScope() diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/kernelFlash/KernelFlash.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/kernelFlash/KernelFlash.kt index 0e6de993..aaa94e02 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/kernelFlash/KernelFlash.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/kernelFlash/KernelFlash.kt @@ -31,8 +31,6 @@ import com.ramcosta.composedestinations.navigation.DestinationsNavigator import com.sukisu.ultra.R import com.sukisu.ultra.ui.component.KeyEventBlocker import com.sukisu.ultra.ui.util.reboot -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.delay import kotlinx.coroutines.launch @@ -208,7 +206,6 @@ fun KernelFlashScreen( } Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopBar( flashState = flashState, @@ -250,7 +247,6 @@ fun KernelFlashScreen( Column( modifier = Modifier .fillMaxSize() - .background(wallpaperContainerColor()) .padding(it) .scrollEndHaptic(), ) { @@ -295,8 +291,7 @@ private fun FlashProgressIndicator( Card( modifier = Modifier .fillMaxWidth() - .padding(horizontal = 16.dp, vertical = 12.dp), - colors = wallpaperCardColors() + .padding(horizontal = 16.dp, vertical = 12.dp) ) { Column( modifier = Modifier diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/About.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/About.kt index 6d8e444b..212c8586 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/About.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/About.kt @@ -46,8 +46,6 @@ import dev.chrisbanes.haze.hazeEffect import dev.chrisbanes.haze.hazeSource import com.sukisu.ultra.BuildConfig import com.sukisu.ultra.R -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.basic.Card import top.yukonga.miuix.kmp.basic.Icon import top.yukonga.miuix.kmp.basic.IconButton @@ -84,7 +82,6 @@ fun AboutScreen(navigator: DestinationsNavigator) { val result = extractLinks(htmlString) Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopAppBar( modifier = Modifier.hazeEffect(hazeState) { @@ -157,8 +154,7 @@ fun AboutScreen(navigator: DestinationsNavigator) { } item { Card( - modifier = Modifier.padding(bottom = 12.dp), - colors = wallpaperCardColors() + modifier = Modifier.padding(bottom = 12.dp) ) { result.forEach { SuperArrow( diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/AppProfile.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/AppProfile.kt index e1dbdaaa..f1e26d9a 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/AppProfile.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/AppProfile.kt @@ -95,8 +95,6 @@ import top.yukonga.miuix.kmp.icon.MiuixIcons import top.yukonga.miuix.kmp.icon.icons.useful.Back import top.yukonga.miuix.kmp.icon.icons.useful.ImmersionMore import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical import top.yukonga.miuix.kmp.utils.scrollEndHaptic @@ -146,7 +144,6 @@ fun AppProfileScreen( } Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopBar( onBack = dropUnlessResumed { navigator.popBackStack() }, @@ -267,7 +264,6 @@ private fun AppProfileInner( .fillMaxWidth() .padding(horizontal = 12.dp) .padding(bottom = 12.dp), - colors = wallpaperCardColors(), insideMargin = PaddingValues(horizontal = 16.dp, vertical = 14.dp) ) { Row( @@ -366,7 +362,6 @@ private fun AppProfileInner( .fillMaxWidth() .padding(horizontal = 12.dp) .padding(bottom = 12.dp), - colors = wallpaperCardColors(), ) { SuperSwitch( leftAction = { @@ -454,7 +449,6 @@ private fun AppProfileInner( .fillMaxWidth() .padding(horizontal = 12.dp) .padding(bottom = if (rootMode != Mode.Default) 12.dp else 0.dp), - colors = wallpaperCardColors(), ) { AnimatedVisibility( visible = rootMode == Mode.Template, @@ -491,7 +485,6 @@ private fun AppProfileInner( .fillMaxWidth() .padding(horizontal = 12.dp) .padding(bottom = if (nonRootMode != Mode.Default) 12.dp else 0.dp), - colors = wallpaperCardColors(), ) { AnimatedVisibility( visible = nonRootMode == Mode.Custom, @@ -518,7 +511,6 @@ private fun AppProfileInner( .fillMaxWidth() .padding(horizontal = 12.dp) .padding(bottom = 12.dp), - colors = wallpaperCardColors(), ) { Spacer(Modifier.height(3.dp)) affectedApps.forEach { app -> @@ -662,7 +654,6 @@ private fun ProfileBox( modifier = Modifier .fillMaxWidth() .padding(horizontal = 12.dp), - colors = wallpaperCardColors(), ) { SuperDropdown( title = stringResource(R.string.profile), diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/ExecuteModuleAction.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/ExecuteModuleAction.kt index 248d165b..84eec3bf 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/ExecuteModuleAction.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/ExecuteModuleAction.kt @@ -60,7 +60,6 @@ import top.yukonga.miuix.kmp.icon.MiuixIcons import top.yukonga.miuix.kmp.icon.icons.useful.Back import top.yukonga.miuix.kmp.icon.icons.useful.Save import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.scrollEndHaptic import java.io.File import java.text.SimpleDateFormat @@ -110,7 +109,6 @@ fun ExecuteModuleActionScreen(navigator: DestinationsNavigator, moduleId: String } Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopBar( onBack = dropUnlessResumed { diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Flash.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Flash.kt index 3d4a7d25..a500ddad 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Flash.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Flash.kt @@ -58,7 +58,6 @@ import com.sukisu.ultra.R import com.sukisu.ultra.ui.component.KeyEventBlocker import com.sukisu.ultra.ui.util.FlashResult import com.sukisu.ultra.ui.util.LkmSelection -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import com.sukisu.ultra.ui.util.flashModule import com.sukisu.ultra.ui.util.installBoot import com.sukisu.ultra.ui.util.reboot @@ -172,7 +171,6 @@ fun FlashScreen( } Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopBar( flashing, diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Home.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Home.kt index b4acc6fc..4aa683f7 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Home.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Home.kt @@ -93,8 +93,6 @@ import top.yukonga.miuix.kmp.icon.icons.useful.Save import top.yukonga.miuix.kmp.theme.MiuixTheme import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme import top.yukonga.miuix.kmp.theme.MiuixTheme.isDynamicColor -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.PressFeedbackType import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical @@ -120,7 +118,6 @@ fun HomePager( val themeMode = prefs.getInt("color_mode", 0) Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopBar( kernelVersion = kernelVersion, @@ -410,7 +407,6 @@ private fun StatusCard( modifier = Modifier .fillMaxWidth() .weight(1f), - colors = wallpaperCardColors(), insideMargin = PaddingValues(16.dp), onClick = { onClickSuperuser() }, showIndication = true, @@ -441,7 +437,6 @@ private fun StatusCard( modifier = Modifier .fillMaxWidth() .weight(1f), - colors = wallpaperCardColors(), insideMargin = PaddingValues(16.dp), onClick = { onclickModule() }, showIndication = true, @@ -476,7 +471,6 @@ private fun StatusCard( onClick = { if (kernelVersion.isGKI()) onClickInstall() }, - colors = wallpaperCardColors(), showIndication = true, pressFeedbackType = PressFeedbackType.Sink ) { @@ -501,7 +495,6 @@ private fun StatusCard( onClick = { if (kernelVersion.isGKI()) onClickInstall() }, - colors = wallpaperCardColors(), showIndication = true, pressFeedbackType = PressFeedbackType.Sink ) { @@ -567,7 +560,6 @@ fun LearnMoreCard() { Card( modifier = Modifier .fillMaxWidth(), - colors = wallpaperCardColors(), ) { BasicComponent( title = stringResource(R.string.home_learn_kernelsu), @@ -594,7 +586,6 @@ fun DonateCard() { Card( modifier = Modifier .fillMaxWidth(), - colors = wallpaperCardColors(), ) { BasicComponent( title = stringResource(R.string.home_support_title), @@ -619,14 +610,14 @@ fun DonateCard() { private fun InfoCard() { val manualHookText = stringResource(R.string.manual_hook) val inlineHookText = stringResource(R.string.inline_hook) - val tracepointHookText = stringResource(R.string.tracepoint_hook) + val TracepointHookText = stringResource(R.string.tracepoint_hook) val unknownHookText = stringResource(R.string.selinux_status_unknown) val susfsInfo = rememberSusfsInfo(manualHookText, inlineHookText) val isSusfsSupported = susfsInfo.status == SusfsStatus.Supported - val hookTypeLabel = remember(manualHookText, inlineHookText, tracepointHookText) { + val hookTypeLabel = remember(manualHookText, inlineHookText, TracepointHookText) { val localized = when (val rawType = Natives.getHookType()) { "Manual" -> manualHookText - "Tracepoint" -> tracepointHookText + "Tracepoint" -> TracepointHookText else -> rawType } localized.ifBlank { unknownHookText } @@ -656,9 +647,7 @@ private fun InfoCard() { val uname = Os.uname() val managerVersion = getManagerVersion(context) - Card( - colors = wallpaperCardColors(), - ) { + Card { Column( modifier = Modifier .fillMaxWidth() diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Install.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Install.kt index b6edf683..2b233bab 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Install.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Install.kt @@ -95,8 +95,6 @@ import top.yukonga.miuix.kmp.icon.icons.useful.Edit import top.yukonga.miuix.kmp.icon.icons.useful.Move import top.yukonga.miuix.kmp.theme.MiuixTheme import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical import top.yukonga.miuix.kmp.utils.scrollEndHaptic @@ -250,7 +248,6 @@ fun InstallScreen( ) Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopBar( onBack = dropUnlessResumed { navigator.popBackStack() }, @@ -278,7 +275,6 @@ fun InstallScreen( Card( modifier = Modifier .fillMaxWidth(), - colors = wallpaperCardColors(), ) { SelectInstallMethod( onSelected = { method -> @@ -300,7 +296,6 @@ fun InstallScreen( modifier = Modifier .fillMaxWidth() .padding(top = 12.dp), - colors = wallpaperCardColors(), ) { val isOta = installMethod is InstallMethod.DirectInstallToInactiveSlot val suffix = produceState(initialValue = "", isOta) { @@ -343,7 +338,6 @@ fun InstallScreen( modifier = Modifier .fillMaxWidth() .padding(top = 12.dp), - colors = wallpaperCardColors(), ) { SuperArrow( title = stringResource(id = R.string.install_upload_lkm_file), @@ -373,7 +367,6 @@ fun InstallScreen( modifier = Modifier .fillMaxWidth() .padding(top = 12.dp), - colors = wallpaperCardColors(), ) { SuperArrow( title = stringResource( @@ -401,7 +394,6 @@ fun InstallScreen( modifier = Modifier .fillMaxWidth() .padding(top = 12.dp), - colors = wallpaperCardColors(), ) { SuperArrow( title = when (kpmPatchOption) { diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Kpm.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Kpm.kt index a04d4de1..fc71c9ca 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Kpm.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Kpm.kt @@ -70,8 +70,6 @@ import top.yukonga.miuix.kmp.icon.MiuixIcons import top.yukonga.miuix.kmp.icon.icons.useful.Refresh import top.yukonga.miuix.kmp.theme.MiuixTheme import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical import top.yukonga.miuix.kmp.utils.scrollEndHaptic @@ -348,7 +346,6 @@ fun KpmScreen( ) Scaffold( - containerColor = wallpaperContainerColor(), topBar = { searchStatus.TopAppBarAnim(hazeState = hazeState, hazeStyle = hazeStyle) { TopAppBar( @@ -698,8 +695,7 @@ private fun KpmList( Card( modifier = Modifier .fillMaxWidth() - .padding(horizontal = 12.dp, vertical = 12.dp), - colors = wallpaperCardColors() + .padding(horizontal = 12.dp, vertical = 12.dp) ) { Row( modifier = Modifier @@ -870,7 +866,6 @@ private fun KpmModuleItem( modifier = Modifier .padding(horizontal = 12.dp) .padding(bottom = 12.dp), - colors = wallpaperCardColors(), insideMargin = PaddingValues(16.dp) ) { Row( diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/LogViewer.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/LogViewer.kt index b17c668f..f4834cfd 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/LogViewer.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/LogViewer.kt @@ -27,8 +27,6 @@ import com.ramcosta.composedestinations.annotation.RootGraph import com.ramcosta.composedestinations.navigation.DestinationsNavigator import com.sukisu.ultra.R import com.sukisu.ultra.ui.util.* -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.delay import kotlinx.coroutines.launch @@ -208,7 +206,6 @@ fun LogViewer(navigator: DestinationsNavigator) { } Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopAppBar( title = stringResource(R.string.log_viewer_title), @@ -387,8 +384,7 @@ private fun LogControlPanel( Card( modifier = Modifier .fillMaxWidth() - .padding(horizontal = SPACING_LARGE, vertical = SPACING_MEDIUM), - colors = wallpaperCardColors() + .padding(horizontal = SPACING_LARGE, vertical = SPACING_MEDIUM) ) { Column { SuperArrow( @@ -576,8 +572,7 @@ private fun LogEntryCard(entry: LogEntry) { Card( modifier = Modifier.fillMaxWidth(), - onClick = { expanded = !expanded }, - colors = wallpaperCardColors() + onClick = { expanded = !expanded } ) { Column( modifier = Modifier.padding(SPACING_LARGE) diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Module.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Module.kt index 4b518a5e..6a828da5 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Module.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Module.kt @@ -141,8 +141,6 @@ import top.yukonga.miuix.kmp.icon.MiuixIcons import top.yukonga.miuix.kmp.icon.icons.useful.ImmersionMore import top.yukonga.miuix.kmp.icon.icons.useful.Undo import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical import top.yukonga.miuix.kmp.utils.scrollEndHaptic @@ -395,7 +393,6 @@ fun ModulePager( ) Scaffold( - containerColor = wallpaperContainerColor(), topBar = { searchStatus.TopAppBarAnim(hazeState = hazeState, hazeStyle = hazeStyle) { TopAppBar( @@ -912,7 +909,6 @@ fun ModuleItem( modifier = Modifier .padding(horizontal = 12.dp) .padding(bottom = 12.dp), - colors = wallpaperCardColors(), insideMargin = PaddingValues(16.dp) ) { Row( diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Settings.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Settings.kt index eb078430..9e440cae 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Settings.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Settings.kt @@ -80,8 +80,6 @@ import top.yukonga.miuix.kmp.extra.SuperArrow import top.yukonga.miuix.kmp.extra.SuperDropdown import top.yukonga.miuix.kmp.extra.SuperSwitch import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical import top.yukonga.miuix.kmp.utils.scrollEndHaptic @@ -106,7 +104,6 @@ fun SettingPager( val isKpmAvailable = rememberKpmAvailable() Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopAppBar( modifier = Modifier.hazeEffect(hazeState) { @@ -152,7 +149,6 @@ fun SettingPager( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { SuperSwitch( title = stringResource(id = R.string.settings_check_update), @@ -203,7 +199,6 @@ fun SettingPager( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val personalization = stringResource(id = R.string.personalization) SuperArrow( @@ -231,7 +226,6 @@ fun SettingPager( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { SuperArrow( title = toolsTitle, @@ -258,7 +252,6 @@ fun SettingPager( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val profileTemplate = stringResource(id = R.string.settings_profile_template) SuperArrow( @@ -286,7 +279,6 @@ fun SettingPager( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val kpmTitle = stringResource(id = R.string.kpm_title) SuperArrow( @@ -314,7 +306,6 @@ fun SettingPager( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val susfsTitle = stringResource(id = R.string.susfs_config_title) SuperArrow( @@ -593,7 +584,6 @@ fun SettingPager( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { var umountChecked by rememberSaveable { mutableStateOf(Natives.isDefaultUmountModules()) } SuperSwitch( @@ -645,7 +635,6 @@ fun SettingPager( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val uninstall = stringResource(id = R.string.settings_uninstall) SuperArrow( @@ -671,7 +660,6 @@ fun SettingPager( modifier = Modifier .padding(vertical = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { if (isSuLogEnabled) { val sulog = stringResource(id = R.string.log_viewer_view_logs) diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/SuperUser.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/SuperUser.kt index 9a63f885..29cc402b 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/SuperUser.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/SuperUser.kt @@ -98,8 +98,6 @@ import top.yukonga.miuix.kmp.icon.MiuixIcons import top.yukonga.miuix.kmp.icon.icons.basic.ArrowRight import top.yukonga.miuix.kmp.icon.icons.useful.ImmersionMore import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.PressFeedbackType import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical @@ -140,7 +138,6 @@ fun SuperUserPager( ) Scaffold( - containerColor = wallpaperContainerColor(), topBar = { searchStatus.TopAppBarAnim(hazeState = hazeState, hazeStyle = hazeStyle) { TopAppBar( @@ -397,8 +394,7 @@ private fun SimpleAppItem( ) Card( modifier = Modifier - .padding(start = 6.dp, end = 12.dp, bottom = 6.dp), - colors = wallpaperCardColors() + .padding(start = 6.dp, end = 12.dp, bottom = 6.dp) ) { BasicComponent( title = app.label, @@ -505,7 +501,6 @@ private fun GroupItem( modifier = Modifier .padding(horizontal = 12.dp) .padding(bottom = 12.dp), - colors = wallpaperCardColors(), onClick = onClickPrimary, onLongPress = if (group.apps.size > 1) onToggleExpand else null, pressFeedbackType = PressFeedbackType.Sink, diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Template.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Template.kt index 23f9aaa0..9b07fd5a 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Template.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/Template.kt @@ -101,8 +101,6 @@ import top.yukonga.miuix.kmp.icon.icons.useful.Copy import top.yukonga.miuix.kmp.icon.icons.useful.Refresh import top.yukonga.miuix.kmp.theme.MiuixTheme import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.PressFeedbackType import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical @@ -171,7 +169,6 @@ fun AppProfileTemplateScreen( ) Scaffold( - containerColor = wallpaperContainerColor(), topBar = { val clipboardManager = LocalClipboardManager.current val context = LocalContext.current @@ -313,7 +310,6 @@ private fun TemplateItem( ) { Card( modifier = Modifier.padding(bottom = 12.dp), - colors = wallpaperCardColors(), onClick = { navigator.navigate(TemplateEditorScreenDestination(template, !template.local)) { popUpTo(TemplateEditorScreenDestination) { diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/TemplateEditor.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/TemplateEditor.kt index 179e4d09..1c17f7c1 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/TemplateEditor.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/TemplateEditor.kt @@ -61,8 +61,6 @@ import top.yukonga.miuix.kmp.icon.icons.useful.Back import top.yukonga.miuix.kmp.icon.icons.useful.Confirm import top.yukonga.miuix.kmp.icon.icons.useful.Delete import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical import top.yukonga.miuix.kmp.utils.scrollEndHaptic @@ -98,7 +96,6 @@ fun TemplateEditorScreen( } Scaffold( - containerColor = wallpaperContainerColor(), topBar = { val saveTemplateFailed = stringResource(id = R.string.app_profile_template_save_failed) val idConflictError = stringResource(id = R.string.app_profile_template_id_exist) @@ -167,7 +164,6 @@ fun TemplateEditorScreen( modifier = Modifier .fillMaxWidth() .padding(12.dp), - colors = wallpaperCardColors(), ) { var errorHint by remember { mutableStateOf(false) diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/UmountManager.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/UmountManager.kt index 9ca077f8..92b07bc6 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/UmountManager.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/UmountManager.kt @@ -24,8 +24,6 @@ import com.ramcosta.composedestinations.navigation.DestinationsNavigator import com.sukisu.ultra.R import com.sukisu.ultra.ui.component.rememberConfirmDialog import com.sukisu.ultra.ui.component.ConfirmResult -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import com.sukisu.ultra.ui.util.* import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.launch @@ -89,7 +87,6 @@ fun UmountManager(navigator: DestinationsNavigator) { } Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopAppBar( title = stringResource(R.string.umount_path_manager), @@ -136,8 +133,7 @@ fun UmountManager(navigator: DestinationsNavigator) { Card( modifier = Modifier .fillMaxWidth() - .padding(SPACING_LARGE), - colors = wallpaperCardColors() + .padding(SPACING_LARGE) ) { Row( modifier = Modifier.padding(SPACING_LARGE), @@ -313,8 +309,7 @@ fun UmountPathCard( val context = LocalContext.current Card( - modifier = Modifier.fillMaxWidth(), - colors = wallpaperCardColors() + modifier = Modifier.fillMaxWidth() ) { Row( modifier = Modifier diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/settings/Personalization.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/settings/Personalization.kt index 39801999..68efe9cc 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/settings/Personalization.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/settings/Personalization.kt @@ -1,19 +1,7 @@ package com.sukisu.ultra.ui.screen.settings -import android.annotation.SuppressLint import android.content.Context -import android.content.Intent -import android.content.SharedPreferences -import android.os.Build -import androidx.activity.compose.rememberLauncherForActivityResult -import androidx.activity.result.PickVisualMediaRequest -import androidx.activity.result.contract.ActivityResultContracts import androidx.compose.animation.AnimatedVisibility -import androidx.compose.foundation.isSystemInDarkTheme -import androidx.compose.foundation.layout.Arrangement -import androidx.compose.foundation.layout.Column -import androidx.compose.foundation.layout.Row -import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.WindowInsets import androidx.compose.foundation.layout.WindowInsetsSides import androidx.compose.foundation.layout.add @@ -27,12 +15,8 @@ import androidx.compose.foundation.lazy.LazyColumn import androidx.compose.material.icons.Icons import androidx.compose.material.icons.rounded.Palette import androidx.compose.runtime.Composable -import androidx.compose.runtime.LaunchedEffect -import androidx.compose.runtime.Stable import androidx.compose.runtime.getValue -import androidx.compose.runtime.mutableFloatStateOf import androidx.compose.runtime.mutableIntStateOf -import androidx.compose.runtime.mutableStateOf import androidx.compose.runtime.remember import androidx.compose.runtime.saveable.rememberSaveable import androidx.compose.runtime.setValue @@ -58,24 +42,15 @@ import top.yukonga.miuix.kmp.basic.Icon import top.yukonga.miuix.kmp.basic.IconButton import top.yukonga.miuix.kmp.basic.MiuixScrollBehavior import top.yukonga.miuix.kmp.basic.Scaffold -import top.yukonga.miuix.kmp.basic.Slider -import top.yukonga.miuix.kmp.basic.SliderDefaults import top.yukonga.miuix.kmp.basic.TopAppBar -import top.yukonga.miuix.kmp.basic.Text -import top.yukonga.miuix.kmp.basic.TextButton import top.yukonga.miuix.kmp.icon.MiuixIcons import top.yukonga.miuix.kmp.icon.icons.useful.Back import top.yukonga.miuix.kmp.theme.MiuixTheme.colorScheme -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor -import top.yukonga.miuix.kmp.extra.SuperArrow import top.yukonga.miuix.kmp.extra.SuperDropdown import top.yukonga.miuix.kmp.utils.getWindowSize import top.yukonga.miuix.kmp.utils.overScrollVertical import top.yukonga.miuix.kmp.utils.scrollEndHaptic -import kotlin.math.roundToInt -@SuppressLint("ObsoleteSdkInt") @Composable @Destination fun Personalization( @@ -89,7 +64,6 @@ fun Personalization( ) Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopAppBar( modifier = Modifier.hazeEffect(hazeState) { @@ -136,7 +110,6 @@ fun Personalization( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val themeItems = listOf( stringResource(id = R.string.settings_theme_mode_system), @@ -217,260 +190,8 @@ fun Personalization( } ) } - - Spacer(modifier = Modifier.height(8.dp)) - - val isSystemDarkMode = isSystemInDarkTheme() - val isDarkThemeActive = when (themeMode) { - 1, 4 -> false - 2, 5 -> true - else -> isSystemDarkMode - } - val wallpaperAlphaMin = if (isDarkThemeActive) 0.2f else 0f - val wallpaperEnabledAlpha = if (isDarkThemeActive) 0.5f else 0.3f - val wallpaperPreferenceState = rememberWallpaperPreferenceState( - prefs = prefs, - wallpaperAlphaMin = wallpaperAlphaMin, - wallpaperEnabledAlpha = wallpaperEnabledAlpha - ) - - val summaryText = if (wallpaperPreferenceState.isEnabled) { - stringResource(id = R.string.settings_wallpaper_summary_selected) - } else { - stringResource(id = R.string.settings_wallpaper_summary) - } - - val wallpaperPicker = rememberLauncherForActivityResult( - ActivityResultContracts.PickVisualMedia() - ) { uri -> - if (uri != null) { - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { - try { - context.contentResolver.takePersistableUriPermission( - uri, - Intent.FLAG_GRANT_READ_URI_PERMISSION - ) - } catch (_: SecurityException) { - } - } - val uriString = uri.toString() - wallpaperPreferenceState.setWallpaper(uriString) - } - } - - SuperArrow( - title = stringResource(id = R.string.settings_wallpaper), - summary = summaryText, - leftAction = { - Icon( - Icons.Rounded.Palette, - modifier = Modifier.padding(end = 16.dp), - contentDescription = stringResource(id = R.string.settings_wallpaper), - tint = colorScheme.onBackground - ) - }, - onClick = { - wallpaperPicker.launch( - PickVisualMediaRequest(ActivityResultContracts.PickVisualMedia.ImageOnly) - ) - } - ) - - val wallpaperModes = listOf( - stringResource(id = R.string.settings_wallpaper_mode_fill), - stringResource(id = R.string.settings_wallpaper_mode_stretch), - stringResource(id = R.string.settings_wallpaper_mode_fit) - ) - - AnimatedVisibility(visible = wallpaperPreferenceState.isEnabled) { - Column( - modifier = Modifier - .fillMaxWidth() - .padding(horizontal = 16.dp, vertical = 12.dp) - ) { - Row( - modifier = Modifier.fillMaxWidth(), - horizontalArrangement = Arrangement.spacedBy(12.dp) - ) { - TextButton( - modifier = Modifier.weight(1f), - text = stringResource(id = R.string.settings_wallpaper_replace), - onClick = { - wallpaperPicker.launch( - PickVisualMediaRequest(ActivityResultContracts.PickVisualMedia.ImageOnly) - ) - } - ) - TextButton( - modifier = Modifier.weight(1f), - text = stringResource(id = R.string.settings_wallpaper_remove), - onClick = { - wallpaperPreferenceState.removeWallpaper() - } - ) - } - - Spacer(modifier = Modifier.height(12.dp)) - - SuperDropdown( - title = stringResource(id = R.string.settings_wallpaper_mode), - summary = stringResource(id = R.string.settings_wallpaper_mode_summary), - items = wallpaperModes, - leftAction = { - Icon( - Icons.Rounded.Palette, - modifier = Modifier.padding(end = 16.dp), - contentDescription = stringResource(id = R.string.settings_wallpaper_mode), - tint = colorScheme.onBackground - ) - }, - selectedIndex = wallpaperPreferenceState.scaleMode, - onSelectedIndexChange = { index -> - wallpaperPreferenceState.updateScaleMode(index) - } - ) - - Column( - modifier = Modifier - .fillMaxWidth() - .padding(top = 12.dp) - ) { - Text( - text = stringResource( - id = R.string.settings_wallpaper_opacity_label, - (wallpaperPreferenceState.sliderValue * 100).roundToInt() - ), - color = colorScheme.onBackground - ) - Slider( - modifier = Modifier - .fillMaxWidth() - .padding(top = 4.dp), - value = wallpaperPreferenceState.sliderValue, - onValueChange = wallpaperPreferenceState::onSliderChange, - valueRange = wallpaperPreferenceState.minAlpha..1f, - steps = 8, - colors = SliderDefaults.sliderColors( - thumbColor = colorScheme.primary, - ), - onValueChangeFinished = { - wallpaperPreferenceState.onSliderChangeFinished() - } - ) - } - } - } } } } } } - -@Composable -private fun rememberWallpaperPreferenceState( - prefs: SharedPreferences, - wallpaperAlphaMin: Float, - wallpaperEnabledAlpha: Float -): WallpaperPreferenceState { - val state = remember(prefs) { - WallpaperPreferenceState( - prefs = prefs, - initialUri = prefs.getString("wallpaper_uri", null), - initialScaleMode = prefs.getInt("wallpaper_scale_mode", 0), - initialAlpha = prefs.getFloat("wallpaper_alpha", wallpaperAlphaMin) - .coerceAtLeast(wallpaperAlphaMin), - initialMinAlpha = wallpaperAlphaMin, - initialEnabledAlpha = wallpaperEnabledAlpha - ) - } - LaunchedEffect(wallpaperAlphaMin, wallpaperEnabledAlpha) { - state.updateBounds(wallpaperAlphaMin, wallpaperEnabledAlpha) - } - return state -} - -@Stable -private class WallpaperPreferenceState( - private val prefs: SharedPreferences, - initialUri: String?, - initialScaleMode: Int, - initialAlpha: Float, - initialMinAlpha: Float, - initialEnabledAlpha: Float, -) { - var uri by mutableStateOf(initialUri) - private set - - val isEnabled: Boolean - get() = !uri.isNullOrBlank() - - var scaleMode by mutableIntStateOf(initialScaleMode) - private set - - var sliderValue by mutableFloatStateOf(initialAlpha) - private set - - var minAlpha by mutableFloatStateOf(initialMinAlpha) - private set - - var enabledAlpha by mutableFloatStateOf(initialEnabledAlpha) - private set - - private var persistedAlpha by mutableFloatStateOf(initialAlpha) - - fun onSliderChange(value: Float) { - sliderValue = value - } - - fun onSliderChangeFinished() { - setAlphaInternal(sliderValue) - } - - fun setWallpaper(uriString: String) { - uri = uriString - val targetAlpha = enabledAlpha.coerceAtLeast(minAlpha) - prefs.edit { - putString("wallpaper_uri", uriString) - putFloat("wallpaper_alpha", targetAlpha) - } - setAlphaInternal(targetAlpha, skipPersist = true) - } - - fun removeWallpaper() { - prefs.edit { - remove("wallpaper_uri") - putFloat("wallpaper_alpha", 1f) - } - uri = null - setAlphaInternal(1f, skipPersist = true) - } - - fun updateScaleMode(index: Int) { - scaleMode = index - prefs.edit { putInt("wallpaper_scale_mode", index) } - } - - fun updateBounds(min: Float, enabled: Float) { - val coercedMin = min.coerceIn(0f, 1f) - val coercedEnabled = enabled.coerceIn(coercedMin, 1f) - val alphaAdjusted = persistedAlpha.coerceAtLeast(coercedMin) - val needsAlphaUpdate = alphaAdjusted != persistedAlpha || coercedMin != minAlpha - minAlpha = coercedMin - enabledAlpha = coercedEnabled - if (sliderValue < coercedMin) { - sliderValue = coercedMin - } - if (needsAlphaUpdate) { - setAlphaInternal(alphaAdjusted, skipPersist = false) - } - } - - private fun setAlphaInternal(target: Float, skipPersist: Boolean = false) { - val coerced = target.coerceIn(minAlpha, 1f) - persistedAlpha = coerced - sliderValue = coerced - if (!skipPersist) { - prefs.edit { putFloat("wallpaper_alpha", coerced) } - } - } -} diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/settings/ToolsScreen.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/settings/ToolsScreen.kt index 81244804..edeb290a 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/screen/settings/ToolsScreen.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/screen/settings/ToolsScreen.kt @@ -53,8 +53,6 @@ import com.sukisu.ultra.ui.component.ConfirmResult import com.sukisu.ultra.ui.component.DynamicManagerCard import com.sukisu.ultra.ui.component.KsuIsValid import com.sukisu.ultra.ui.component.rememberConfirmDialog -import com.sukisu.ultra.ui.theme.wallpaperCardColors -import com.sukisu.ultra.ui.theme.wallpaperContainerColor import com.sukisu.ultra.ui.util.cleanRuntimeEnvironment import com.sukisu.ultra.ui.util.getUidMultiUserScan import com.sukisu.ultra.ui.util.readUidScannerFile @@ -103,7 +101,6 @@ fun Tools( val prefs = remember { context.getSharedPreferences("settings", Context.MODE_PRIVATE) } Scaffold( - containerColor = wallpaperContainerColor(), topBar = { TopAppBar( modifier = Modifier.hazeEffect(hazeState) { @@ -146,7 +143,6 @@ fun Tools( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { UidScannerSection(prefs = prefs, scope = scope, context = context) } @@ -157,7 +153,6 @@ fun Tools( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val lkmMode = Natives.isLkmMode if (lkmMode) { @@ -352,7 +347,6 @@ fun SelinuxToggleSection( modifier = Modifier .padding(top = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { val statusLabel = getSELinuxStatus() SuperSwitch( @@ -463,7 +457,6 @@ private fun AllowlistBackupSection( modifier = Modifier .padding(vertical = 12.dp) .fillMaxWidth(), - colors = wallpaperCardColors(), ) { SuperArrow( title = stringResource(R.string.allowlist_backup_title), diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/theme/CardManage.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/theme/CardManage.kt deleted file mode 100644 index acde2ac3..00000000 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/theme/CardManage.kt +++ /dev/null @@ -1,74 +0,0 @@ -package com.sukisu.ultra.ui.theme - -import androidx.compose.runtime.Composable -import androidx.compose.runtime.Stable -import androidx.compose.runtime.compositionLocalOf -import androidx.compose.ui.graphics.Color -import androidx.compose.ui.graphics.lerp -import top.yukonga.miuix.kmp.basic.CardDefaults -import top.yukonga.miuix.kmp.theme.MiuixTheme - -@Stable -data class WallpaperState( - val enabled: Boolean, - val surfaceAlpha: Float, - val transitionBlend: Float -) - -val LocalWallpaperState = compositionLocalOf { - WallpaperState( - enabled = false, - surfaceAlpha = 1f, - transitionBlend = 0f - ) -} - -@Composable -fun wallpaperContainerColor(): Color { - val wallpaperState = LocalWallpaperState.current - if (!wallpaperState.enabled) { - return MiuixTheme.colorScheme.surface - } - val base = MiuixTheme.colorScheme.surface - val adjustedAlpha = wallpaperState.surfaceAlpha.coerceIn(0f, 1f) - return base.copy(alpha = adjustedAlpha) -} - -@Composable -fun wallpaperSurfaceColor(base: Color = MiuixTheme.colorScheme.surface): Color { - val wallpaperState = LocalWallpaperState.current - if (!wallpaperState.enabled) { - return base - } - val alphaMultiplier = wallpaperState.surfaceAlpha.coerceIn(0f, 1f) - val dimOverlay = Color.Black.copy(alpha = 0.25f) - val tintedBase = lerp(base, dimOverlay, 0.15f) - return tintedBase.copy(alpha = tintedBase.alpha * alphaMultiplier) -} - -@Composable -fun wallpaperContentColor(): Color { - return MiuixTheme.colorScheme.onSurface -} - -@Composable -fun wallpaperTransitionAlpha( - enabledAlpha: Float, - disabledAlpha: Float = 1f -): Float { - val wallpaperState = LocalWallpaperState.current - val blend = wallpaperState.transitionBlend.coerceIn(0f, 1f) - val clampedEnabled = enabledAlpha.coerceIn(0f, 1f) - val clampedDisabled = disabledAlpha.coerceIn(0f, 1f) - return (clampedDisabled + (clampedEnabled - clampedDisabled) * blend) - .coerceIn(0f, 1f) -} - -@Composable -fun wallpaperCardColors( - background: Color = wallpaperSurfaceColor(), - content: Color = wallpaperContentColor(), -) = CardDefaults.defaultColors( - color = background, - contentColor = content, -) diff --git a/manager/app/src/main/java/com/sukisu/ultra/ui/theme/Theme.kt b/manager/app/src/main/java/com/sukisu/ultra/ui/theme/Theme.kt index fffb08ed..6aa58cf3 100644 --- a/manager/app/src/main/java/com/sukisu/ultra/ui/theme/Theme.kt +++ b/manager/app/src/main/java/com/sukisu/ultra/ui/theme/Theme.kt @@ -1,21 +1,8 @@ package com.sukisu.ultra.ui.theme -import android.net.Uri -import androidx.compose.foundation.Image -import androidx.compose.foundation.background import androidx.compose.foundation.isSystemInDarkTheme -import androidx.compose.foundation.layout.Box -import androidx.compose.foundation.layout.fillMaxSize import androidx.compose.runtime.Composable -import androidx.compose.runtime.CompositionLocalProvider -import androidx.compose.ui.Alignment -import androidx.compose.ui.Modifier import androidx.compose.ui.graphics.Color -import androidx.compose.ui.layout.ContentScale -import androidx.compose.ui.platform.LocalContext -import androidx.compose.ui.zIndex -import coil.compose.rememberAsyncImagePainter -import coil.request.ImageRequest import top.yukonga.miuix.kmp.theme.ColorSchemeMode import top.yukonga.miuix.kmp.theme.MiuixTheme import top.yukonga.miuix.kmp.theme.ThemeController @@ -24,9 +11,6 @@ import top.yukonga.miuix.kmp.theme.ThemeController fun KernelSUTheme( colorMode: Int = 0, keyColor: Color? = null, - wallpaperUri: String? = null, - wallpaperAlpha: Float = 1f, - wallpaperScaleMode: Int = 0, content: @Composable () -> Unit ) { val isDark = isSystemInDarkTheme() @@ -53,63 +37,6 @@ fun KernelSUTheme( } return MiuixTheme( controller = controller, - ) { - val context = LocalContext.current - val hasWallpaper = !wallpaperUri.isNullOrBlank() - val surfaceAlpha = if (hasWallpaper) wallpaperAlpha.coerceIn(0f, 1f) else 1f - val uri = wallpaperUri?.takeIf { it.isNotBlank() }?.let(Uri::parse) - - Box(modifier = Modifier.fillMaxSize(), contentAlignment = Alignment.Center) { - if (hasWallpaper && uri != null) { - val contentScale = when (wallpaperScaleMode) { - 1 -> ContentScale.FillBounds - 2 -> ContentScale.Fit - else -> ContentScale.Crop - } - Image( - modifier = Modifier.fillMaxSize(), - painter = rememberAsyncImagePainter( - ImageRequest.Builder(context) - .data(uri) - .crossfade(true) - .build() - ), - contentDescription = null, - contentScale = contentScale - ) - - val scrimBase = if (isDark) 0.25f else 0.05f - val scrimScale = if (isDark) 0.75f else 0.4f - val overlayAlpha = (scrimBase + (1f - surfaceAlpha) * scrimScale).coerceIn(0f, if (isDark) 0.85f else 0.45f) - if (overlayAlpha > 0f) { - val overlayColor = if (isDark) { - Color.Black.copy(alpha = overlayAlpha) - } else { - Color.White.copy(alpha = overlayAlpha * 0.6f) - } - Box( - modifier = Modifier - .fillMaxSize() - .background(overlayColor) - ) - } - } - - CompositionLocalProvider( - LocalWallpaperState provides WallpaperState( - enabled = hasWallpaper, - surfaceAlpha = surfaceAlpha, - transitionBlend = if (hasWallpaper) 1f else 0f - ) - ) { - Box( - modifier = Modifier - .fillMaxSize() - .zIndex(1f) - ) { - content() - } - } - } - } + content = content + ) } diff --git a/manager/app/src/main/res/values-ar/strings.xml b/manager/app/src/main/res/values-ar/strings.xml index 94be8106..7cf05306 100644 --- a/manager/app/src/main/res/values-ar/strings.xml +++ b/manager/app/src/main/res/values-ar/strings.xml @@ -5,6 +5,8 @@ إضغط للتثبيت يعمل الإصدار: %d + مستخدمين الجذر: %d + الإضافات: %d غير مدعوم KernelSU يدعم GKI kernels فقط إصدار النواة @@ -57,8 +59,12 @@ تشغيل الإفتراضي نموذج + موروث + عالمي + فردي مجموعات مُخصّص + تركيب مساحة الاسم الغاء تحميل الإضافات فشل تحديث ملف تعريف التطبيق لـ %s سياق SELinux @@ -83,6 +89,7 @@ معرف القالب غير صالح مزامنة القوالب عبر الإنترنت إنشاء قالب + للقراءة فقط استيراد / تصدير فشل في حفظ القالب تحرير القالب diff --git a/manager/app/src/main/res/values-az/strings.xml b/manager/app/src/main/res/values-az/strings.xml index 13e7f952..c274a847 100644 --- a/manager/app/src/main/res/values-az/strings.xml +++ b/manager/app/src/main/res/values-az/strings.xml @@ -1,11 +1,13 @@ Ana səhifə + Super istifadəçilər: %d Nüvə Yüklənmədi Yükləmək üçün toxunun İşləyir Versiya: %d + Modullar: %d Hal-hazırda KernelSU yalnız GKI nüvələrini dəstəkləyir Dəstəklənmir Yüklə @@ -55,6 +57,10 @@ Profil adı Bacarıqlar Modulları umount et + Miras qalmış + Qlobal + Bölmənin ad sahəsi + Fərdi Qruplar Defolt olaraq modulları umount et SELinux konteksi @@ -90,5 +96,6 @@ Yadda saxla Sil Şablonu göstər + Yalnız oxu Şablon ID-si artıq mövcuddur! diff --git a/manager/app/src/main/res/values-bn-rBD/strings.xml b/manager/app/src/main/res/values-bn-rBD/strings.xml index d03cee6f..9d8ddff7 100644 --- a/manager/app/src/main/res/values-bn-rBD/strings.xml +++ b/manager/app/src/main/res/values-bn-rBD/strings.xml @@ -6,6 +6,7 @@ মোডিউল ইনেবল করা যায়নি: %s ইন্সটল করটে চাপুন কাজ করছে + মোডিউল: %d অমূলক কর্নেল ম্যানেজার ভারসন @@ -20,6 +21,7 @@ রিবুট সেটিংস সফট রিবুট + গ্লোবাল গ্রুপস এসইলিনাক্স কন্টেক্সট %s এর জন্য অ্যাপ প্রফাইল আপডেট করা যায়নি @@ -30,6 +32,10 @@ মোডিউল ডিসেবল করা যায়নি: %s কোনো মোডিউল ইন্সটল করা নেই সংস্করণ: %d + সুপার ইউজার: %d + নেইম স্পেস মাউন্ট + ইনহেরিটেড + ইন্ডিভিজুয়াল ক্যাপাবিলিটিস আনমাউন্ট মোডিউলস রিকভারিতে বুট diff --git a/manager/app/src/main/res/values-bn/strings.xml b/manager/app/src/main/res/values-bn/strings.xml index 1a3121ef..83983ef7 100644 --- a/manager/app/src/main/res/values-bn/strings.xml +++ b/manager/app/src/main/res/values-bn/strings.xml @@ -5,6 +5,8 @@ ইনস্টল করার জন্য ক্লিক করুন ওয়ার্কিং ওয়ার্কিং সংস্করণ: %d + সুপার ইউজার: %d + মডিউল: %d অসমর্থিত KernelSU শুধুমাত্র GKI কার্নেল সমর্থন করে কার্নেল @@ -50,12 +52,15 @@ কার্নেলএসইউ বিনামূল্যে এবং ওপেন সোর্স, এবং সবসময় থাকবে। আপনি সবসময় একটি অনুদান দিয়ে আপনার কৃতজ্ঞতা প্রদর্শন করতে পারেন. আমাদের %2$s চ্যানেল মার্জ করুন]]> প্রফাইলের নাম + নেমস্পেস মাউন্ট গ্রুপস যোগ্যতা এসই লিনাক্স কনটেক্সট ডিফল্ট টেমপ্লেট কাস্টম + গ্লোবাল + আলাদাভাবে আনমাউন্ট মোডিউল ম্যানেজার সঠিকভাবে কাজ করার জন্য বর্তমান KernelSU সংস্করণ %d খুবই কম। অনুগ্রহ করে %d বা উচ্চতর সংস্করণে আপগ্রেড করুন! লগ সংরক্ষণ করুন diff --git a/manager/app/src/main/res/values-bs/strings.xml b/manager/app/src/main/res/values-bs/strings.xml index 8e4584f6..f91a9e53 100644 --- a/manager/app/src/main/res/values-bs/strings.xml +++ b/manager/app/src/main/res/values-bs/strings.xml @@ -1,5 +1,9 @@ + Imenski prostor nosača + Naslijeđen + Globalan + Pojedinačan Grupe Sposobnosti SELinux kontekst @@ -20,6 +24,8 @@ Početna Nije instalirano Kliknite da instalirate + Superkorisnici: %d + Module: %d Nepodržano KernelSU samo podržava GKI kernele sad Verzija Upravitelja diff --git a/manager/app/src/main/res/values-da/strings.xml b/manager/app/src/main/res/values-da/strings.xml index 418fd391..6e2fc02f 100644 --- a/manager/app/src/main/res/values-da/strings.xml +++ b/manager/app/src/main/res/values-da/strings.xml @@ -1,6 +1,7 @@ Arbejder + Moduler: %d Ikke understøttet Kernel-version KernelSU understøtter nu kun GKI-kerner. @@ -34,6 +35,9 @@ Join our %2$s channel]]> Standard Skabelon + Monter namespace + Arvet + Global Grupper Evner SELinux-kontext @@ -51,6 +55,7 @@ Version: %d Hjem Ikke installeret + Superbrugere: %d Fingeraftryk Ukendt Aktivering af modul fejlede: %s @@ -66,6 +71,7 @@ KernelSU er, og vil altid være, gratis og åben kildekode. Du kan dog vise os, at du holder af os, ved at give en donation. Brugerdefineret Profilnavn + Individuel Opdatering af App Profil for %s fejlede Den globale standardværdi for \"Umount moduler\" i App Profile. Hvis aktiveret, fjernes alle modulændringer til systemet for apps, der ikke har en profil angivet. Domæne @@ -90,6 +96,7 @@ Gem Slet Visningsskabelon + Skrivebeskyttet Skabelon-ID findes allerede! Import/Eksport Importér fra udklipsholder diff --git a/manager/app/src/main/res/values-de/strings.xml b/manager/app/src/main/res/values-de/strings.xml index 7723e5a7..6b78edb3 100644 --- a/manager/app/src/main/res/values-de/strings.xml +++ b/manager/app/src/main/res/values-de/strings.xml @@ -7,6 +7,7 @@ Version: %d Superuser Tippe zum Installieren + Superuser: %d Unbekannt Erzwingen In den Bootloader-Modus neustarten @@ -26,6 +27,9 @@ Vorlage Benutzerdefiniert App-Profilaktualisierung für %s fehlgeschlagen + Geerbt + Global + Individuell Domäne Aktualisieren Wenn du diese Option aktivierst, kann KernelSU alle von den Modulen für diese App geänderten Dateien wiederherstellen. @@ -36,6 +40,7 @@ Neue Version %s verfügbar, tippen zum Aktualisieren. Stopp erzwingen Neustarten + Module: %d Manager-Version SELinux Status Deaktiviert @@ -59,6 +64,7 @@ Neustarten, damit Änderungen wirksam werden Unserem %2$s-Kanal beitreten]]> Profilname + Namespace einhängen Gruppen Fähigkeiten Module aushängen @@ -83,6 +89,7 @@ Ungültige Vorlagen-ID Online-Vorlagen synchronisieren Vorlage erstellen + Schreibgeschützt Import/Export Schlug beim Speichern der Vorlage fehl Vorlage bearbeiten diff --git a/manager/app/src/main/res/values-es/strings.xml b/manager/app/src/main/res/values-es/strings.xml index f25f1ed0..dd3733c3 100644 --- a/manager/app/src/main/res/values-es/strings.xml +++ b/manager/app/src/main/res/values-es/strings.xml @@ -5,6 +5,8 @@ Haz clic para instalar Funcionando Versión: %d + Superusuarios: %d + Módulos: %d Sin soporte KernelSU solo admite kernels GKI por ahora Versión del kernel @@ -54,6 +56,10 @@ Plantilla Personalizado Nombre de perfil + Montaje del espacio de nombres + Heredado + Global + Individual Grupos Capacidades Contexto SELinux @@ -84,6 +90,7 @@ ID de plantilla no válida Sincronizar plantillas en línea Crear plantilla + Sólo lectura Importar/Exportar No se ha podido guardar la plantilla Editar plantilla diff --git a/manager/app/src/main/res/values-et/strings.xml b/manager/app/src/main/res/values-et/strings.xml index 1a830897..01b3534e 100644 --- a/manager/app/src/main/res/values-et/strings.xml +++ b/manager/app/src/main/res/values-et/strings.xml @@ -2,6 +2,7 @@ Töötamine Versioon: %d + Mooduleid: %d Tuum Manageri versioon Sõrmejälg @@ -18,6 +19,7 @@ Õpi KernelSUd https://kernelsu.org/guide/what-is-kernelsu.html Vaikimisi + Haagi nimeruum Lahtihaagitud moodulid Rakenduseprofiili uuendamine %s jaoks ebaõnnestus Haagi moodulid vaikimisi lahti @@ -26,6 +28,7 @@ Muuda malli Rakenduseprofiili mall ID + Vaid lugemiseks Malli ID juba eksisteerib! Ekspordi lõikelauale Sünkrooni võrgumallid @@ -34,6 +37,7 @@ Klõpsa paigaldamiseks Pole paigaldatud Mittetoetatud + Superkasutajaid: %d KernelSU toetab hetkel vaid GSI tuumasid SELinuxi olek Keelatud @@ -66,6 +70,9 @@ Vaata lähtekoodi %1$sis
Liitu meie %2$si kanaliga
Profiili nimi Kohandatud + Päritud + Globaalne + Individuaalne Võimekused Sobimatu malli ID SELinux kontekst diff --git a/manager/app/src/main/res/values-fa/strings.xml b/manager/app/src/main/res/values-fa/strings.xml index 8b6b6912..37db04e4 100644 --- a/manager/app/src/main/res/values-fa/strings.xml +++ b/manager/app/src/main/res/values-fa/strings.xml @@ -5,6 +5,8 @@ برای نصب ضربه بزنید به درستی کار می‌کند نسخه: %d + برنامه های با دسترسی روت: %d + ماژول‌ها: %d پشتیبانی نشده کرنل اس یو فقط هسته های gki را پشتیبانی میکند هسته @@ -56,6 +58,10 @@ قالب شخصی سازی شده اسم پروفایل + Mount namespace + اثر گرفته + گلوبال + تکی جداکردن ماژول ها ذخیره گزارش‌ها
diff --git a/manager/app/src/main/res/values-fil/strings.xml b/manager/app/src/main/res/values-fil/strings.xml index b233727d..06eea427 100644 --- a/manager/app/src/main/res/values-fil/strings.xml +++ b/manager/app/src/main/res/values-fil/strings.xml @@ -10,6 +10,7 @@ Gumagana Bersyon: %d Hindi matukoy + Mga Modyul: %d Hindi Suportado Sinusuportahan lamang ng KernelSU ang mga GKI na kernel Nabigong paganahin ang module: %s @@ -37,6 +38,8 @@ Suportahan Kami Ang KernelSU ay, at palaging magiging, libre, at open source. Gayunpaman, maaari mong ipakita sa amin na nagmamalasakit ka sa pamamagitan ng pagbibigay ng donasyon. Sumali sa aming %2$s channel]]> + I-mount ang namespace + Indibidwal Mga Grupo Mga Kakayanan Konteksto ng SELinux @@ -60,8 +63,10 @@ I-uninstall Itago ang mga application ng system Pangalan ng profile + Minana Ang pangkalahatang default na halaga para sa \"Umount modules\" sa Mga Profile ng App. Kung pinagana, aalisin nito ang lahat ng mga pagbabago sa modyul sa system para sa mga aplikasyon na walang hanay ng Profile. I-save ang mga Log + Mga Superuser: %d Bersyon ng kernel Fingerprint Superuser @@ -74,6 +79,7 @@ Default Template Pasadya + Global I-unmount ang mga module bilang default Domain I-update @@ -90,6 +96,7 @@ I-save Burahin Tignan ang template + Read only Umiiral na ang Template ID! I-import/I-export Mag-import mula sa clipboard diff --git a/manager/app/src/main/res/values-fr/strings.xml b/manager/app/src/main/res/values-fr/strings.xml index 9ba6ad96..eb56e969 100644 --- a/manager/app/src/main/res/values-fr/strings.xml +++ b/manager/app/src/main/res/values-fr/strings.xml @@ -3,6 +3,8 @@ Non installé Fonctionnel Version : %d + Super-utilisateurs : %d + Modules : %d KernelSU ne prend désormais en charge que les noyaux GKI Version du noyau Empreinte digitale @@ -53,7 +55,11 @@ Par défaut Personnalisé Nom du profil + Espace de noms de montage + Hérité + Individuel Contexte SELinux + Global Groupes Capacités Démonter les modules @@ -83,6 +89,7 @@ ID de modèle invalide Synchroniser les modèles en ligne Créer un modèle + Lecture seule Importer/exporter Échec de l\'enregistrement du modèle Modifier le modèle diff --git a/manager/app/src/main/res/values-hi/strings.xml b/manager/app/src/main/res/values-hi/strings.xml index 020c13fb..da541809 100644 --- a/manager/app/src/main/res/values-hi/strings.xml +++ b/manager/app/src/main/res/values-hi/strings.xml @@ -9,19 +9,24 @@ लॉग भेजे डिसेबल्ड (बंद) हमें प्रोत्साहन दें + Inherited मॉड्यूल बंद कर दिए गए हैं क्योंकि यह मैजिक के साथ टकरा रहे है! क्या बदलाव हुए है पर्मिसिव डाउनलोड में रिबूट करें डिफ़ॉल्ट रूप से मॉड्यूल अनमाउन्ट करें इस विकल्प को चालू करने से KernelSU को इस एप्लिकेशन के लिए मॉड्यूल द्वारा किसी भी मोडिफाइड फ़ाइल को रिस्टोर करें। + Individual %s मॉड्यूल चालू करने में विफल जबर्दस्ती बंद करें EDL मोड में रिबूट करें फिर से चालू करें क्षमताएं + सुपरयूजर : %d %s की डाउनलोडिंग स्टार्ट करें + Global ऐप प्रोफाइल में \"अनमाउंट मॉड्यूल\" के लिए ग्लोबल डिफ़ॉल्ट वैल्यू। यदि चालू किया गया है, तो यह एप्लीकेशंस के लिऐ सिस्टम के सभी मॉड्यूल मोडिफिकेशन को हटा देगा जिनकी प्रोफ़ाइल सेट नहीं है। + मॉड्यूल्स : %d एनफोर्सिंग SELinux context फिंगरप्रिंट @@ -34,6 +39,7 @@ प्रोफाइल का नाम KernelSU मुफ़्त और ओपन सोर्स और हमेशा रहेगा। हालाँकि आप दान देकर हमें दिखा सकते हैं कि आप संरक्षण करते हैं। अनइंस्टॉल करें + Namspace माउंट करें इंस्टाल करें इंस्टाल करने के लिए क्लिक करें नियम diff --git a/manager/app/src/main/res/values-hr/strings.xml b/manager/app/src/main/res/values-hr/strings.xml index 9e113a0b..b6aae406 100644 --- a/manager/app/src/main/res/values-hr/strings.xml +++ b/manager/app/src/main/res/values-hr/strings.xml @@ -11,6 +11,8 @@ Verzija: %d Kliknite da instalirate Radi + Superkorisnici: %d + Moduli: %d Nepodržano KernelSU sada samo podržava GKI kernele Verzija kernela @@ -54,7 +56,11 @@ Šablon Prilagođeno Naziv profila + Naslijeđen + Imenski prostor nosača Ažuriranje Profila Aplikacije za %s nije uspjelo + Globalan + Pojedinačan Umount module Grupe Sposobnosti @@ -88,6 +94,7 @@ Spremi Izbriši Prikaži predložak + Samo za čitanje ID predloška već postoji! Uvoz/Izvoz Uvezi iz međuspremnika diff --git a/manager/app/src/main/res/values-hu/strings.xml b/manager/app/src/main/res/values-hu/strings.xml index f5167b56..a31b5f1f 100644 --- a/manager/app/src/main/res/values-hu/strings.xml +++ b/manager/app/src/main/res/values-hu/strings.xml @@ -2,6 +2,7 @@ Működik Verzió: %d + Modulok: %d A KernelSU jelenleg csak GKI kerneleket támogat Kernel Alkalmazás verziója @@ -26,7 +27,10 @@ Sablon Egyedi Profil neve + Névtér csatlakoztatása + Örökölt https://kernelsu.org/guide/what-is-kernelsu.html + Különálló Csoportok Jogosultságok SELinux kontextus @@ -43,6 +47,7 @@ Kezdőlap Nincs telepítve Kattintson a telepítéshez + Engedélyezett alkalmazások: %d Nem támogatott SELinux állapot Kényszerített @@ -66,6 +71,7 @@ Naplók küldése Indítsa újra a készüléket a változások érvényesítéséhez A KernelSU ingyenes, nyílt forráskódú és mindig is az lesz. Ön azonban adományozással megmutathatja, hogy törődik a projekttel. + Globális Modulok leválasztása Nem sikerült frissíteni az App Profilt ehhez: %s A \"Modulok leválasztása\" globális alapértelmezett értéke az App Profile-ban. Ha engedélyezve van, eltávolít minden modulmódosítást a rendszerből azon alkalmazások esetében, amelyeknek nincs profilja beállítva. @@ -83,6 +89,7 @@ Hibás sablon ID Online sablonok szinkronizálása Sablon készítése + Csak olvasható Import/Export A sablon mentése sikertelen Sablon szerkesztése diff --git a/manager/app/src/main/res/values-in/strings.xml b/manager/app/src/main/res/values-in/strings.xml index efba066b..759eb50e 100644 --- a/manager/app/src/main/res/values-in/strings.xml +++ b/manager/app/src/main/res/values-in/strings.xml @@ -5,6 +5,8 @@ Klik untuk menginstal Berfungsi Versi: %d + SuperUser: %d + Modul: %d Tidak didukung KernelSU saat ini hanya mendukung kernel GKI. Versi kernel @@ -54,6 +56,10 @@ Templat Khusus Nama profil + Gunakan Namespace + Diwariskan + Universal + Individual Kelompok Kemampuan Konteks SELinux @@ -95,6 +101,7 @@ Hapus Papan klip kosong! Lihat templat + readonly Debugging WebView Dapat digunakan untuk mendebug antarmuka web (WebUI). Harap aktifkan hanya saat diperlukan. %1$s image partisi terekomendasi diff --git a/manager/app/src/main/res/values-it/strings.xml b/manager/app/src/main/res/values-it/strings.xml index b6d87848..6ed4692a 100644 --- a/manager/app/src/main/res/values-it/strings.xml +++ b/manager/app/src/main/res/values-it/strings.xml @@ -5,6 +5,8 @@ Clicca per installare In esecuzione Versione: %d + Applicazioni con accesso root: %d + Moduli installati: %d Non supportato KernelSU ora supporta solo i kernel GKI Kernel @@ -50,7 +52,11 @@ KernelSU è, e sempre sarà, gratuito e open source. Puoi comunque mostrarci il tuo apprezzamento facendo una donazione. Unisciti al nostro canale %2$s]]> Nome profilo + Spazio dei nomi del mount + Globale Gruppi + Ereditato + Individuale Predefinito Personalizzato Modello @@ -79,6 +85,7 @@ Identificativo modello non valido Nome Visualizza modello + Sola lettura L\'identificatore del modello è già in uso! Importa/Esporta Importa dagli appunti diff --git a/manager/app/src/main/res/values-iw/strings.xml b/manager/app/src/main/res/values-iw/strings.xml index c06a497f..f0ff9fe8 100644 --- a/manager/app/src/main/res/values-iw/strings.xml +++ b/manager/app/src/main/res/values-iw/strings.xml @@ -9,19 +9,24 @@ שלח לוג מושבת תמכו בנו + ירושה מודולים מושבתים מכיוון שהם מתנגשים עם זה של Magisk! יומן שינויים התרים הפעלה מחדש למצב הורדה טעינת מודולים כברירת מחדל הפעלת אפשרות זו תאפשר ל-KernelSU לשחזר קבצים שהשתנו על ידי המודולים עבור יישום זה. + אישי הפעלת המודל נכשלה: %s עצירה בכח הפעלה מחדש למצב EDL איתחול יכולת + משתמשי על: %d מפעיל מודל: %s + גלובלי ערך ברירת המחדל הגלובלי עבור \"טעינת מודולים\" בפרופילי אפליקציה. אם מופעל, זה יסיר את כל שינויי המודול למערכת עבור יישומים שאין להם ערכת פרופיל. + מודלים:%d אכיפה הקשר SELinux טביעת אצבע @@ -34,6 +39,7 @@ שם פרופיל KernelSU הוא, ותמיד יהיה, חינמי וקוד פתוח. עם זאת, תוכל להראות לנו שאכפת לך על ידי תרומה. הסרה + טעינת מרחב שמות התקנה לחץ להתקנה כללים diff --git a/manager/app/src/main/res/values-ja/strings.xml b/manager/app/src/main/res/values-ja/strings.xml index d7369a2f..7bbef90a 100644 --- a/manager/app/src/main/res/values-ja/strings.xml +++ b/manager/app/src/main/res/values-ja/strings.xml @@ -5,6 +5,8 @@ タップでインストール 動作中 バージョン: %d + スーパーユーザー: %d + モジュール: %d 非対応 現在、 KernelSU は GKI カーネルにのみ対応しています カーネル @@ -54,6 +56,10 @@ テンプレート カスタム プロファイル名 + 名前空間のマウント + 継承 + 共通 + 分離 モジュールのアンマウント グループ SELinux コンテキスト @@ -84,6 +90,7 @@ 無効なテンプレート ID オンラインテンプレートの同期 テンプレートの作成 + 読み取り専用 インポート/エクスポート テンプレートの保存に失敗しました テンプレートの編集 diff --git a/manager/app/src/main/res/values-kn/strings.xml b/manager/app/src/main/res/values-kn/strings.xml index 18af6da0..3964f203 100644 --- a/manager/app/src/main/res/values-kn/strings.xml +++ b/manager/app/src/main/res/values-kn/strings.xml @@ -8,17 +8,22 @@ Umount ಮಾಡ್ಯೂಲ್‌ಗಳು ಲಾಗ್ ಕಳುಹಿಸಿ ನಮ್ಮನ್ನು ಬೆಂಬಲಿಸಿ + ಪಿತ್ರಾರ್ಜಿತ ಮಾಡ್ಯೂಲ್‌ಗಳನ್ನು ನಿಷ್ಕ್ರಿಯಗೊಳಿಸಲಾಗಿದೆ ಏಕೆಂದರೆ ಇದು ಮ್ಯಾಜಿಸ್ಕ್‌ನೊಂದಿಗೆ ಸಂಘರ್ಷವಾಗಿದೆ! ಚೇಂಜ್ಲಾಗ್ Permissive ಡೀಫಾಲ್ಟ್ ಆಗಿ Umount ಮಾಡ್ಯೂಲ್ ಈ ಆಯ್ಕೆಯನ್ನು ಸಕ್ರಿಯಗೊಳಿಸುವುದರಿಂದ ಈ ಅಪ್ಲಿಕೇಶನ್‌ಗಾಗಿ ಮಾಡ್ಯೂಲ್‌ಗಳ ಮೂಲಕ ಯಾವುದೇ ಮಾರ್ಪಡಿಸಿದ ಫೈಲ್‌ಗಳನ್ನು ಮರುಸ್ಥಾಪಿಸಲು KernelSU ಗೆ ಅನುಮತಿಸುತ್ತದೆ. + ವೈಯಕ್ತಿಕ ಮಾಡ್ಯೂಲ್ ಅನ್ನು ಸಕ್ರಿಯಗೊಳಿಸಲು ವಿಫಲವಾಗಿದೆ: %s ಫೋರ್ಸ್ ಸ್ಟಾಪ್ EDL ಗೆ ರೀಬೂಟ್ ಸಾಮರ್ಥ್ಯಗಳು + ಸೂಪರ್‌ಯೂಸರ್‌ಗಳು: %d ಡೌನ್‌ಲೋಡ್ ಮಾಡುವುದನ್ನು ಪ್ರಾರಂಭಿಸಿ: %s + ಜಾಗತಿಕ ಅಪ್ಲಿಕೇಶನ್ ಪ್ರೊಫೈಲ್‌ಗಳಲ್ಲಿ \"Umount ಮಾಡ್ಯೂಲ್\" ಗಾಗಿ ಜಾಗತಿಕ ಡೀಫಾಲ್ಟ್ ಮೌಲ್ಯ. ಸಕ್ರಿಯಗೊಳಿಸಿದರೆ, ಪ್ರೊಫೈಲ್ ಸೆಟ್ ಅನ್ನು ಹೊಂದಿರದ ಅಪ್ಲಿಕೇಶನ್‌ಗಳಿಗಾಗಿ ಸಿಸ್ಟಮ್‌ಗೆ ಎಲ್ಲಾ ಮಾಡ್ಯೂಲ್ ಮಾರ್ಪಾಡುಗಳನ್ನು ಇದು ತೆಗೆದುಹಾಕುತ್ತದೆ. + ಮಾಡ್ಯೂಲ್‌ಗಳು: %d SELinux ಸಂದರ್ಭ ಡೀಫಾಲ್ಟ್ ಲಾಂಚ್ @@ -28,6 +33,7 @@ ಪ್ರೊಫೈಲ್ ಹೆಸರು KernelSU ಉಚಿತ ಮತ್ತು ಮುಕ್ತ ಮೂಲವಾಗಿದೆ ಮತ್ತು ಯಾವಾಗಲೂ ಇರುತ್ತದೆ. ಆದಾಗ್ಯೂ ನೀವು ದೇಣಿಗೆ ನೀಡುವ ಮೂಲಕ ನೀವು ಕಾಳಜಿ ವಹಿಸುತ್ತೀರಿ ಎಂದು ನಮಗೆ ತೋರಿಸಬಹುದು. ಅನ್‌ಇನ್‌ಸ್ಟಾಲ್ + ಮೌಂಟ್ ನೇಮ್‌ಸ್ಪೇಸ್ ನಿಯಮಗಳು ಗುಂಪುಗಳು ಮಾಡ್ಯೂಲ್ diff --git a/manager/app/src/main/res/values-ko/strings.xml b/manager/app/src/main/res/values-ko/strings.xml index 75788060..9419ad38 100644 --- a/manager/app/src/main/res/values-ko/strings.xml +++ b/manager/app/src/main/res/values-ko/strings.xml @@ -5,6 +5,8 @@ 이 곳을 눌러 설치하기 작동 중 버전: %d + 슈퍼유저: %d개 + 모듈: %d개 지원되지 않음 KernelSU는 현재 GKI 커널만 지원합니다. 커널 버전 @@ -59,6 +61,10 @@ 사용자 지정 템플릿 프로필 이름 + 마운트할 네임스페이스 + 상속 + 전역 + 개별 사용자 그룹 모듈 마운트 해제 SELinux 컨텍스트 @@ -100,6 +106,7 @@ 설명 저장 삭제 + 읽기 전용 템플릿 ID가 이미 존재합니다! 불러오기/내보내기 클립보드에서 불러오기 diff --git a/manager/app/src/main/res/values-lt/strings.xml b/manager/app/src/main/res/values-lt/strings.xml index 59e25272..5b879cdb 100644 --- a/manager/app/src/main/res/values-lt/strings.xml +++ b/manager/app/src/main/res/values-lt/strings.xml @@ -35,6 +35,10 @@ Šablonas Pasirinktinis Profilio pavadinimas + Prijungti vardų erdvę + Paveldėtas + Globalus + Individualus Grupės Galimybės SELinux kontekstas @@ -56,8 +60,10 @@ KernelSU dabar palaiko tik GKI branduolius Spustelėkite norėdami įdiegti Veikia + Supernaudotojai: %d Versija: %d Nepalaikoma + Moduliai: %d Tvarkyklės versija Branduolys SELinux statusas diff --git a/manager/app/src/main/res/values-lv/strings.xml b/manager/app/src/main/res/values-lv/strings.xml index c4ae7296..27d6a36a 100644 --- a/manager/app/src/main/res/values-lv/strings.xml +++ b/manager/app/src/main/res/values-lv/strings.xml @@ -14,6 +14,8 @@ Noklikšķiniet, lai uzstādītu Darbojas Versija: %d + Superlietotāji: %d + Moduļi: %d Neatbalstīts KernelSU pagaidām atbalsta tikai GKI kodolus Kodols @@ -54,6 +56,8 @@ Veidne Pielāgots Profila vārds + Mount nosaukumvieta + Individuāls Iespējas SELinux konteksts Atvienot moduļus @@ -79,6 +83,7 @@ Saglabāt Dzēst Skatīt veidni + tikai lasīt Importēt/Eksportēt Nevar atrast vietējo eksportējamo veidni! Neizdevās saglabāt veidni @@ -93,10 +98,12 @@ Moduļi nav pieejami dēļ konflikta ar Magisk! KernelSU ir un vienmēr būs bezmaksas un atvērtā koda. Tomēr jūs varat parādīt mums, ka jums rūp, veicot ziedojumu. Grupas + Globāli Pašreizējā KernelSU versija %d ir pārāk zema, lai pārvaldnieks darbotos pareizi. Lūdzu, atjauniniet uz versiju %d vai jaunāku! Iespējot WebView atkļūdošanu Ieteicams %1$s nodalījuma attēls Nākamais + Mantots Izvēlieties failu Instalēt neaktīvajā slotā (pēc OTA) Pēc restartēšanas jūsu ierīce tiks **PIESPIESTI** palaista pašreizējā neaktīvajā slotā! diff --git a/manager/app/src/main/res/values-mr/strings.xml b/manager/app/src/main/res/values-mr/strings.xml index 243ae427..43bd5878 100644 --- a/manager/app/src/main/res/values-mr/strings.xml +++ b/manager/app/src/main/res/values-mr/strings.xml @@ -5,6 +5,8 @@ इंस्टॉल साठी क्लिक करा कार्यरत आवृत्ती: %d + मॉड्यूल्स: %d + सुपरयूझर: %d असमर्थित KernelSU आता फक्त GKI कर्नलचे समर्थन करते कर्नल @@ -49,11 +51,15 @@ KernelSU विनामूल्य आणि मुक्त स्रोत आहे, आणि नेहमीच असेल. तथापि, देणगी देऊन तुम्ही आम्हाला दाखवू शकता की तुमची काळजी आहे. आम्हाला पाठिंबा द्या कस्टम + माउंट नेमस्पेस डीफॉल्ट साचा + वैयक्तिक क्षमता %1$s वर स्रोत कोड पहा
आमच्या %2$s चॅनेलमध्ये सामील व्हा
प्रोफाइल नाव + इनहेरीटेड + जागतिक गट SELinux संदर्भ उमाउंट मॉड्यूल्स diff --git a/manager/app/src/main/res/values-ms/strings.xml b/manager/app/src/main/res/values-ms/strings.xml index ed2601c1..67215ee7 100644 --- a/manager/app/src/main/res/values-ms/strings.xml +++ b/manager/app/src/main/res/values-ms/strings.xml @@ -6,6 +6,8 @@ Reboot ke Download Modul tidak berjaya diaktifkan: %s Reboot ke EDL + Superusers: %d + Modul: %d Enforcing Cap Jari Reboot ke Recovery diff --git a/manager/app/src/main/res/values-nl/strings.xml b/manager/app/src/main/res/values-nl/strings.xml index af6ca2dc..02a35922 100644 --- a/manager/app/src/main/res/values-nl/strings.xml +++ b/manager/app/src/main/res/values-nl/strings.xml @@ -5,6 +5,8 @@ Klik om te installeren Werkend Versie: %d + Supergebruikers: %d + Modules: %d Niet ondersteund KernelSU ondersteunt alleen GKI kernels Kernel version @@ -54,6 +56,10 @@ Sjabloon Aangepast Profiel naam + Koppel naamruimte + Overgenomen + Globaal + Individuëel Groepen Mogelijkheden SELinux context @@ -85,6 +91,7 @@ Beschrijving Beheer lokale en online sjabloon van app-profiel. Verwijderen + Alleen lezen Sjabloon ID bestaat al! Synchroniseer online-sjablonen Mislukt naar opslaan sjabloon diff --git a/manager/app/src/main/res/values-pl/strings.xml b/manager/app/src/main/res/values-pl/strings.xml index 842eba10..5cf08e0b 100644 --- a/manager/app/src/main/res/values-pl/strings.xml +++ b/manager/app/src/main/res/values-pl/strings.xml @@ -6,6 +6,8 @@ Kliknij, aby zainstalować Działa Wersja: %d + Superużytkownicy: %d + Moduły: %d Nieobsługiwany KernelSU obsługuje obecnie tylko jądra GKI. Wersja jądra @@ -55,6 +57,10 @@ Szablon Własny Nazwa profilu + Przestrzeń nazw montowania + Odziedziczona + Globalna + Indywidualna Grupy Uprawnienia Kontekst SELinux @@ -92,6 +98,7 @@ Opis Zapisz Usuń + Tylko do odczytu Importuj/Eksportuj Importuj ze schowka Eksportuj do schowka diff --git a/manager/app/src/main/res/values-pt-rBR/strings.xml b/manager/app/src/main/res/values-pt-rBR/strings.xml index 7fce8c4b..ec408eed 100644 --- a/manager/app/src/main/res/values-pt-rBR/strings.xml +++ b/manager/app/src/main/res/values-pt-rBR/strings.xml @@ -5,6 +5,8 @@ Clique para instalar Em execução Versão: %d + SuperUsuários: %d + Módulos: %d Sem suporte KernelSU suporta apenas kernels GKI agora Versão do kernel @@ -54,6 +56,10 @@ Modelo Personalizado Nome do perfil + Montar namespace + Herdado + Global + Individual Grupos Capacidades Contexto do SELinux @@ -84,6 +90,7 @@ ID do modelo inválido Sincronizar modelos online Criar modelo + Somente leitura Importar/Exportar Falha ao salvar o modelo Editar modelo diff --git a/manager/app/src/main/res/values-pt/strings.xml b/manager/app/src/main/res/values-pt/strings.xml index 6ea50705..0a3c19ef 100644 --- a/manager/app/src/main/res/values-pt/strings.xml +++ b/manager/app/src/main/res/values-pt/strings.xml @@ -4,6 +4,8 @@ Início Clique para instalar Funcionando + Super Usuário: %d + Módulos: %d Versão: %d Kernel Instalar @@ -43,10 +45,14 @@ Aprenda a instalar o KernelSU e usar os módulos O KernelSU é, e sempre será, gratuito e de código aberto. No entanto, você pode nos mostrar que se importa fazendo uma doação. Veja o código-fonte em %1$s
Junte-se ao nosso canal %2$s
+ Individual + Global + Herdado Padrão Modelo Personalizado Nome do perfil + Montar namespace Modo de segurança Reinicie para entrar em vigor Aprender KernelSU diff --git a/manager/app/src/main/res/values-ro/strings.xml b/manager/app/src/main/res/values-ro/strings.xml index 7187661e..42e0b439 100644 --- a/manager/app/src/main/res/values-ro/strings.xml +++ b/manager/app/src/main/res/values-ro/strings.xml @@ -5,6 +5,8 @@ Click pentru a instala Funcționează Versiune: %d + Super-utilizatori: %d + Module: %d Necompatibil KernelSU suportă doar nuclee GKI acum Nucleu @@ -53,6 +55,10 @@ Șablon Personalizat Nume profil + Montare spațiu de nume + Moștenit + Global + Individual Grupuri Capabilități Context SELinux @@ -83,6 +89,7 @@ ID șablon nevalid Sincronizează șabloanele online Creează un șablon + doar citire Import/Export Nu s-a salvat șablonul Editează șablonul diff --git a/manager/app/src/main/res/values-ru/strings.xml b/manager/app/src/main/res/values-ru/strings.xml index 5024a6f7..e2fb20e7 100644 --- a/manager/app/src/main/res/values-ru/strings.xml +++ b/manager/app/src/main/res/values-ru/strings.xml @@ -5,7 +5,9 @@ Нажмите, чтобы установить Работает Версия: %d + Суперпользователи: %d + Модули: %d Не поддерживается KernelSU поддерживает только GKI ядра. Версия ядра @@ -57,6 +59,10 @@ Шаблон Пользовательский Название профиля + Монтировать пространство имен + Унаследованный + Глобальный + Индивидуальный Группы Возможности Контекст SELinux @@ -87,6 +93,7 @@ Неверный ID шаблона Синхронизировать онлайн-шаблоны Создать шаблон + Только чтение Импорт/Экспорт Не удалось сохранить шаблон Редактирование шаблона diff --git a/manager/app/src/main/res/values-sl/strings.xml b/manager/app/src/main/res/values-sl/strings.xml index 0f2e16f0..2486a425 100644 --- a/manager/app/src/main/res/values-sl/strings.xml +++ b/manager/app/src/main/res/values-sl/strings.xml @@ -3,6 +3,7 @@ Klikni za namestitev V obdelavi Verzija: %d + Superuporabniki: %d KernelSU podpira samo GKI kernele Kernel Verzija upravitelja @@ -31,6 +32,10 @@ Glej odprto kodo na %1$s
Pridružite se našem %2$s kanalu
Privzeto Predloga + Imenski prostor vmestitve + Podedovano + Globalno + Pozameznik Zmožnosti Izvrzi module Po privzetem izvrzi module @@ -42,6 +47,7 @@ Dnevnik sprememb Predloga za aplikacijski profil Domov + Moduli: %d Ne podpira SuperUporabnik Napaka pri omogočanju modula: %s @@ -80,6 +86,7 @@ Opis Shrani Odstrani + le za branje id predloge že obstaja! Uvoz iz odložišča Izvoz v odložišče diff --git a/manager/app/src/main/res/values-sr/strings.xml b/manager/app/src/main/res/values-sr/strings.xml index 5ede2b29..73920b6f 100644 --- a/manager/app/src/main/res/values-sr/strings.xml +++ b/manager/app/src/main/res/values-sr/strings.xml @@ -1,5 +1,7 @@ + Superkorisnici + Moduli: %d Додирните да бисте инсталирали Почетна Није инсталирано diff --git a/manager/app/src/main/res/values-te/strings.xml b/manager/app/src/main/res/values-te/strings.xml index 1263f9c5..9887318f 100644 --- a/manager/app/src/main/res/values-te/strings.xml +++ b/manager/app/src/main/res/values-te/strings.xml @@ -15,5 +15,7 @@ ఇన్‌స్టాల్ చేయడానికి క్లిక్ చేయండి పని చేస్తోంది వెర్షన్: %d + సూపర్‌యూజర్‌లు: %d + మాడ్యూల్స్: %d లాగ్‌లు సేవ్ చేయండి diff --git a/manager/app/src/main/res/values-th/strings.xml b/manager/app/src/main/res/values-th/strings.xml index f513e883..21a5120e 100644 --- a/manager/app/src/main/res/values-th/strings.xml +++ b/manager/app/src/main/res/values-th/strings.xml @@ -6,6 +6,8 @@ กำลังทำงาน เวอร์ชัน: %d เวอร์ชันตัวจัดการ + สิทธิ์ผู้ใช้ขั้นสูง: %d + โมดูล: %d ไม่รองรับ Enforcing รีบูตเข้าสู่โหมดกู้คืน @@ -53,6 +55,10 @@ ค่าเริ่มต้น เทมเพลต ชื่อโปรไฟล์ + Mount เนมสเปซ + ทั่วไป + สืบทอด + ส่วนบุคคล หมวดหมู่ ความสามารถของแอป การเปิดใช้งานตัวเลือกนี้จะทำให้ KernelSU สามารถกู้คืนไฟล์ที่แก้ไขโดยโมดูลสำหรับแอปนี้ได้ @@ -82,6 +88,7 @@ ไอดีเทมเพลตไม่ถูกต้อง ซิงค์เทมเพลตออนไลน์ สร้างเทมเพลต + อ่านเท่านั้น นำเข้า/ส่งออก ไม่สามารถบันทึกเทมเพลต แก้ไขเทมเพลต diff --git a/manager/app/src/main/res/values-tr/strings.xml b/manager/app/src/main/res/values-tr/strings.xml index 43551f2f..e050a20c 100644 --- a/manager/app/src/main/res/values-tr/strings.xml +++ b/manager/app/src/main/res/values-tr/strings.xml @@ -6,6 +6,8 @@ Kurmak için tıklayın Çalışıyor Sürüm: %d + Süper kullanıcılar: %d + Modüller: %d Desteklenmiyor KernelSU şimdilik sadece GKI çekirdeklerini destekliyor Çekirdek Versiyonu @@ -55,6 +57,10 @@ Şablon Özel Profil adı + Ad alanını bağla + Kalıtsal + Küresel + Bireysel Gruplar Yetkinlikler SELinux içeriği @@ -86,6 +92,7 @@ Kaydet Sil Şablonu görüntüle + Salt okunur Şablon kimliği zaten var! İçe aktar/Dışa aktar Panodan içe aktar diff --git a/manager/app/src/main/res/values-uk/strings.xml b/manager/app/src/main/res/values-uk/strings.xml index 7ca3ac0f..fda89aba 100644 --- a/manager/app/src/main/res/values-uk/strings.xml +++ b/manager/app/src/main/res/values-uk/strings.xml @@ -5,6 +5,8 @@ Натисніть щоб встановити Працює Версія: %d + Суперкористувачі: %d + Модулі: %d Не підтримується KernelSU зараз підтримує лише ядра GKI. Версія ядра @@ -54,6 +56,10 @@ Шаблон Власний Назва профілю + Змонтувати простір імен + Наслідуваний + Глобальний + Індивідуальний Групи Можливості Контекст SELinux @@ -84,6 +90,7 @@ Недійсний ідентифікатор шаблону Синхронізувати мережеві шаблони Створити шаблон + Тільки для читання Імпорт/Експорт Помилка при збереженні шаблону Редагувати шаблон diff --git a/manager/app/src/main/res/values-vi/strings.xml b/manager/app/src/main/res/values-vi/strings.xml index d7e1a363..a9b261d2 100644 --- a/manager/app/src/main/res/values-vi/strings.xml +++ b/manager/app/src/main/res/values-vi/strings.xml @@ -63,13 +63,19 @@ Chế độ an toàn Khởi động lại để có hiệu lực https://kernelsu.org/guide/what-is-kernelsu.html + Superusers: %d + Modules: %d Tên miền Quy tắc Khởi chạy Khởi động lại + Không gian tên Tính tương thích Cập nhật quy tắc SELinux cho %s thất bại Buộc dừng + Thừa hưởng + Toàn cục + Riêng biệt Bối cảnh SELinux Umount modules Phiên bản KernelSU hiện tại %d quá thấp để trình quản lý hoạt động bình thường. Vui lòng cập nhật lên phiên bản %d hoặc cao hơn! @@ -94,6 +100,7 @@ Xóa Bộ nhớ tạm đang trống! Xem mẫu + Chỉ đọc ID Gỡ lỗi WebView Có thể sử dụng để gỡ lỗi WebUI. Vui lòng chỉ bật khi cần thiết. diff --git a/manager/app/src/main/res/values-zh-rCN/strings.xml b/manager/app/src/main/res/values-zh-rCN/strings.xml index 32c44590..de0a7db5 100644 --- a/manager/app/src/main/res/values-zh-rCN/strings.xml +++ b/manager/app/src/main/res/values-zh-rCN/strings.xml @@ -5,6 +5,7 @@ 点击安装 工作中 版本:%d + 超级用户数:%d 不支持 内核上未检测到 KernelSU 驱动程序,内核错误? 内核版本 @@ -46,6 +47,7 @@ 安全模式 重启生效 因与 Magisk 有冲突,所有模块不可用! + 模块数:%d 了解 KernelSU https://kernelsu.org/zh_CN/guide/what-is-kernelsu.html 了解如何安装 KernelSU 以及如何开发模块 @@ -56,6 +58,10 @@ 模版 自定义 名称 + 命名空间 + 继承 + 全局 + 私有 权能 SELinux @@ -88,6 +94,7 @@ 保存 删除 查看模版 + 只读 模版 ID 已存在! 导入/导出 从剪切板导入 @@ -186,6 +193,7 @@ 搜索 清空日志 确定要清空选中的日志文件吗?此操作无法撤销。 + 日志清空成功 按类型筛选 所有类型 显示 %1$d / %2$d 条记录 @@ -194,6 +202,7 @@ 刷新 原始日志 按 UID、命令或详情搜索… + 清除搜索 查看 KernelSU 超级用户访问日志 排除子类型 当前应用 @@ -211,6 +220,7 @@ 启用动态管理器 动态管理器签名大小 动态管理器签名哈希 + 哈希必须是 64 个 16 进制字符 动态管理器配置设置成功 设置动态管理器配置失败 无效的管理器配置 @@ -228,12 +238,14 @@ 运行环境清理失败 Umount 路径管理 + 管理内核卸载路径 添加或删除路径后需要重启设备才能生效。系统会在下次启动时应用新的配置。 添加 Umount 路径 挂载路径 卸载标志 0=正常卸载, 8=MNT_DETACH, -1=自动 标志 + 默认条目 确认删除 确定要删除路径 %s 吗? 路径已添加,重启后生效 @@ -248,17 +260,9 @@ 个性化 自定义应用外观和主题 - 自定义壁纸 - 选择一张图片作为应用背景。 - 已应用壁纸 - 更换 - 移除 - 壁纸透明度:%1$d%% - 壁纸缩放 - 选择壁纸如何适配背景 - 填充 - 拉伸 - 适应 + 主题设置 + 主题模式 + 选择应用的显示主题 刷入完成 准备中… @@ -280,14 +284,20 @@ 复制失败 未知错误 刷入失败 + LKM 修复/安装 + 刷入 AnyKernel3 内核版本:%1$s 使用的修补工具:%1$s + 配置 + 应用程序设置 工具 需要root权限 KPM 补丁 用于添加额外的KPM功能 KPM 补丁 + 在刷入前对内核镜像应用KPM补丁 KPM 撤销补丁 + 撤销之前应用的KPM补丁 KPM 补丁已启用 KPM 撤销补丁已启用 KPM 补丁模式 @@ -305,6 +315,7 @@ KPM 撤销补丁失败 KPM 补丁操作失败: %s 跟随内核 + 原样使用内核,不进行任何KPM修改 内核刷入 AnyKernel3 内核 刷入AnyKernel3格式的内核zip包 @@ -320,11 +331,18 @@ kpm 模块加载失败 参数 执行 + KPM 版本 关闭 以下内核模块功能由 KernelPatch 开发,并经过修改后加入了 SukiSU Ultra 的内核模块功能 + SukiSU Ultra 期待 成功 失败 + SukiSU Ultra 在未来将是 KSU 的相对独立分支,但我们仍然感谢官方 KernelSU 和 MKSU 等的贡献! 不支持 + 支持 + 内核未修补 + 内核未配置 + 自定义设置 KPM 安装 加载 嵌入 diff --git a/manager/app/src/main/res/values-zh-rHK/strings.xml b/manager/app/src/main/res/values-zh-rHK/strings.xml index a9d95063..5c292744 100644 --- a/manager/app/src/main/res/values-zh-rHK/strings.xml +++ b/manager/app/src/main/res/values-zh-rHK/strings.xml @@ -5,6 +5,8 @@ 按一下以安裝 運作中 KernelSU 版本:%d + 超級使用者:%d 個 + 已安裝模組:%d 個 不支援 KernelSU 現在僅支援 GKI 核心 核心 @@ -52,6 +54,8 @@ 預設 設定檔名稱 範本 + 繼承 + 全域 功能 卸載模組 無法更新 %s 應用程式設定檔 @@ -62,6 +66,8 @@ 網域 更新 自訂 + 掛載命名空間 + 個人 群組 SELinux 環境 預設解除安裝模組 @@ -83,6 +89,7 @@ 模板 ID 無效 同步在線規則 創建模板 + 只讀 匯出 / 匯入 模板儲存失敗 編輯模板 diff --git a/manager/app/src/main/res/values-zh-rTW/strings.xml b/manager/app/src/main/res/values-zh-rTW/strings.xml index b07bffa5..edf3f90e 100644 --- a/manager/app/src/main/res/values-zh-rTW/strings.xml +++ b/manager/app/src/main/res/values-zh-rTW/strings.xml @@ -5,6 +5,7 @@ 點選開始安裝 已開始運作 版本:%d + 授權:%d 個應用程式 未受支援 KernelSU 目前僅支援 GKI 核心 核心版本 @@ -43,6 +44,7 @@ 安全模式 將在重新啟動時生效 與 Magisk 發生衝突,無法使用模組功能! + 掛載:%d 個模組 深入瞭解 KernelSU https://kernelsu.org/zh_TW/guide/what-is-kernelsu.html 知曉安裝、使用 KernelSU 本體與其模組功能的方法 @@ -63,6 +65,10 @@ 重新執行 範本 Profile 名稱 + 命名空間掛載 + 繼承 + 全域 + 個體 群組 SELinux 上下文 定域 @@ -87,6 +93,7 @@ 無法取得更新說明:%s 名稱 同步線上範本 + 唯讀 匯入/匯出 無法儲存範本 說明 diff --git a/manager/app/src/main/res/values/strings.xml b/manager/app/src/main/res/values/strings.xml index 0d3457bd..d9887453 100644 --- a/manager/app/src/main/res/values/strings.xml +++ b/manager/app/src/main/res/values/strings.xml @@ -6,6 +6,8 @@ Click to install Working Version: %d + Superusers: %d + Modules: %d Unsupported No KernelSU driver detected on your kernel, wrong kernel? Kernel version @@ -60,6 +62,10 @@ Template Custom Profile name + Mount namespace + Inherited + Global + Individual Groups Capabilities SELinux context @@ -92,6 +98,7 @@ Save Delete View template + Read only Template ID already exists! Import/Export Import from clipboard @@ -191,6 +198,7 @@ Search Clear Logs Are you sure you want to clear the selected log file? This action cannot be undone. + Logs cleared successfully Filter by Type All Types Showing %1$d of %2$d entries @@ -199,6 +207,7 @@ Refresh Raw Log Search by UID, command, or details… + Clear search View KernelSU superuser access logs Exclude sub-types Current App @@ -216,6 +225,7 @@ Enable Dynamic Manager Dynamic Manager Signature Size Dynamic Manager Signature Hash + Hash must be 64 hexadecimal characters Dynamic Manager configuration set successfully Failed to set dynamic Manager configuration Invalid Manager configuration @@ -234,12 +244,14 @@ Failed to clean runtime environment Umount Path Management + Manage kernel unmount paths A reboot is required for changes to take effect. The system will apply the new configuration on the next boot. Add Umount Path Mount Path Unmount Flags 0=Normal unmount, 8=MNT_DETACH, -1=Auto Flags + Default Entry Confirm Delete Are you sure you want to delete the path %s? Path added, will take effect after reboot @@ -255,17 +267,9 @@ Personalization Customize the app\'s appearance and theme - Custom wallpaper - Choose an image as the app background. - Wallpaper applied - Replace - Remove - Wallpaper transparency: %1$d%% - Wallpaper scaling - Choose how the wallpaper should fit the background. - Fill - Stretch - Fit + Theme Settings + Theme Mode + Select the app\'s display theme Flash Complete Preparing… @@ -287,14 +291,20 @@ Copy failed Unknown error Flash failed + LKM repair/installation + Flashing AnyKernel3 Kernel version:%1$s Using the patching tool:%1$s + Configure + Application Settings Tools Requires root privileges KPM Patch For adding additional KPM features KPM Patch + Apply KPM patch to kernel image before flashing KPM Undo Patch + Undo previously applied KPM patch KPM patch enabled KPM undo patch enabled KPM Patch Mode @@ -312,6 +322,7 @@ KPM undo patch failed KPM patch operation failed: %s Follow Kernel + Use kernel as-is without any KPM modifications Kernel Flashing AnyKernel3 Kernel Flash AnyKernel3 format kernel zip @@ -328,11 +339,18 @@ Load of kpm module failed Parameters Execute + KPM Version Close The following kernel module functions were developed by KernelPatch and modified to include the kernel module functions of SukiSU Ultra + SukiSU Ultra Look forward to Success Failed + SukiSU Ultra will be a relatively independent branch of KSU in the future, but we still appreciate the official KernelSU and MKSU etc. for their contributions! Unsupported + Supported + Kernel not patched + Kernel not configured + Custom settings KPM Install Load Embed