|
@@ -1,22 +1,23 @@
|
|
|
package eu.kanade.presentation.reader
|
|
|
|
|
|
-import androidx.compose.foundation.layout.Box
|
|
|
+import androidx.compose.foundation.layout.Column
|
|
|
import androidx.compose.foundation.layout.fillMaxWidth
|
|
|
-import androidx.compose.foundation.layout.padding
|
|
|
import androidx.compose.foundation.lazy.grid.items
|
|
|
import androidx.compose.material3.Surface
|
|
|
import androidx.compose.runtime.Composable
|
|
|
import androidx.compose.runtime.collectAsState
|
|
|
import androidx.compose.runtime.getValue
|
|
|
+import androidx.compose.runtime.mutableStateOf
|
|
|
import androidx.compose.runtime.remember
|
|
|
+import androidx.compose.runtime.setValue
|
|
|
import androidx.compose.ui.Modifier
|
|
|
import androidx.compose.ui.graphics.vector.ImageVector
|
|
|
import androidx.compose.ui.res.stringResource
|
|
|
import androidx.compose.ui.res.vectorResource
|
|
|
import androidx.compose.ui.tooling.preview.PreviewLightDark
|
|
|
-import androidx.compose.ui.unit.dp
|
|
|
import eu.kanade.domain.manga.model.readerOrientation
|
|
|
import eu.kanade.presentation.components.AdaptiveSheet
|
|
|
+import eu.kanade.presentation.reader.components.ModeSelectionDialog
|
|
|
import eu.kanade.presentation.theme.TachiyomiTheme
|
|
|
import eu.kanade.tachiyomi.R
|
|
|
import eu.kanade.tachiyomi.ui.reader.setting.ReaderOrientation
|
|
@@ -24,6 +25,8 @@ import eu.kanade.tachiyomi.ui.reader.setting.ReaderSettingsScreenModel
|
|
|
import tachiyomi.presentation.core.components.SettingsIconGrid
|
|
|
import tachiyomi.presentation.core.components.material.IconToggleButton
|
|
|
|
|
|
+private val ReaderOrientationsWithoutDefault = ReaderOrientation.entries - ReaderOrientation.DEFAULT
|
|
|
+
|
|
|
@Composable
|
|
|
fun OrientationSelectDialog(
|
|
|
onDismissRequest: () -> Unit,
|
|
@@ -50,13 +53,22 @@ private fun DialogContent(
|
|
|
orientation: ReaderOrientation,
|
|
|
onChangeOrientation: (ReaderOrientation) -> Unit,
|
|
|
) {
|
|
|
- Box(modifier = Modifier.padding(vertical = 16.dp)) {
|
|
|
+ var selected by remember { mutableStateOf(orientation) }
|
|
|
+
|
|
|
+ ModeSelectionDialog(
|
|
|
+ onUseDefault = {
|
|
|
+ onChangeOrientation(
|
|
|
+ ReaderOrientation.DEFAULT,
|
|
|
+ )
|
|
|
+ }.takeIf { orientation != ReaderOrientation.DEFAULT },
|
|
|
+ onApply = { onChangeOrientation(selected) },
|
|
|
+ ) {
|
|
|
SettingsIconGrid(R.string.rotation_type) {
|
|
|
- items(ReaderOrientation.entries) { mode ->
|
|
|
+ items(ReaderOrientationsWithoutDefault) { mode ->
|
|
|
IconToggleButton(
|
|
|
- checked = mode == orientation,
|
|
|
+ checked = mode == selected,
|
|
|
onCheckedChange = {
|
|
|
- onChangeOrientation(mode)
|
|
|
+ selected = mode
|
|
|
},
|
|
|
modifier = Modifier.fillMaxWidth(),
|
|
|
imageVector = ImageVector.vectorResource(mode.iconRes),
|
|
@@ -72,10 +84,17 @@ private fun DialogContent(
|
|
|
private fun DialogContentPreview() {
|
|
|
TachiyomiTheme {
|
|
|
Surface {
|
|
|
- DialogContent(
|
|
|
- orientation = ReaderOrientation.DEFAULT,
|
|
|
- onChangeOrientation = {},
|
|
|
- )
|
|
|
+ Column {
|
|
|
+ DialogContent(
|
|
|
+ orientation = ReaderOrientation.DEFAULT,
|
|
|
+ onChangeOrientation = {},
|
|
|
+ )
|
|
|
+
|
|
|
+ DialogContent(
|
|
|
+ orientation = ReaderOrientation.FREE,
|
|
|
+ onChangeOrientation = {},
|
|
|
+ )
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
}
|