mirror of
https://github.com/oxen-io/session-android.git
synced 2024-11-27 20:15:21 +00:00
Add image attachments
This commit is contained in:
parent
4decce9dde
commit
1303979cdf
@ -10,11 +10,13 @@ import androidx.compose.foundation.layout.Column
|
|||||||
import androidx.compose.foundation.layout.ExperimentalLayoutApi
|
import androidx.compose.foundation.layout.ExperimentalLayoutApi
|
||||||
import androidx.compose.foundation.layout.FlowRow
|
import androidx.compose.foundation.layout.FlowRow
|
||||||
import androidx.compose.foundation.layout.Row
|
import androidx.compose.foundation.layout.Row
|
||||||
|
import androidx.compose.foundation.layout.aspectRatio
|
||||||
import androidx.compose.foundation.layout.fillMaxWidth
|
import androidx.compose.foundation.layout.fillMaxWidth
|
||||||
import androidx.compose.foundation.layout.height
|
import androidx.compose.foundation.layout.height
|
||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.layout.width
|
import androidx.compose.foundation.layout.width
|
||||||
import androidx.compose.foundation.pager.HorizontalPager
|
import androidx.compose.foundation.pager.HorizontalPager
|
||||||
|
import androidx.compose.foundation.pager.rememberPagerState
|
||||||
import androidx.compose.foundation.rememberScrollState
|
import androidx.compose.foundation.rememberScrollState
|
||||||
import androidx.compose.foundation.verticalScroll
|
import androidx.compose.foundation.verticalScroll
|
||||||
import androidx.compose.material.Divider
|
import androidx.compose.material.Divider
|
||||||
@ -230,31 +232,7 @@ class MessageDetailActivity: PassphraseRequiredActionBarActivity() {
|
|||||||
modifier = Modifier.verticalScroll(rememberScrollState()),
|
modifier = Modifier.verticalScroll(rememberScrollState()),
|
||||||
verticalArrangement = Arrangement.spacedBy(16.dp)
|
verticalArrangement = Arrangement.spacedBy(16.dp)
|
||||||
) {
|
) {
|
||||||
HorizontalPager(pageCount = attachments.size) {i ->
|
Attachments(attachments)
|
||||||
val attachment = attachments[i]
|
|
||||||
attachment.apply {
|
|
||||||
Column(verticalArrangement = Arrangement.spacedBy(16.dp)) {
|
|
||||||
Cell {
|
|
||||||
if (slide.hasImage()) GlideImage(
|
|
||||||
contentScale = ContentScale.FillHeight,
|
|
||||||
modifier = Modifier.fillMaxWidth(),
|
|
||||||
model = attachment.slide.uri,
|
|
||||||
contentDescription = attachment.slide.fileName.orNull() ?: "image"
|
|
||||||
)
|
|
||||||
}
|
|
||||||
fileDetails.takeIf { it.isNotEmpty() }?.let {
|
|
||||||
CellWithPadding {
|
|
||||||
FlowRow(
|
|
||||||
verticalArrangement = Arrangement.spacedBy(16.dp),
|
|
||||||
maxItemsInEachRow = 2
|
|
||||||
) {
|
|
||||||
it.forEach { titledText(it, Modifier.weight(1f)) }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (sent != null || received != null || senderInfo != null) CellWithPadding {
|
if (sent != null || received != null || senderInfo != null) CellWithPadding {
|
||||||
Column(verticalArrangement = Arrangement.spacedBy(16.dp)) {
|
Column(verticalArrangement = Arrangement.spacedBy(16.dp)) {
|
||||||
sent?.let { titledText(it) }
|
sent?.let { titledText(it) }
|
||||||
@ -299,6 +277,50 @@ class MessageDetailActivity: PassphraseRequiredActionBarActivity() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
fun Attachments(attachments: List<Attachment>) {
|
||||||
|
val slide = attachments.firstOrNull()?.slide ?: return
|
||||||
|
when {
|
||||||
|
slide.hasImage() -> ImageAttachments(attachments)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@OptIn(
|
||||||
|
ExperimentalFoundationApi::class,
|
||||||
|
ExperimentalGlideComposeApi::class,
|
||||||
|
ExperimentalLayoutApi::class,
|
||||||
|
)
|
||||||
|
@Composable
|
||||||
|
fun ImageAttachments(attachments: List<Attachment>) {
|
||||||
|
val pagerState = rememberPagerState()
|
||||||
|
|
||||||
|
Column(verticalArrangement = Arrangement.spacedBy(16.dp)) {
|
||||||
|
Cell {
|
||||||
|
val imageAttachments = attachments.filter { it.slide.hasImage() }
|
||||||
|
HorizontalPager(state = pagerState, pageCount = imageAttachments.size) { i ->
|
||||||
|
imageAttachments[i].slide.apply {
|
||||||
|
GlideImage(
|
||||||
|
contentScale = ContentScale.Crop,
|
||||||
|
modifier = Modifier.aspectRatio(1f),
|
||||||
|
model = uri,
|
||||||
|
contentDescription = fileName.orNull() ?: "image"
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
attachments[pagerState.currentPage].fileDetails.takeIf { it.isNotEmpty() }?.let {
|
||||||
|
CellWithPadding {
|
||||||
|
FlowRow(
|
||||||
|
verticalArrangement = Arrangement.spacedBy(16.dp),
|
||||||
|
maxItemsInEachRow = 2
|
||||||
|
) {
|
||||||
|
it.forEach { titledText(it, Modifier.weight(1f)) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun Divider() {
|
fun Divider() {
|
||||||
Divider(modifier = Modifier.padding(horizontal = 16.dp), thickness = 1.dp, color = LocalExtraColors.current.divider)
|
Divider(modifier = Modifier.padding(horizontal = 16.dp), thickness = 1.dp, color = LocalExtraColors.current.divider)
|
||||||
|
Loading…
Reference in New Issue
Block a user