Created
March 22, 2024 21:36
-
-
Save limkhashing/0aa5a7ad7029bb63114167b97d8fdc11 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| import androidx.compose.animation.core.animateFloat | |
| import androidx.compose.animation.core.infiniteRepeatable | |
| import androidx.compose.animation.core.rememberInfiniteTransition | |
| import androidx.compose.animation.core.tween | |
| import androidx.compose.foundation.background | |
| import androidx.compose.foundation.layout.* | |
| import androidx.compose.foundation.shape.CircleShape | |
| import androidx.compose.runtime.* | |
| import androidx.compose.ui.Modifier | |
| import androidx.compose.ui.composed | |
| import androidx.compose.ui.draw.clip | |
| import androidx.compose.ui.geometry.Offset | |
| import androidx.compose.ui.graphics.Brush | |
| import androidx.compose.ui.graphics.Color | |
| import androidx.compose.ui.layout.onGloballyPositioned | |
| import androidx.compose.ui.unit.IntSize | |
| import androidx.compose.ui.unit.dp | |
| @Composable | |
| fun ShimmerListItem( | |
| isLoading: Boolean, | |
| contentAfterLoading: @Composable () -> Unit, | |
| modifier: Modifier = Modifier | |
| ) { | |
| if(isLoading) { | |
| Row(modifier = modifier) { | |
| Box( | |
| modifier = Modifier | |
| .size(100.dp) | |
| .clip(CircleShape) | |
| .shimmerEffect() | |
| ) | |
| Spacer(modifier = Modifier.width(16.dp)) | |
| Column( | |
| modifier = Modifier.weight(1f) | |
| ) { | |
| Box( | |
| modifier = Modifier | |
| .fillMaxWidth() | |
| .height(20.dp) | |
| .shimmerEffect() | |
| ) | |
| Spacer(modifier = Modifier.height(16.dp)) | |
| Box( | |
| modifier = Modifier | |
| .fillMaxWidth(0.7f) | |
| .height(20.dp) | |
| .shimmerEffect() | |
| ) | |
| } | |
| } | |
| } else { | |
| contentAfterLoading() | |
| } | |
| } | |
| fun Modifier.shimmerEffect(): Modifier = composed { | |
| var size by remember { | |
| mutableStateOf(IntSize.Zero) | |
| } | |
| val transition = rememberInfiniteTransition() | |
| val startOffsetX by transition.animateFloat( | |
| initialValue = -2 * size.width.toFloat(), | |
| targetValue = 2 * size.width.toFloat(), | |
| animationSpec = infiniteRepeatable( | |
| animation = tween(1000) | |
| ) | |
| ) | |
| background( | |
| brush = Brush.linearGradient( | |
| colors = listOf( | |
| Color(0xFFB8B5B5), | |
| Color(0xFF8F8B8B), | |
| Color(0xFFB8B5B5), | |
| ), | |
| start = Offset(startOffsetX, 0f), | |
| end = Offset(startOffsetX + size.width.toFloat(), size.height.toFloat()) | |
| ) | |
| ) | |
| .onGloballyPositioned { | |
| size = it.size | |
| } | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment