Skip to content

Commit

Permalink
Tweak ReorderingLazyList code
Browse files Browse the repository at this point in the history
  • Loading branch information
vfsfitvnm committed Aug 26, 2022
1 parent 97707d7 commit e41bca1
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 18 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ fun ReorderingLazyColumn(
) {
ReorderingLazyList(
modifier = modifier,
state = reorderingState.lazyListState,
reorderingState = reorderingState,
contentPadding = contentPadding,
flingBehavior = flingBehavior,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@ import androidx.compose.foundation.lazy.rememberLazyListItemProvider
import androidx.compose.foundation.overscroll
import androidx.compose.runtime.Composable
import androidx.compose.runtime.remember
import androidx.compose.runtime.rememberCoroutineScope
import androidx.compose.runtime.snapshots.Snapshot
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
Expand All @@ -49,7 +48,6 @@ import androidx.compose.ui.unit.offset
@Composable
internal fun ReorderingLazyList(
modifier: Modifier,
state: LazyListState,
reorderingState: ReorderingState,
contentPadding: PaddingValues,
reverseLayout: Boolean,
Expand All @@ -63,16 +61,16 @@ internal fun ReorderingLazyList(
content: LazyListScope.() -> Unit
) {
val overscrollEffect = ScrollableDefaults.overscrollEffect()
val itemProvider = rememberLazyListItemProvider(state, content)
val scope = rememberCoroutineScope()
val placementAnimator = remember(state, isVertical) {
LazyListItemPlacementAnimator(scope, isVertical)
val itemProvider = rememberLazyListItemProvider(reorderingState.lazyListState, content)
val placementAnimator = remember(reorderingState.lazyListState, isVertical) {
LazyListItemPlacementAnimator(reorderingState.coroutineScope, isVertical).also {
reorderingState.lazyListState.placementAnimator = it
}
}
state.placementAnimator = placementAnimator

val measurePolicy = rememberLazyListMeasurePolicy(
itemProvider,
state,
reorderingState.lazyListState,
reorderingState.lazyListBeyondBoundsInfo,
overscrollEffect,
contentPadding,
Expand All @@ -88,19 +86,26 @@ internal fun ReorderingLazyList(
val orientation = if (isVertical) Orientation.Vertical else Orientation.Horizontal
LazyLayout(
modifier = modifier
.then(state.remeasurementModifier)
.then(state.awaitLayoutModifier)
.then(reorderingState.lazyListState.remeasurementModifier)
.then(reorderingState.lazyListState.awaitLayoutModifier)
.lazyListSemantics(
itemProvider = itemProvider,
state = state,
coroutineScope = scope,
state = reorderingState.lazyListState,
coroutineScope = reorderingState.coroutineScope,
isVertical = isVertical,
reverseScrolling = reverseLayout,
userScrollEnabled = userScrollEnabled
)
.clipScrollableContainer(orientation)
.lazyListBeyondBoundsModifier(state, reorderingState.lazyListBeyondBoundsInfo, reverseLayout)
.lazyListPinningModifier(state, reorderingState.lazyListBeyondBoundsInfo)
.lazyListBeyondBoundsModifier(
state = reorderingState.lazyListState,
beyondBoundsInfo = reorderingState.lazyListBeyondBoundsInfo,
reverseLayout = reverseLayout
)
.lazyListPinningModifier(
state = reorderingState.lazyListState,
beyondBoundsInfo = reorderingState.lazyListBeyondBoundsInfo
)
.overscroll(overscrollEffect)
.scrollable(
orientation = orientation,
Expand All @@ -109,13 +114,13 @@ internal fun ReorderingLazyList(
orientation,
reverseLayout
),
interactionSource = state.internalInteractionSource,
interactionSource = reorderingState.lazyListState.internalInteractionSource,
flingBehavior = flingBehavior,
state = state,
state = reorderingState.lazyListState,
overscrollEffect = overscrollEffect,
enabled = userScrollEnabled
),
prefetchState = state.prefetchState,
prefetchState = reorderingState.lazyListState.prefetchState,
measurePolicy = measurePolicy,
itemProvider = itemProvider
)
Expand Down

0 comments on commit e41bca1

Please sign in to comment.