Allow manual selection of manga description instead of copying to clipboard
Closes #6548 Notably missing some "standard" options like "Select all" or "Share": https://issuetracker.google.com/issues/226648919
This commit is contained in:
parent
cf6407c4d4
commit
60bcebe4d1
@ -21,6 +21,7 @@ import androidx.compose.foundation.layout.size
|
|||||||
import androidx.compose.foundation.layout.sizeIn
|
import androidx.compose.foundation.layout.sizeIn
|
||||||
import androidx.compose.foundation.lazy.LazyRow
|
import androidx.compose.foundation.lazy.LazyRow
|
||||||
import androidx.compose.foundation.lazy.items
|
import androidx.compose.foundation.lazy.items
|
||||||
|
import androidx.compose.foundation.text.selection.SelectionContainer
|
||||||
import androidx.compose.material.icons.Icons
|
import androidx.compose.material.icons.Icons
|
||||||
import androidx.compose.material.icons.filled.AttachMoney
|
import androidx.compose.material.icons.filled.AttachMoney
|
||||||
import androidx.compose.material.icons.filled.Block
|
import androidx.compose.material.icons.filled.Block
|
||||||
@ -209,7 +210,6 @@ fun ExpandableMangaDescription(
|
|||||||
tagsProvider: () -> List<String>?,
|
tagsProvider: () -> List<String>?,
|
||||||
onTagClicked: (String) -> Unit,
|
onTagClicked: (String) -> Unit,
|
||||||
) {
|
) {
|
||||||
val context = LocalContext.current
|
|
||||||
Column(modifier = modifier) {
|
Column(modifier = modifier) {
|
||||||
val (expanded, onExpanded) = rememberSaveable {
|
val (expanded, onExpanded) = rememberSaveable {
|
||||||
mutableStateOf(defaultExpandState)
|
mutableStateOf(defaultExpandState)
|
||||||
@ -228,10 +228,7 @@ fun ExpandableMangaDescription(
|
|||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.padding(top = 8.dp)
|
.padding(top = 8.dp)
|
||||||
.padding(horizontal = 16.dp)
|
.padding(horizontal = 16.dp)
|
||||||
.clickableNoIndication(
|
.clickableNoIndication { onExpanded(!expanded) },
|
||||||
onLongClick = { context.copyToClipboard(desc, desc) },
|
|
||||||
onClick = { onExpanded(!expanded) },
|
|
||||||
),
|
|
||||||
)
|
)
|
||||||
val tags = tagsProvider()
|
val tags = tagsProvider()
|
||||||
if (!tags.isNullOrEmpty()) {
|
if (!tags.isNullOrEmpty()) {
|
||||||
@ -566,13 +563,15 @@ private fun MangaSummary(
|
|||||||
expandedHeight = expandedPlaceable.maxByOrNull { it.height }?.height?.coerceAtLeast(shrunkHeight) ?: 0
|
expandedHeight = expandedPlaceable.maxByOrNull { it.height }?.height?.coerceAtLeast(shrunkHeight) ?: 0
|
||||||
|
|
||||||
val actualPlaceable = subcompose("description") {
|
val actualPlaceable = subcompose("description") {
|
||||||
Text(
|
SelectionContainer {
|
||||||
text = if (expanded) expandedDescription else shrunkDescription,
|
Text(
|
||||||
maxLines = Int.MAX_VALUE,
|
text = if (expanded) expandedDescription else shrunkDescription,
|
||||||
style = MaterialTheme.typography.bodyMedium,
|
maxLines = Int.MAX_VALUE,
|
||||||
color = MaterialTheme.colorScheme.onBackground,
|
style = MaterialTheme.typography.bodyMedium,
|
||||||
modifier = Modifier.secondaryItemAlpha(),
|
color = MaterialTheme.colorScheme.onBackground,
|
||||||
)
|
modifier = Modifier.secondaryItemAlpha(),
|
||||||
|
)
|
||||||
|
}
|
||||||
}.map { it.measure(constraints) }
|
}.map { it.measure(constraints) }
|
||||||
|
|
||||||
val scrimPlaceable = subcompose("scrim") {
|
val scrimPlaceable = subcompose("scrim") {
|
||||||
|
Loading…
Reference in New Issue
Block a user