-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPostList.kt
94 lines (90 loc) · 3.28 KB
/
PostList.kt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
package com.github.jetbrains.rssreader.androidApp.composeui
import androidx.compose.foundation.Image
import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.*
import androidx.compose.foundation.lazy.LazyColumn
import androidx.compose.foundation.lazy.LazyListState
import androidx.compose.foundation.lazy.itemsIndexed
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material.Card
import androidx.compose.material.MaterialTheme
import androidx.compose.material.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import androidx.compose.ui.text.style.TextOverflow
import androidx.compose.ui.unit.dp
import coil.compose.rememberAsyncImagePainter
import com.github.jetbrains.rssreader.core.entity.Post
import com.google.accompanist.insets.statusBarsHeight
import java.text.SimpleDateFormat
import java.util.*
@Composable
fun PostList(
modifier: Modifier,
posts: List<Post>,
listState: LazyListState,
onClick: (Post) -> Unit
) {
LazyColumn(
modifier = modifier,
contentPadding = PaddingValues(16.dp),
state = listState
) {
itemsIndexed(posts) { i, post ->
if (i == 0) Spacer(Modifier.statusBarsHeight())
PostItem(post) { onClick(post) }
if (i != posts.size - 1) Spacer(modifier = Modifier.size(16.dp))
}
}
}
private val dateFormatter = SimpleDateFormat("dd MMMM yyyy", Locale.getDefault())
@Composable
fun PostItem(
item: Post,
onClick: () -> Unit
) {
val padding = 16.dp
Box {
Card(
elevation = 16.dp,
shape = RoundedCornerShape(padding)
) {
Column(
modifier = Modifier.clickable(onClick = onClick)
) {
Spacer(modifier = Modifier.size(padding))
Text(
modifier = Modifier.padding(start = padding, end = padding),
style = MaterialTheme.typography.h6,
text = item.title
)
item.imageUrl?.let { url ->
Spacer(modifier = Modifier.size(padding))
Image(
painter = rememberAsyncImagePainter(url),
modifier = Modifier.height(180.dp).fillMaxWidth(),
contentDescription = null
)
}
item.desc?.let { desc ->
Spacer(modifier = Modifier.size(padding))
Text(
modifier = Modifier.padding(start = padding, end = padding),
style = MaterialTheme.typography.body1,
maxLines = 5,
overflow = TextOverflow.Ellipsis,
text = desc
)
}
Spacer(modifier = Modifier.size(padding))
Text(
modifier = Modifier.padding(start = padding, end = padding),
style = MaterialTheme.typography.body2,
color = MaterialTheme.colors.onSurface.copy(alpha = 0.7f),
text = dateFormatter.format(Date(item.date))
)
Spacer(modifier = Modifier.size(padding))
}
}
}
}