Benoit Marty
2 years ago
6 changed files with 123 additions and 6 deletions
@ -0,0 +1,101 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2022 New Vector Ltd |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0 |
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
|
||||||
|
package io.element.android.x.matrix.ui.components |
||||||
|
|
||||||
|
import androidx.compose.foundation.clickable |
||||||
|
import androidx.compose.foundation.layout.Column |
||||||
|
import androidx.compose.foundation.layout.IntrinsicSize |
||||||
|
import androidx.compose.foundation.layout.Row |
||||||
|
import androidx.compose.foundation.layout.fillMaxWidth |
||||||
|
import androidx.compose.foundation.layout.height |
||||||
|
import androidx.compose.foundation.layout.padding |
||||||
|
import androidx.compose.material3.MaterialTheme |
||||||
|
import androidx.compose.material3.Text |
||||||
|
import androidx.compose.runtime.Composable |
||||||
|
import androidx.compose.ui.Alignment |
||||||
|
import androidx.compose.ui.Modifier |
||||||
|
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.compose.ui.unit.sp |
||||||
|
import io.element.android.x.designsystem.ElementXTheme |
||||||
|
import io.element.android.x.designsystem.components.avatar.Avatar |
||||||
|
import io.element.android.x.designsystem.components.avatar.AvatarData |
||||||
|
import io.element.android.x.matrix.core.UserId |
||||||
|
import io.element.android.x.matrix.ui.model.MatrixUser |
||||||
|
import io.element.android.x.matrix.ui.model.getBestName |
||||||
|
|
||||||
|
@Composable |
||||||
|
fun MatrixUserRow( |
||||||
|
matrixUser: MatrixUser, |
||||||
|
modifier: Modifier = Modifier, |
||||||
|
onClick: () -> Unit = {}, |
||||||
|
) { |
||||||
|
Row( |
||||||
|
modifier = modifier |
||||||
|
.clickable(onClick = onClick) |
||||||
|
.fillMaxWidth() |
||||||
|
.padding(horizontal = 16.dp) |
||||||
|
.height(IntrinsicSize.Min), |
||||||
|
verticalAlignment = Alignment.CenterVertically |
||||||
|
) { |
||||||
|
Avatar( |
||||||
|
matrixUser.avatarData, |
||||||
|
) |
||||||
|
Column( |
||||||
|
modifier = Modifier |
||||||
|
.padding(start = 12.dp, end = 4.dp, top = 12.dp, bottom = 12.dp) |
||||||
|
.alignByBaseline() |
||||||
|
.weight(1f) |
||||||
|
) { |
||||||
|
// Name |
||||||
|
Text( |
||||||
|
fontSize = 16.sp, |
||||||
|
fontWeight = FontWeight.SemiBold, |
||||||
|
text = matrixUser.getBestName(), |
||||||
|
maxLines = 1, |
||||||
|
overflow = TextOverflow.Ellipsis |
||||||
|
) |
||||||
|
// Id |
||||||
|
if (matrixUser.username.isNullOrEmpty().not()) { |
||||||
|
Text( |
||||||
|
text = matrixUser.id.value, |
||||||
|
color = MaterialTheme.colorScheme.secondary, |
||||||
|
fontSize = 14.sp, |
||||||
|
maxLines = 1, |
||||||
|
overflow = TextOverflow.Ellipsis |
||||||
|
) |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
@Preview |
||||||
|
@Composable |
||||||
|
fun MatrixUserRowPreview() { |
||||||
|
ElementXTheme { |
||||||
|
MatrixUserRow( |
||||||
|
MatrixUser( |
||||||
|
id = UserId("@alice:server.org"), |
||||||
|
username = "Alice", |
||||||
|
avatarUrl = null, |
||||||
|
avatarData = AvatarData("Alice") |
||||||
|
) |
||||||
|
) |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue