Skip to content

Commit

Permalink
Merge branch 'refs/heads/material-1.1.0-alpha01' into Kotlin-2.0
Browse files Browse the repository at this point in the history
  • Loading branch information
Rob Orgiu committed Sep 4, 2024
2 parents 46417e2 + ba5d63f commit 03d0a48
Showing 1 changed file with 36 additions and 46 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
* limitations under the License.
*/

@file:OptIn(ExperimentalSharedTransitionApi::class)
@file:OptIn(ExperimentalSharedTransitionApi::class, ExperimentalSharedTransitionApi::class)

package com.example.listdetailcompose.ui

Expand Down Expand Up @@ -96,15 +96,15 @@ private data class DefinedWord(
fun ListDetailSample() {
var selectedWordIndex: Int? by rememberSaveable { mutableStateOf(null) }
val navigator = rememberListDetailPaneScaffoldNavigator<Nothing>()
val isCompact =
val isSmallerThanExpanded =
currentWindowAdaptiveInfo().windowSizeClass.windowWidthSizeClass != WindowWidthSizeClass.EXPANDED

BackHandler(enabled = navigator.canNavigateBack()) {
navigator.navigateBack()
}

SharedTransitionLayout {
AnimatedContent(targetState = isCompact, label = "simple sample") {
AnimatedContent(targetState = isSmallerThanExpanded, label = "simple sample") {
ListDetailPaneScaffold(
directive = navigator.scaffoldDirective,
value = navigator.scaffoldValue,
Expand All @@ -124,7 +124,7 @@ fun ListDetailSample() {
selectedWordIndex = index
navigator.navigateTo(ListDetailPaneScaffoldRole.Detail)
},
isCompact = isCompact,
isSmallerThanExpanded = isSmallerThanExpanded,
isDetailVisible = isDetailVisible,
animatedVisibilityScope = this@AnimatedPane,
sharedTransitionScope = this@SharedTransitionLayout
Expand All @@ -138,7 +138,7 @@ fun ListDetailSample() {
AnimatedPane {
DetailContent(
definedWord = definedWord,
isCompact = isCompact,
isSmallerThanExpanded = isSmallerThanExpanded,
isDetailVisible = isDetailVisible,
animatedVisibilityScope = this@AnimatedPane,
sharedTransitionScope = this@SharedTransitionLayout
Expand Down Expand Up @@ -184,7 +184,7 @@ private fun ListContent(
selectionState: SelectionVisibilityState,
onIndexClick: (index: Int) -> Unit,
modifier: Modifier = Modifier,
isCompact: Boolean,
isSmallerThanExpanded: Boolean,
isDetailVisible: Boolean,
sharedTransitionScope: SharedTransitionScope,
animatedVisibilityScope: AnimatedVisibilityScope
Expand Down Expand Up @@ -252,31 +252,27 @@ private fun ListContent(
.fillMaxWidth()
) {
Row {
if (isCompact && !isDetailVisible) {
with(sharedTransitionScope) {
val state = rememberSharedContentState(key = word.word)

println("list-" + word.word + "-" + state.isMatchFound)

Image(
painter = painterResource(id = word.icon),
contentDescription = word.word,
modifier = Modifier
val imageModifier =
if (isSmallerThanExpanded && !isDetailVisible) {
with(sharedTransitionScope) {
val state = rememberSharedContentState(key = word.word)
Modifier
.padding(horizontal = 8.dp)
.sharedElement(
state,
animatedVisibilityScope = animatedVisibilityScope
)
)

}
} else {
Modifier.padding(horizontal = 8.dp)
}
} else {
Image(
painter = painterResource(id = word.icon),
contentDescription = word.word,
modifier = Modifier
.padding(horizontal = 8.dp)
)
}

Image(
painter = painterResource(id = word.icon),
contentDescription = word.word,
modifier = imageModifier
)
Text(
text = word.word,
modifier = Modifier
Expand All @@ -297,7 +293,7 @@ private fun ListContent(
private fun DetailContent(
definedWord: DefinedWord?,
modifier: Modifier = Modifier,
isCompact: Boolean,
isSmallerThanExpanded: Boolean,
isDetailVisible: Boolean,
sharedTransitionScope: SharedTransitionScope,
animatedVisibilityScope: AnimatedVisibilityScope
Expand All @@ -309,31 +305,25 @@ private fun DetailContent(
) {
if (definedWord != null) {

if (isCompact && isDetailVisible) {
val imageModifier = if (isSmallerThanExpanded && isDetailVisible) {
with(sharedTransitionScope) {
val state = rememberSharedContentState(key = definedWord.word)

println("detail-" + definedWord.word + "-" + state.isMatchFound)

Image(
painter = painterResource(id = definedWord.icon),
contentDescription = definedWord.word,
modifier = Modifier
.padding(horizontal = 8.dp)
.sharedElement(
state,
animatedVisibilityScope = animatedVisibilityScope
)
)
Modifier
.padding(horizontal = 8.dp)
.sharedElement(
state,
animatedVisibilityScope = animatedVisibilityScope
)
}
} else {
Image(
painter = painterResource(id = definedWord.icon),
contentDescription = definedWord.word,
modifier = Modifier
.padding(horizontal = 8.dp)
)
Modifier.padding(horizontal = 8.dp)
}

Image(
painter = painterResource(id = definedWord.icon),
contentDescription = definedWord.word,
modifier = imageModifier
)
Text(
text = definedWord.word,
style = MaterialTheme.typography.headlineMedium
Expand Down

0 comments on commit 03d0a48

Please sign in to comment.