mirror of
https://github.com/msfjarvis/compose-lobsters
synced 2025-08-17 23:47:02 +05:30
LobstersItem: reimplement with Rows and Columns
Signed-off-by: Harsh Shandilya <me@msfjarvis.dev>
This commit is contained in:
parent
5971163361
commit
ebc75bddca
1 changed files with 43 additions and 57 deletions
|
@ -5,10 +5,11 @@ import androidx.compose.foundation.ExperimentalFoundationApi
|
||||||
import androidx.compose.foundation.background
|
import androidx.compose.foundation.background
|
||||||
import androidx.compose.foundation.combinedClickable
|
import androidx.compose.foundation.combinedClickable
|
||||||
import androidx.compose.foundation.layout.Arrangement
|
import androidx.compose.foundation.layout.Arrangement
|
||||||
|
import androidx.compose.foundation.layout.Column
|
||||||
import androidx.compose.foundation.layout.Row
|
import androidx.compose.foundation.layout.Row
|
||||||
import androidx.compose.foundation.layout.fillMaxWidth
|
|
||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.layout.requiredWidth
|
import androidx.compose.foundation.layout.requiredWidth
|
||||||
|
import androidx.compose.foundation.layout.width
|
||||||
import androidx.compose.foundation.lazy.LazyColumn
|
import androidx.compose.foundation.lazy.LazyColumn
|
||||||
import androidx.compose.foundation.lazy.items
|
import androidx.compose.foundation.lazy.items
|
||||||
import androidx.compose.foundation.shape.RoundedCornerShape
|
import androidx.compose.foundation.shape.RoundedCornerShape
|
||||||
|
@ -16,13 +17,14 @@ import androidx.compose.material.IconToggleButton
|
||||||
import androidx.compose.material.Surface
|
import androidx.compose.material.Surface
|
||||||
import androidx.compose.material.Text
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
|
import androidx.compose.ui.Alignment
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.graphics.Color
|
import androidx.compose.ui.graphics.Color
|
||||||
|
import androidx.compose.ui.platform.LocalConfiguration
|
||||||
import androidx.compose.ui.res.stringResource
|
import androidx.compose.ui.res.stringResource
|
||||||
import androidx.compose.ui.text.font.FontWeight
|
import androidx.compose.ui.text.font.FontWeight
|
||||||
import androidx.compose.ui.tooling.preview.Preview
|
import androidx.compose.ui.tooling.preview.Preview
|
||||||
import androidx.compose.ui.unit.dp
|
import androidx.compose.ui.unit.dp
|
||||||
import androidx.constraintlayout.compose.ConstraintLayout
|
|
||||||
import coil.transform.CircleCropTransformation
|
import coil.transform.CircleCropTransformation
|
||||||
import dev.chrisbanes.accompanist.coil.CoilImage
|
import dev.chrisbanes.accompanist.coil.CoilImage
|
||||||
import dev.msfjarvis.lobsters.R
|
import dev.msfjarvis.lobsters.R
|
||||||
|
@ -71,71 +73,55 @@ fun LobstersItem(
|
||||||
) {
|
) {
|
||||||
Surface(
|
Surface(
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.fillMaxWidth()
|
|
||||||
.combinedClickable(
|
.combinedClickable(
|
||||||
onClick = onClick,
|
onClick = onClick,
|
||||||
onLongClick = onLongClick,
|
onLongClick = onLongClick,
|
||||||
),
|
),
|
||||||
) {
|
) {
|
||||||
ConstraintLayout(
|
Row(
|
||||||
modifier = Modifier.padding(start = 12.dp, end = 12.dp),
|
modifier = Modifier.padding(start = 12.dp, end = 12.dp),
|
||||||
|
verticalAlignment = Alignment.CenterVertically,
|
||||||
) {
|
) {
|
||||||
val (title, tags, avatar, submitter, saveButton) = createRefs()
|
Column(
|
||||||
Text(
|
modifier = Modifier.width(LocalConfiguration.current.screenWidthDp.dp.times(0.9f))
|
||||||
text = post.title,
|
) {
|
||||||
color = titleColor,
|
Text(
|
||||||
fontWeight = FontWeight.Bold,
|
text = post.title,
|
||||||
modifier = Modifier
|
color = titleColor,
|
||||||
.padding(top = 4.dp)
|
fontWeight = FontWeight.Bold,
|
||||||
.constrainAs(title) {
|
modifier = Modifier
|
||||||
top.linkTo(parent.top)
|
.padding(top = 4.dp),
|
||||||
start.linkTo(parent.start)
|
)
|
||||||
},
|
TagRow(
|
||||||
)
|
tags = post.tags,
|
||||||
TagRow(
|
modifier = Modifier
|
||||||
tags = post.tags,
|
.padding(vertical = 8.dp),
|
||||||
modifier = Modifier
|
)
|
||||||
.constrainAs(tags) {
|
Row {
|
||||||
top.linkTo(title.bottom)
|
CoilImage(
|
||||||
}
|
data = "${LobstersApi.BASE_URL}/${post.submitter_user.avatarUrl}",
|
||||||
.padding(vertical = 8.dp),
|
contentDescription = stringResource(
|
||||||
)
|
R.string.avatar_content_description,
|
||||||
CoilImage(
|
post.submitter_user.username
|
||||||
data = "${LobstersApi.BASE_URL}/${post.submitter_user.avatarUrl}",
|
),
|
||||||
contentDescription = stringResource(
|
fadeIn = true,
|
||||||
R.string.avatar_content_description,
|
requestBuilder = {
|
||||||
post.submitter_user.username
|
transformations(CircleCropTransformation())
|
||||||
),
|
},
|
||||||
fadeIn = true,
|
modifier = Modifier
|
||||||
requestBuilder = {
|
.requiredWidth(30.dp)
|
||||||
transformations(CircleCropTransformation())
|
.padding(4.dp),
|
||||||
},
|
)
|
||||||
modifier = Modifier
|
Text(
|
||||||
.requiredWidth(30.dp)
|
text = stringResource(id = R.string.submitted_by, post.submitter_user.username),
|
||||||
.padding(4.dp)
|
modifier = Modifier
|
||||||
.constrainAs(avatar) {
|
.padding(4.dp),
|
||||||
top.linkTo(tags.bottom)
|
)
|
||||||
start.linkTo(parent.start)
|
}
|
||||||
},
|
}
|
||||||
)
|
|
||||||
Text(
|
|
||||||
text = stringResource(id = R.string.submitted_by, post.submitter_user.username),
|
|
||||||
modifier = Modifier
|
|
||||||
.padding(4.dp)
|
|
||||||
.constrainAs(submitter) {
|
|
||||||
top.linkTo(avatar.top)
|
|
||||||
bottom.linkTo(avatar.bottom)
|
|
||||||
start.linkTo(avatar.end)
|
|
||||||
},
|
|
||||||
)
|
|
||||||
IconToggleButton(
|
IconToggleButton(
|
||||||
checked = isSaved,
|
checked = isSaved,
|
||||||
onCheckedChange = { onSaveButtonClick.invoke() },
|
onCheckedChange = { onSaveButtonClick.invoke() },
|
||||||
modifier = Modifier
|
|
||||||
.constrainAs(saveButton) {
|
|
||||||
end.linkTo(parent.end)
|
|
||||||
centerVerticallyTo(parent)
|
|
||||||
}
|
|
||||||
) {
|
) {
|
||||||
Crossfade(targetState = isSaved) {
|
Crossfade(targetState = isSaved) {
|
||||||
if (it) {
|
if (it) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue