-
Notifications
You must be signed in to change notification settings - Fork 19
/
ReactionOption.kt
99 lines (96 loc) 路 4.07 KB
/
ReactionOption.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
95
96
97
98
99
package com.wire.android.ui.edit
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.PaddingValues
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.defaultMinSize
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.width
import androidx.compose.material3.Button
import androidx.compose.material3.ButtonDefaults
import androidx.compose.material3.ExperimentalMaterial3Api
import androidx.compose.material3.Icon
import androidx.compose.material3.IconButton
import androidx.compose.material3.LocalContentColor
import androidx.compose.material3.LocalMinimumInteractiveComponentEnforcement
import androidx.compose.material3.MaterialTheme
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.CompositionLocalProvider
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.alpha
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.text.TextStyle
import androidx.compose.ui.unit.TextUnit
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import com.wire.android.R
import com.wire.android.ui.common.dimensions
import com.wire.android.ui.theme.WireTheme
import com.wire.android.ui.theme.wireColorScheme
import com.wire.android.ui.theme.wireTypography
import com.wire.android.util.ui.PreviewMultipleThemes
@OptIn(ExperimentalMaterial3Api::class)
@Composable
fun ReactionOption(
onReactionClick: (emoji: String) -> Unit,
emojiFontSize: TextUnit = 28.sp
) {
CompositionLocalProvider(LocalContentColor provides MaterialTheme.colorScheme.secondary) {
Column {
Row {
Spacer(modifier = Modifier.width(dimensions().spacing8x))
Text(
stringResource(R.string.label_reactions).uppercase(),
style = MaterialTheme.wireTypography.label01
)
}
Row(
modifier = Modifier.fillMaxWidth(),
verticalAlignment = Alignment.CenterVertically,
horizontalArrangement = Arrangement.SpaceEvenly
) {
listOf("鉂わ笍", "馃憤", "馃榿", "馃檪", "鈽癸笍", "馃憥").forEach { emoji ->
CompositionLocalProvider(
LocalMinimumInteractiveComponentEnforcement provides false
) {
Button(
onClick = {
onReactionClick(emoji)
},
modifier = Modifier.defaultMinSize(minWidth = 1.dp, minHeight = 1.dp),
contentPadding = PaddingValues(dimensions().spacing8x),
colors = ButtonDefaults.buttonColors(
containerColor = MaterialTheme.wireColorScheme.surface,
contentColor = MaterialTheme.wireColorScheme.secondaryButtonSelectedOutline
)
) {
Text(emoji, style = TextStyle(fontSize = emojiFontSize))
}
}
}
IconButton(
onClick = {
// TODO show more emojis
},
modifier = Modifier
// TODO remove when all emojis will be available
.alpha(0.1F),
) {
Icon(
painter = painterResource(id = R.drawable.ic_more_emojis),
contentDescription = stringResource(R.string.content_description_more_emojis)
)
}
}
}
}
}
@PreviewMultipleThemes
@Composable
private fun BasePreview() = WireTheme(isPreview = true) {
ReactionOption(onReactionClick = {})
}