mirror of
https://github.com/gkd-kit/gkd.git
synced 2024-11-16 03:32:38 +08:00
perf: switch enabled
This commit is contained in:
parent
d48ae8d251
commit
de431cb3c3
|
@ -64,7 +64,6 @@ import li.songe.gkd.util.RuleSortOption
|
||||||
import li.songe.gkd.util.appInfoCacheFlow
|
import li.songe.gkd.util.appInfoCacheFlow
|
||||||
import li.songe.gkd.util.launchTry
|
import li.songe.gkd.util.launchTry
|
||||||
import li.songe.gkd.util.navigate
|
import li.songe.gkd.util.navigate
|
||||||
import li.songe.gkd.util.toast
|
|
||||||
|
|
||||||
@RootNavGraph
|
@RootNavGraph
|
||||||
@Destination(style = ProfileTransitions::class)
|
@Destination(style = ProfileTransitions::class)
|
||||||
|
@ -171,13 +170,9 @@ fun AppConfigPage(appId: String) {
|
||||||
ExcludeData.parse(g.config?.exclude)
|
ExcludeData.parse(g.config?.exclude)
|
||||||
}
|
}
|
||||||
val checked = getChecked(excludeData, g.group, appId, appInfo)
|
val checked = getChecked(excludeData, g.group, appId, appInfo)
|
||||||
AppGroupCard(g.group, checked ?: false, onClick = {
|
AppGroupCard(g.group, checked, onClick = {
|
||||||
navController.navigate(GlobalRulePageDestination(g.subsItem.id, g.group.key))
|
navController.navigate(GlobalRulePageDestination(g.subsItem.id, g.group.key))
|
||||||
}) { newChecked ->
|
}) { newChecked ->
|
||||||
if (checked == null) {
|
|
||||||
toast("内置禁用,不可修改")
|
|
||||||
return@AppGroupCard
|
|
||||||
}
|
|
||||||
vm.viewModelScope.launchTry {
|
vm.viewModelScope.launchTry {
|
||||||
DbSet.subsConfigDao.insert(
|
DbSet.subsConfigDao.insert(
|
||||||
(g.config ?: SubsConfig(
|
(g.config ?: SubsConfig(
|
||||||
|
@ -243,7 +238,7 @@ fun AppConfigPage(appId: String) {
|
||||||
@Composable
|
@Composable
|
||||||
private fun AppGroupCard(
|
private fun AppGroupCard(
|
||||||
group: RawSubscription.RawGroupProps,
|
group: RawSubscription.RawGroupProps,
|
||||||
enable: Boolean,
|
checked: Boolean?,
|
||||||
onClick: () -> Unit,
|
onClick: () -> Unit,
|
||||||
onCheckedChange: ((Boolean) -> Unit)?,
|
onCheckedChange: ((Boolean) -> Unit)?,
|
||||||
) {
|
) {
|
||||||
|
@ -297,6 +292,14 @@ private fun AppGroupCard(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Spacer(modifier = Modifier.width(10.dp))
|
Spacer(modifier = Modifier.width(10.dp))
|
||||||
Switch(checked = enable, modifier = Modifier, onCheckedChange = onCheckedChange)
|
if (checked != null) {
|
||||||
|
Switch(checked = checked, onCheckedChange = onCheckedChange)
|
||||||
|
} else {
|
||||||
|
Switch(
|
||||||
|
checked = false,
|
||||||
|
enabled = false,
|
||||||
|
onCheckedChange = onCheckedChange
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user