mirror of
https://github.com/mihonapp/mihon.git
synced 2025-01-04 04:34:38 +00:00
Revert "Fix banners-related issues" (#9186)
Revert "Fix banners-related issues (#9143)"
This reverts commit 63048d2f0b
.
This commit is contained in:
parent
ed32a511e7
commit
c0f94ae8af
4 changed files with 26 additions and 29 deletions
|
@ -69,8 +69,7 @@ fun AppStateBanners(
|
|||
val mainInsets = WindowInsets.statusBars
|
||||
val mainInsetsTop = mainInsets.getTop(density)
|
||||
SubcomposeLayout(modifier = modifier) { constraints ->
|
||||
val indexingId = if (indexing) 0 else -1
|
||||
val indexingPlaceable = subcompose(indexingId) {
|
||||
val indexingPlaceable = subcompose(0) {
|
||||
AnimatedVisibility(
|
||||
visible = indexing,
|
||||
enter = expandVertically(),
|
||||
|
@ -83,8 +82,7 @@ fun AppStateBanners(
|
|||
}.fastMap { it.measure(constraints) }
|
||||
val indexingHeight = indexingPlaceable.fastMaxBy { it.height }?.height ?: 0
|
||||
|
||||
val downloadedId = if (indexing) 1 else 0
|
||||
val downloadedOnlyPlaceable = subcompose(downloadedId) {
|
||||
val downloadedOnlyPlaceable = subcompose(1) {
|
||||
AnimatedVisibility(
|
||||
visible = downloadedOnlyMode,
|
||||
enter = expandVertically(),
|
||||
|
@ -98,12 +96,7 @@ fun AppStateBanners(
|
|||
}.fastMap { it.measure(constraints) }
|
||||
val downloadedOnlyHeight = downloadedOnlyPlaceable.fastMaxBy { it.height }?.height ?: 0
|
||||
|
||||
val incognitoId = when {
|
||||
indexing && downloadedOnlyMode -> 3
|
||||
indexing || downloadedOnlyMode -> 2
|
||||
else -> 1
|
||||
}
|
||||
val incognitoPlaceable = subcompose(incognitoId) {
|
||||
val incognitoPlaceable = subcompose(2) {
|
||||
AnimatedVisibility(
|
||||
visible = incognitoMode,
|
||||
enter = expandVertically(),
|
||||
|
|
|
@ -3,7 +3,6 @@ package eu.kanade.presentation.util
|
|||
import androidx.compose.runtime.Composable
|
||||
import androidx.compose.runtime.ProvidableCompositionLocal
|
||||
import androidx.compose.runtime.staticCompositionLocalOf
|
||||
import androidx.compose.ui.Modifier
|
||||
import cafe.adriel.voyager.core.screen.Screen
|
||||
import cafe.adriel.voyager.core.screen.ScreenKey
|
||||
import cafe.adriel.voyager.core.screen.uniqueScreenKey
|
||||
|
@ -34,7 +33,7 @@ interface AssistContentScreen {
|
|||
}
|
||||
|
||||
@Composable
|
||||
fun DefaultNavigatorScreenTransition(navigator: Navigator, modifier: Modifier = Modifier) {
|
||||
fun DefaultNavigatorScreenTransition(navigator: Navigator) {
|
||||
val slideDistance = rememberSlideDistance()
|
||||
ScreenTransition(
|
||||
navigator = navigator,
|
||||
|
@ -44,6 +43,5 @@ fun DefaultNavigatorScreenTransition(navigator: Navigator, modifier: Modifier =
|
|||
slideDistance = slideDistance,
|
||||
)
|
||||
},
|
||||
modifier = modifier,
|
||||
)
|
||||
}
|
||||
|
|
|
@ -6,6 +6,7 @@ import androidx.compose.animation.AnimatedVisibility
|
|||
import androidx.compose.animation.expandVertically
|
||||
import androidx.compose.animation.shrinkVertically
|
||||
import androidx.compose.animation.with
|
||||
import androidx.compose.foundation.layout.Box
|
||||
import androidx.compose.foundation.layout.RowScope
|
||||
import androidx.compose.foundation.layout.WindowInsets
|
||||
import androidx.compose.foundation.layout.consumeWindowInsets
|
||||
|
@ -112,21 +113,24 @@ object HomeScreen : Screen() {
|
|||
},
|
||||
contentWindowInsets = WindowInsets(0),
|
||||
) { contentPadding ->
|
||||
AnimatedContent(
|
||||
Box(
|
||||
modifier = Modifier
|
||||
.padding(contentPadding)
|
||||
.consumeWindowInsets(contentPadding),
|
||||
targetState = tabNavigator.current,
|
||||
transitionSpec = {
|
||||
materialFadeThroughIn(initialScale = 1f, durationMillis = TabFadeDuration) with
|
||||
materialFadeThroughOut(durationMillis = TabFadeDuration)
|
||||
},
|
||||
content = {
|
||||
tabNavigator.saveableState(key = "currentTab", it) {
|
||||
it.Content()
|
||||
}
|
||||
},
|
||||
)
|
||||
) {
|
||||
AnimatedContent(
|
||||
targetState = tabNavigator.current,
|
||||
transitionSpec = {
|
||||
materialFadeThroughIn(initialScale = 1f, durationMillis = TabFadeDuration) with
|
||||
materialFadeThroughOut(durationMillis = TabFadeDuration)
|
||||
},
|
||||
content = {
|
||||
tabNavigator.saveableState(key = "currentTab", it) {
|
||||
it.Content()
|
||||
}
|
||||
},
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -13,6 +13,7 @@ import android.widget.Toast
|
|||
import androidx.activity.ComponentActivity
|
||||
import androidx.activity.compose.BackHandler
|
||||
import androidx.compose.foundation.isSystemInDarkTheme
|
||||
import androidx.compose.foundation.layout.Box
|
||||
import androidx.compose.foundation.layout.WindowInsets
|
||||
import androidx.compose.foundation.layout.WindowInsetsSides
|
||||
import androidx.compose.foundation.layout.consumeWindowInsets
|
||||
|
@ -221,14 +222,15 @@ class MainActivity : BaseActivity() {
|
|||
},
|
||||
contentWindowInsets = scaffoldInsets,
|
||||
) { contentPadding ->
|
||||
// Shows current screen
|
||||
// Consume insets already used by app state banners
|
||||
DefaultNavigatorScreenTransition(
|
||||
navigator = navigator,
|
||||
Box(
|
||||
modifier = Modifier
|
||||
.padding(contentPadding)
|
||||
.consumeWindowInsets(contentPadding),
|
||||
)
|
||||
) {
|
||||
// Shows current screen
|
||||
DefaultNavigatorScreenTransition(navigator = navigator)
|
||||
}
|
||||
}
|
||||
|
||||
// Pop source-related screens when incognito mode is turned off
|
||||
|
|
Loading…
Reference in a new issue