Add option for old action bar

This commit is contained in:
Aleksandras Kostarevas 2024-07-21 21:20:32 +03:00
parent 9355b32466
commit e53ef1094a
2 changed files with 66 additions and 46 deletions

View File

@ -94,6 +94,7 @@ import org.futo.inputmethod.latin.uix.actions.FavoriteActions
import org.futo.inputmethod.latin.uix.actions.MoreActionsAction import org.futo.inputmethod.latin.uix.actions.MoreActionsAction
import org.futo.inputmethod.latin.uix.actions.PinnedActions import org.futo.inputmethod.latin.uix.actions.PinnedActions
import org.futo.inputmethod.latin.uix.actions.toActionList import org.futo.inputmethod.latin.uix.actions.toActionList
import org.futo.inputmethod.latin.uix.settings.useDataStore
import org.futo.inputmethod.latin.uix.settings.useDataStoreValueBlocking import org.futo.inputmethod.latin.uix.settings.useDataStoreValueBlocking
import org.futo.inputmethod.latin.uix.theme.DarkColorScheme import org.futo.inputmethod.latin.uix.theme.DarkColorScheme
import org.futo.inputmethod.latin.uix.theme.Typography import org.futo.inputmethod.latin.uix.theme.Typography
@ -130,6 +131,27 @@ import kotlin.math.roundToInt
* TODO: Will need to make RTL languages work * TODO: Will need to make RTL languages work
*/ */
val ActionBarScrollIndexSetting = SettingsKey(
intPreferencesKey("action_bar_scroll_index"),
0
)
val ActionBarScrollOffsetSetting = SettingsKey(
intPreferencesKey("action_bar_scroll_offset"),
0
)
val ActionBarExpanded = SettingsKey(
booleanPreferencesKey("actionExpanded"),
false
)
val OldStyleActionsBar = SettingsKey(
booleanPreferencesKey("oldActionBar"),
false
)
interface ImportantNotice { interface ImportantNotice {
@Composable fun getText(): String @Composable fun getText(): String
fun onDismiss(context: Context) fun onDismiss(context: Context)
@ -422,14 +444,6 @@ fun ActionItemSmall(action: Action, onSelect: (Action) -> Unit, onLongSelect: (A
} }
} }
val ActionBarScrollIndexSetting = SettingsKey(
intPreferencesKey("action_bar_scroll_index"),
0
)
val ActionBarScrollOffsetSetting = SettingsKey(
intPreferencesKey("action_bar_scroll_offset"),
0
)
@Composable @Composable
fun ActionItems(onSelect: (Action) -> Unit, onLongSelect: (Action) -> Unit) { fun ActionItems(onSelect: (Action) -> Unit, onLongSelect: (Action) -> Unit) {
@ -613,11 +627,6 @@ fun ImportantNoticeView(
} }
} }
val ActionBarExpanded = SettingsKey(
booleanPreferencesKey("actionExpanded"),
false
)
@Composable @Composable
fun RowScope.PinnedActionItems(onSelect: (Action) -> Unit, onLongSelect: (Action) -> Unit) { fun RowScope.PinnedActionItems(onSelect: (Action) -> Unit, onLongSelect: (Action) -> Unit) {
val actions = if(!LocalInspectionMode.current) { val actions = if(!LocalInspectionMode.current) {
@ -658,8 +667,10 @@ fun ActionBar(
MaterialTheme.colorScheme.surfaceVariant MaterialTheme.colorScheme.surfaceVariant
} }
val oldActionBar = useDataStore(OldStyleActionsBar)
Column { Column {
if(isActionsExpanded) { if(isActionsExpanded && !oldActionBar.value) {
Box(modifier = Modifier Box(modifier = Modifier
.fillMaxWidth() .fillMaxWidth()
.height(1.dp) .height(1.dp)
@ -694,41 +705,47 @@ fun ActionBar(
) )
} }
if (importantNotice != null) { if(oldActionBar.value && isActionsExpanded) {
ImportantNoticeView(importantNotice) Box(modifier = Modifier.weight(1.0f).fillMaxHeight()) {
ActionItems(onActionActivated, onActionAltActivated)
}
} else { } else {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) { if (importantNotice != null) {
AnimatedVisibility( ImportantNoticeView(importantNotice)
inlineSuggestions.isNotEmpty(),
enter = fadeIn(),
exit = fadeOut()
) {
InlineSuggestions(inlineSuggestions)
}
}
if (words != null && inlineSuggestions.isEmpty()) {
SuggestionItems(
words,
onClick = {
suggestionStripListener.pickSuggestionManually(
words.getInfo(it)
)
keyboardManagerForAction?.performHapticAndAudioFeedback(
Constants.CODE_TAB,
view
)
},
onLongClick = {
suggestionStripListener.requestForgetWord(
words.getInfo(it)
)
})
} else { } else {
Spacer(modifier = Modifier.weight(1.0f)) if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) {
} AnimatedVisibility(
inlineSuggestions.isNotEmpty(),
enter = fadeIn(),
exit = fadeOut()
) {
InlineSuggestions(inlineSuggestions)
}
}
PinnedActionItems(onActionActivated, onActionAltActivated) if (words != null && inlineSuggestions.isEmpty()) {
SuggestionItems(
words,
onClick = {
suggestionStripListener.pickSuggestionManually(
words.getInfo(it)
)
keyboardManagerForAction?.performHapticAndAudioFeedback(
Constants.CODE_TAB,
view
)
},
onLongClick = {
suggestionStripListener.requestForgetWord(
words.getInfo(it)
)
})
} else {
Spacer(modifier = Modifier.weight(1.0f))
}
PinnedActionItems(onActionActivated, onActionAltActivated)
}
} }
} }
} }

View File

@ -17,6 +17,7 @@ import kotlinx.coroutines.withContext
import org.futo.inputmethod.latin.BuildConfig import org.futo.inputmethod.latin.BuildConfig
import org.futo.inputmethod.latin.R import org.futo.inputmethod.latin.R
import org.futo.inputmethod.latin.uix.HiddenKeysSetting import org.futo.inputmethod.latin.uix.HiddenKeysSetting
import org.futo.inputmethod.latin.uix.OldStyleActionsBar
import org.futo.inputmethod.latin.uix.SettingsKey import org.futo.inputmethod.latin.uix.SettingsKey
import org.futo.inputmethod.latin.uix.settings.NavigationItem import org.futo.inputmethod.latin.uix.settings.NavigationItem
import org.futo.inputmethod.latin.uix.settings.NavigationItemStyle import org.futo.inputmethod.latin.uix.settings.NavigationItemStyle
@ -55,6 +56,8 @@ fun DeveloperScreen(navController: NavHostController = rememberNavController())
SettingToggleDataStore(title = "Dismissed migration notice", setting = dismissedMigrateUpdateNotice) SettingToggleDataStore(title = "Dismissed migration notice", setting = dismissedMigrateUpdateNotice)
SettingToggleDataStore(title = "Old action bar", setting = OldStyleActionsBar)
NavigationItem( NavigationItem(
title = "Crash the app", title = "Crash the app",
style = NavigationItemStyle.MiscNoArrow, style = NavigationItemStyle.MiscNoArrow,