From b8ece962e938780f94c65ba7f9735ae3e509154c Mon Sep 17 00:00:00 2001 From: Secozzi Date: Sun, 29 Dec 2024 14:12:42 +0100 Subject: [PATCH 1/3] Add in border style button --- .../panels/SubtitleSettingsTypographyCard.kt | 72 ++++++++++++++----- .../moko-resources/base/strings.xml | 1 + 2 files changed, 55 insertions(+), 18 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/components/panels/SubtitleSettingsTypographyCard.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/components/panels/SubtitleSettingsTypographyCard.kt index 35767816c6..8d849703ea 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/components/panels/SubtitleSettingsTypographyCard.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/components/panels/SubtitleSettingsTypographyCard.kt @@ -18,18 +18,23 @@ package eu.kanade.tachiyomi.ui.player.controls.components.panels import android.annotation.SuppressLint +import androidx.compose.foundation.clickable import androidx.compose.foundation.horizontalScroll import androidx.compose.foundation.layout.Arrangement +import androidx.compose.foundation.layout.Box import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxWidth +import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding import androidx.compose.foundation.layout.size +import androidx.compose.foundation.layout.width import androidx.compose.foundation.layout.widthIn import androidx.compose.foundation.rememberScrollState import androidx.compose.material.icons.Icons import androidx.compose.material.icons.filled.BorderColor +import androidx.compose.material.icons.filled.BorderStyle import androidx.compose.material.icons.filled.Check import androidx.compose.material.icons.filled.FormatBold import androidx.compose.material.icons.filled.FormatClear @@ -52,6 +57,7 @@ import androidx.compose.runtime.setValue import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.res.painterResource +import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import com.yubyf.truetypeparser.TTFFile import dev.icerock.moko.resources.StringResource @@ -269,24 +275,54 @@ fun SubtitleSettingsTypographyCard( } var selectingBorderStyle by remember { mutableStateOf(false) } - DropdownMenu(expanded = selectingBorderStyle, onDismissRequest = { selectingBorderStyle = false }) { - SubtitlesBorderStyle.entries.map { - DropdownMenuItem( - text = { Text(stringResource(it.titleRes)) }, - onClick = { - borderStyle = it - preferences.borderStyleSubtitles().set(it) - MPVLib.setPropertyString("sub-border-style", it.value) - }, - trailingIcon = { - if (borderStyle == it) { - Icon( - imageVector = Icons.Default.Check, - contentDescription = null, - ) - } - }, - ) + Box { + Row( + modifier = Modifier + .fillMaxWidth() + .clickable( + onClick = { + selectingBorderStyle = !selectingBorderStyle + }, + ) + .padding( + horizontal = MaterialTheme.padding.medium, + vertical = MaterialTheme.padding.small, + ), + verticalAlignment = Alignment.CenterVertically, + horizontalArrangement = Arrangement.spacedBy(MaterialTheme.padding.large), + ) { + Icon(Icons.Default.BorderStyle, null) + Column { + Text( + text = stringResource(MR.strings.player_sheets_sub_typography_border_style), + style = MaterialTheme.typography.bodyLarge, + ) + Text( + text = stringResource(borderStyle.titleRes), + style = MaterialTheme.typography.bodyMedium, + ) + } + } + DropdownMenu(expanded = selectingBorderStyle, onDismissRequest = { selectingBorderStyle = false }) { + SubtitlesBorderStyle.entries.map { + DropdownMenuItem( + text = { Text(stringResource(it.titleRes)) }, + onClick = { + borderStyle = it + preferences.borderStyleSubtitles().set(it) + MPVLib.setPropertyString("sub-border-style", it.value) + selectingBorderStyle = false + }, + trailingIcon = { + if (borderStyle == it) { + Icon( + imageVector = Icons.Default.Check, + contentDescription = null, + ) + } + }, + ) + } } } SliderItem( diff --git a/i18n/src/commonMain/moko-resources/base/strings.xml b/i18n/src/commonMain/moko-resources/base/strings.xml index e326697e1f..74683a7530 100644 --- a/i18n/src/commonMain/moko-resources/base/strings.xml +++ b/i18n/src/commonMain/moko-resources/base/strings.xml @@ -399,6 +399,7 @@ Typography Font Font size + Border style Border size Shadow offset Outline and shadow From bac0d9b023c52f0b695570b31fe18e4721578013 Mon Sep 17 00:00:00 2001 From: Secozzi Date: Sun, 29 Dec 2024 14:17:02 +0100 Subject: [PATCH 2/3] Fix double tap issues --- .../tachiyomi/ui/player/controls/GestureHandler.kt | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/GestureHandler.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/GestureHandler.kt index 97c6acadf7..ad0aa2d9dd 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/GestureHandler.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/GestureHandler.kt @@ -125,17 +125,18 @@ fun GestureHandler( if (controlsShown) viewModel.hideControls() else viewModel.showControls() }, onDoubleTap = { - if (isDoubleTapSeeking) return@detectTapGestures + if (areControlsLocked || isDoubleTapSeeking) return@detectTapGestures if (it.x > size.width * 3 / 5) { if (!isSeekingForwards) viewModel.updateSeekAmount(0) viewModel.handleRightDoubleTap() + isDoubleTapSeeking = true } else if (it.x < size.width * 2 / 5) { if (isSeekingForwards) viewModel.updateSeekAmount(0) viewModel.handleLeftDoubleTap() + isDoubleTapSeeking = true } else { viewModel.handleCenterDoubleTap() } - isDoubleTapSeeking = true }, onPress = { if (panelShown != Panels.None && !allowGesturesInPanels) { @@ -144,7 +145,7 @@ fun GestureHandler( val press = PressInteraction.Press( it.copy(x = if (it.x > size.width * 3 / 5) it.x - size.width * 0.6f else it.x), ) - if (isDoubleTapSeeking) { + if (!areControlsLocked && isDoubleTapSeeking && seekAmount != 0) { if (it.x > size.width * 3 / 5) { if (!isSeekingForwards) viewModel.updateSeekAmount(0) viewModel.handleRightDoubleTap() @@ -154,6 +155,8 @@ fun GestureHandler( } else { viewModel.handleCenterDoubleTap() } + } else { + isDoubleTapSeeking = false } interactionSource.emit(press) tryAwaitRelease() From eaaa6964a26500f329d431c4aa9879f73459f0b9 Mon Sep 17 00:00:00 2001 From: Secozzi Date: Sun, 29 Dec 2024 14:33:24 +0100 Subject: [PATCH 3/3] spotless(spotless): spotless --- .../components/panels/SubtitleSettingsTypographyCard.kt | 3 --- 1 file changed, 3 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/components/panels/SubtitleSettingsTypographyCard.kt b/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/components/panels/SubtitleSettingsTypographyCard.kt index 8d849703ea..8c9cc092d2 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/components/panels/SubtitleSettingsTypographyCard.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/ui/player/controls/components/panels/SubtitleSettingsTypographyCard.kt @@ -26,10 +26,8 @@ import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxWidth -import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding import androidx.compose.foundation.layout.size -import androidx.compose.foundation.layout.width import androidx.compose.foundation.layout.widthIn import androidx.compose.foundation.rememberScrollState import androidx.compose.material.icons.Icons @@ -57,7 +55,6 @@ import androidx.compose.runtime.setValue import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.res.painterResource -import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import com.yubyf.truetypeparser.TTFFile import dev.icerock.moko.resources.StringResource