Talaria/app/src/main/java/dev/lonami/talaria/ui/screens/DialogScreen.kt

136 lines
4.5 KiB
Kotlin
Raw Normal View History

package dev.lonami.talaria.ui.screens
import androidx.compose.foundation.Image
2022-10-12 09:44:38 +00:00
import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.*
import androidx.compose.foundation.lazy.LazyColumn
2022-10-24 10:44:41 +00:00
import androidx.compose.material.Divider
import androidx.compose.material.Icon
2022-10-24 10:44:41 +00:00
import androidx.compose.material.Surface
import androidx.compose.material.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.collectAsState
import androidx.compose.runtime.getValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.layout.ContentScale
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.text.style.TextOverflow
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import androidx.lifecycle.viewmodel.compose.viewModel
import dev.lonami.talaria.R
import dev.lonami.talaria.data.MockDialogRepository
import dev.lonami.talaria.models.Dialog
import dev.lonami.talaria.models.MessageAck
import dev.lonami.talaria.ui.state.DialogViewModel
import dev.lonami.talaria.ui.theme.TalariaTheme
import java.time.format.DateTimeFormatter
import java.time.format.FormatStyle
@Composable
fun Dialog(dialog: Dialog, onDialogSelected: () -> Unit, modifier: Modifier = Modifier) {
2022-10-24 10:44:41 +00:00
Row(
modifier = modifier
2022-10-24 10:44:41 +00:00
.padding(4.dp)
2022-10-12 09:44:38 +00:00
.clickable(onClick = onDialogSelected)
) {
2022-10-24 10:44:41 +00:00
Image(
painter = painterResource(R.drawable.ic_launcher_foreground),
contentDescription = stringResource(R.string.profile_photo),
contentScale = ContentScale.Fit,
modifier = Modifier.height(48.dp),
)
Column(modifier = Modifier.weight(1.0f)) {
Text(
dialog.title,
fontWeight = FontWeight.SemiBold,
maxLines = 1,
overflow = TextOverflow.Ellipsis
)
2022-10-24 10:44:41 +00:00
if (dialog.lastMessage != null) {
Text(
2022-10-24 10:44:41 +00:00
stringResource(
R.string.message_preview,
dialog.lastMessage.sender,
dialog.lastMessage.text
),
maxLines = 1,
2022-10-24 10:44:41 +00:00
overflow = TextOverflow.Ellipsis,
)
}
2022-10-24 10:44:41 +00:00
}
Column {
if (dialog.lastMessage != null) {
Row {
when (dialog.lastMessage.ack) {
MessageAck.RECEIVED -> {}
MessageAck.SENT -> Icon(
painterResource(R.drawable.sent),
stringResource(R.string.sent)
)
MessageAck.SEEN -> Icon(
painterResource(R.drawable.seen),
stringResource(R.string.seen)
)
}
2022-10-24 10:44:41 +00:00
Spacer(Modifier.width(8.dp))
Text(
dialog.lastMessage.date.format(
DateTimeFormatter.ofLocalizedTime(
FormatStyle.SHORT
)
),
)
}
}
2022-10-24 10:44:41 +00:00
if (dialog.pinned) {
Icon(
painterResource(R.drawable.tack),
stringResource(R.string.pinned),
modifier = Modifier.align(Alignment.End)
)
}
}
}
}
@Composable
fun DialogList(
dialogs: List<Dialog>,
onDialogSelected: (String) -> Unit,
modifier: Modifier = Modifier,
) {
LazyColumn(modifier = modifier) {
2022-10-12 09:44:38 +00:00
items(dialogs.size) {
2022-10-24 10:44:41 +00:00
Dialog(dialogs[it], onDialogSelected = {
2022-10-23 18:25:45 +00:00
onDialogSelected(dialogs[it].id)
2022-10-12 09:44:38 +00:00
})
2022-10-24 10:44:41 +00:00
Divider(startIndent = 52.dp)
2022-10-12 09:44:38 +00:00
}
}
}
@Composable
2022-10-12 19:26:51 +00:00
fun DialogScreen(
onDialogSelected: (String) -> Unit,
modifier: Modifier = Modifier,
dialogViewModel: DialogViewModel = viewModel(),
2022-10-12 19:26:51 +00:00
) {
val dialogUiState by dialogViewModel.uiState.collectAsState()
Surface(modifier = modifier) {
2022-10-24 10:44:41 +00:00
DialogList(dialogUiState.dialogs, onDialogSelected = onDialogSelected)
}
}
@Preview
@Composable
fun DialogPreview() {
val viewModel = DialogViewModel(MockDialogRepository())
TalariaTheme {
2022-10-21 12:19:34 +00:00
DialogScreen(onDialogSelected = { }, dialogViewModel = viewModel)
}
}