2022-10-11 18:10:31 +00:00
|
|
|
package dev.lonami.talaria.ui
|
|
|
|
|
|
|
|
import androidx.compose.foundation.Image
|
2022-10-12 09:44:38 +00:00
|
|
|
import androidx.compose.foundation.clickable
|
2022-10-11 18:10:31 +00:00
|
|
|
import androidx.compose.foundation.layout.Column
|
|
|
|
import androidx.compose.foundation.layout.Row
|
|
|
|
import androidx.compose.foundation.layout.fillMaxWidth
|
|
|
|
import androidx.compose.foundation.layout.padding
|
|
|
|
import androidx.compose.foundation.lazy.LazyColumn
|
|
|
|
import androidx.compose.material.Card
|
|
|
|
import androidx.compose.material.Switch
|
|
|
|
import androidx.compose.material.Text
|
|
|
|
import androidx.compose.runtime.Composable
|
2022-10-11 18:58:40 +00:00
|
|
|
import androidx.compose.runtime.collectAsState
|
|
|
|
import androidx.compose.runtime.getValue
|
2022-10-11 18:10:31 +00:00
|
|
|
import androidx.compose.ui.Modifier
|
|
|
|
import androidx.compose.ui.res.painterResource
|
|
|
|
import androidx.compose.ui.res.stringResource
|
|
|
|
import androidx.compose.ui.text.font.FontWeight
|
|
|
|
import androidx.compose.ui.tooling.preview.Preview
|
|
|
|
import androidx.compose.ui.unit.dp
|
2022-10-11 18:58:40 +00:00
|
|
|
import androidx.lifecycle.viewmodel.compose.viewModel
|
2022-10-11 18:10:31 +00:00
|
|
|
import dev.lonami.talaria.R
|
|
|
|
import dev.lonami.talaria.model.Dialog
|
|
|
|
import dev.lonami.talaria.ui.theme.TalariaTheme
|
|
|
|
|
|
|
|
@Composable
|
2022-10-12 09:44:38 +00:00
|
|
|
fun DialogCard(dialog: Dialog, onDialogSelected: () -> Unit) {
|
2022-10-11 18:10:31 +00:00
|
|
|
Card(
|
|
|
|
modifier = Modifier
|
|
|
|
.fillMaxWidth()
|
|
|
|
.padding(8.dp, 16.dp)
|
2022-10-12 09:44:38 +00:00
|
|
|
.clickable(onClick = onDialogSelected)
|
2022-10-11 18:10:31 +00:00
|
|
|
) {
|
|
|
|
Row {
|
|
|
|
Image(
|
|
|
|
painter = painterResource(R.drawable.ic_launcher_foreground),
|
|
|
|
contentDescription = stringResource(R.string.profile_photo),
|
|
|
|
)
|
|
|
|
Column(modifier = Modifier.weight(1.0f)) {
|
|
|
|
Text(dialog.title, fontWeight = FontWeight.Bold)
|
|
|
|
Text(dialog.lastMessage)
|
|
|
|
}
|
|
|
|
Switch(dialog.pinned, enabled = false, onCheckedChange = null)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Composable
|
2022-10-12 09:44:38 +00:00
|
|
|
fun DialogList(dialogs: List<Dialog>, onDialogSelected: (Int) -> Unit) {
|
2022-10-11 18:10:31 +00:00
|
|
|
LazyColumn {
|
2022-10-12 09:44:38 +00:00
|
|
|
items(dialogs.size) {
|
|
|
|
DialogCard(dialogs[it], onDialogSelected = {
|
|
|
|
onDialogSelected(it)
|
|
|
|
})
|
|
|
|
}
|
2022-10-11 18:10:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-11 18:58:40 +00:00
|
|
|
@Composable
|
2022-10-12 09:44:38 +00:00
|
|
|
fun DialogScreen(onDialogSelected: (Int) -> Unit, dialogViewModel: DialogViewModel = viewModel()) {
|
2022-10-11 18:58:40 +00:00
|
|
|
val dialogUiState by dialogViewModel.uiState.collectAsState()
|
2022-10-12 09:44:38 +00:00
|
|
|
DialogList(dialogUiState.dialogs, onDialogSelected = onDialogSelected)
|
2022-10-11 18:58:40 +00:00
|
|
|
}
|
|
|
|
|
2022-10-11 18:10:31 +00:00
|
|
|
@Preview
|
|
|
|
@Composable
|
|
|
|
fun DialogPreview() {
|
|
|
|
TalariaTheme {
|
2022-10-12 09:44:38 +00:00
|
|
|
DialogScreen(onDialogSelected = { })
|
2022-10-11 18:10:31 +00:00
|
|
|
}
|
|
|
|
}
|